mirror of
https://github.com/misskey-dev/misskey
synced 2024-12-27 04:59:10 +09:00
343 lines
10 KiB
Vue
343 lines
10 KiB
Vue
<template>
|
|
<div class="mwysmxbg">
|
|
<div class="_isolated">{{ $ts._mfm.intro }}</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.mention }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.mentionDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_mention"/>
|
|
<MkTextarea v-model:value="preview_mention"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.hashtag }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.hashtagDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_hashtag"/>
|
|
<MkTextarea v-model:value="preview_hashtag"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.url }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.urlDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_url"/>
|
|
<MkTextarea v-model:value="preview_url"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.link }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.linkDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_link"/>
|
|
<MkTextarea v-model:value="preview_link"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.emoji }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.emojiDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_emoji"/>
|
|
<MkTextarea v-model:value="preview_emoji"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.bold }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.boldDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_bold"/>
|
|
<MkTextarea v-model:value="preview_bold"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.small }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.smallDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_small"/>
|
|
<MkTextarea v-model:value="preview_small"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.quote }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.quoteDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_quote"/>
|
|
<MkTextarea v-model:value="preview_quote"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.center }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.centerDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_center"/>
|
|
<MkTextarea v-model:value="preview_center"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.inlineCode }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.inlineCodeDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_inlineCode"/>
|
|
<MkTextarea v-model:value="preview_inlineCode"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.blockCode }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.blockCodeDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_blockCode"/>
|
|
<MkTextarea v-model:value="preview_blockCode"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.inlineMath }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.inlineMathDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_inlineMath"/>
|
|
<MkTextarea v-model:value="preview_inlineMath"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.search }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.searchDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_search"/>
|
|
<MkTextarea v-model:value="preview_search"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.flip }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.flipDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_flip"/>
|
|
<MkTextarea v-model:value="preview_flip"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.font }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.fontDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_font"/>
|
|
<MkTextarea v-model:value="preview_font"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.x2 }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.x2Description }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_x2"/>
|
|
<MkTextarea v-model:value="preview_x2"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.x3 }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.x3Description }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_x3"/>
|
|
<MkTextarea v-model:value="preview_x3"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.x4 }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.x4Description }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_x4"/>
|
|
<MkTextarea v-model:value="preview_x4"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.blur }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.blurDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_blur"/>
|
|
<MkTextarea v-model:value="preview_blur"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.jelly }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.jellyDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_jelly"/>
|
|
<MkTextarea v-model:value="preview_jelly"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.tada }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.tadaDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_tada"/>
|
|
<MkTextarea v-model:value="preview_tada"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.jump }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.jumpDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_jump"/>
|
|
<MkTextarea v-model:value="preview_jump"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.bounce }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.bounceDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_bounce"/>
|
|
<MkTextarea v-model:value="preview_bounce"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.spin }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.spinDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_spin"/>
|
|
<MkTextarea v-model:value="preview_spin"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.shake }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.shakeDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_shake"/>
|
|
<MkTextarea v-model:value="preview_shake"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section _block">
|
|
<div class="title">{{ $ts._mfm.twitch }}</div>
|
|
<div class="content">
|
|
<p>{{ $ts._mfm.twitchDescription }}</p>
|
|
<div class="preview">
|
|
<Mfm :text="preview_twitch"/>
|
|
<MkTextarea v-model:value="preview_twitch"><span>MFM</span></MkTextarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { defineComponent } from 'vue';
|
|
import { faQuestionCircle } from '@fortawesome/free-regular-svg-icons';
|
|
import MkTextarea from '@client/components/ui/textarea.vue';
|
|
import * as symbols from '@client/symbols';
|
|
|
|
export default defineComponent({
|
|
components: {
|
|
MkTextarea
|
|
},
|
|
|
|
data() {
|
|
return {
|
|
[symbols.PAGE_INFO]: {
|
|
title: this.$ts._mfm.cheatSheet,
|
|
icon: faQuestionCircle,
|
|
},
|
|
preview_mention: '@example',
|
|
preview_hashtag: '#test',
|
|
preview_url: `https://example.com`,
|
|
preview_link: `[${this.$ts._mfm.dummy}](https://example.com)`,
|
|
preview_emoji: `:${this.$instance.emojis[0].name}:`,
|
|
preview_bold: `**${this.$ts._mfm.dummy}**`,
|
|
preview_small: `<small>${this.$ts._mfm.dummy}</small>`,
|
|
preview_center: `<center>${this.$ts._mfm.dummy}</center>`,
|
|
preview_inlineCode: '`<: "Hello, world!"`',
|
|
preview_blockCode: '```\n~ (#i, 100) {\n\t<: ? ((i % 15) = 0) "FizzBuzz"\n\t\t.? ((i % 3) = 0) "Fizz"\n\t\t.? ((i % 5) = 0) "Buzz"\n\t\t. i\n}\n```',
|
|
preview_inlineMath: '\\(x= \\frac{-b\' \\pm \\sqrt{(b\')^2-ac}}{a}\\)',
|
|
preview_quote: `> ${this.$ts._mfm.dummy}`,
|
|
preview_search: `${this.$ts._mfm.dummy} 検索`,
|
|
preview_jelly: `[jelly 🍮]`,
|
|
preview_tada: `[tada 🍮]`,
|
|
preview_jump: `[jump 🍮]`,
|
|
preview_bounce: `[bounce 🍮]`,
|
|
preview_shake: `[shake 🍮]`,
|
|
preview_twitch: `[twitch 🍮]`,
|
|
preview_spin: `[spin 🍮] [spin.left 🍮] [spin.alternate 🍮]\n[spin.x 🍮] [spin.x,left 🍮] [spin.x,alternate 🍮]\n[spin.y 🍮] [spin.y,left 🍮] [spin.y,alternate 🍮]`,
|
|
preview_flip: `[flip ${this.$ts._mfm.dummy}]\n[flip.v ${this.$ts._mfm.dummy}]\n[flip.h,v ${this.$ts._mfm.dummy}]`,
|
|
preview_font: `[font.serif ${this.$ts._mfm.dummy}]\n[font.monospace ${this.$ts._mfm.dummy}]\n[font.cursive ${this.$ts._mfm.dummy}]\n[font.fantasy ${this.$ts._mfm.dummy}]`,
|
|
preview_x2: `[x2 🍮]`,
|
|
preview_x3: `[x3 🍮]`,
|
|
preview_x4: `[x4 🍮]`,
|
|
preview_blur: `[blur ${this.$ts._mfm.dummy}]`,
|
|
}
|
|
},
|
|
});
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.mwysmxbg {
|
|
> .section {
|
|
> .title {
|
|
position: sticky;
|
|
z-index: 1;
|
|
top: var(--stickyTop, 0px);
|
|
padding: 16px;
|
|
font-weight: bold;
|
|
-webkit-backdrop-filter: blur(10px);
|
|
backdrop-filter: blur(10px);
|
|
background-color: var(--X16);
|
|
}
|
|
|
|
> .content {
|
|
> p {
|
|
margin: 0;
|
|
padding: 16px;
|
|
}
|
|
|
|
> .preview {
|
|
border-top: solid 0.5px var(--divider);
|
|
padding: 16px;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</style>
|