summaryrefslogtreecommitdiff
path: root/src/client/pages
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2021-08-08 23:25:21 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2021-08-08 23:25:21 +0900
commitc52e30e8e0fb0e84a30f5d422585de492bab59ca (patch)
treee23c4fd3ff4f089e0259f5e4e751b5bef6c18e1f /src/client/pages
parentMerge branch 'develop' (diff)
parent12.85.0 (diff)
downloadmisskey-c52e30e8e0fb0e84a30f5d422585de492bab59ca.tar.gz
misskey-c52e30e8e0fb0e84a30f5d422585de492bab59ca.tar.bz2
misskey-c52e30e8e0fb0e84a30f5d422585de492bab59ca.zip
Merge branch 'develop'
Diffstat (limited to 'src/client/pages')
-rw-r--r--src/client/pages/_error_.vue26
-rw-r--r--src/client/pages/advanced-theme-editor.vue2
-rw-r--r--src/client/pages/api-console.vue14
-rw-r--r--src/client/pages/channel-editor.vue8
-rw-r--r--src/client/pages/clip.vue2
-rw-r--r--src/client/pages/doc.vue189
-rw-r--r--src/client/pages/docs.vue124
-rw-r--r--src/client/pages/drive.vue1
-rw-r--r--src/client/pages/emojis.vue151
-rw-r--r--src/client/pages/explore.vue5
-rw-r--r--src/client/pages/federation.vue (renamed from src/client/pages/instance/federation.vue)189
-rw-r--r--src/client/pages/follow-requests.vue2
-rw-r--r--src/client/pages/instance-info.vue4
-rw-r--r--src/client/pages/instance/abuses.vue8
-rw-r--r--src/client/pages/instance/ads.vue20
-rw-r--r--src/client/pages/instance/announcements.vue12
-rw-r--r--src/client/pages/instance/emoji-edit-dialog.vue14
-rw-r--r--src/client/pages/instance/emojis.vue16
-rw-r--r--src/client/pages/instance/file-dialog.vue2
-rw-r--r--src/client/pages/instance/files.vue14
-rw-r--r--src/client/pages/instance/index.vue4
-rw-r--r--src/client/pages/instance/instance.vue12
-rw-r--r--src/client/pages/instance/logs.vue6
-rw-r--r--src/client/pages/instance/metrics.vue4
-rw-r--r--src/client/pages/instance/overview.vue4
-rw-r--r--src/client/pages/instance/queue.chart.vue2
-rw-r--r--src/client/pages/instance/users.vue16
-rw-r--r--src/client/pages/messaging/index.vue4
-rw-r--r--src/client/pages/messaging/messaging-room.vue8
-rw-r--r--src/client/pages/mfm-cheat-sheet.vue65
-rw-r--r--src/client/pages/my-antennas/create.vue51
-rw-r--r--src/client/pages/my-antennas/edit.vue56
-rw-r--r--src/client/pages/my-antennas/editor.vue (renamed from src/client/pages/my-antennas/index.antenna.vue)62
-rw-r--r--src/client/pages/my-antennas/index.vue59
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.button.vue16
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.canvas.vue15
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.counter.vue13
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.if.vue2
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.note.vue8
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.number-input.vue13
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.post.vue6
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.radio-button.vue8
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.switch.vue6
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.text-input.vue6
-rw-r--r--src/client/pages/page-editor/els/page-editor.el.textarea-input.vue6
-rw-r--r--src/client/pages/page-editor/page-editor.script-block.vue6
-rw-r--r--src/client/pages/page-editor/page-editor.vue20
-rw-r--r--src/client/pages/reversi/game.setting.vue8
-rw-r--r--src/client/pages/room/room.vue2
-rw-r--r--src/client/pages/settings/2fa.vue8
-rw-r--r--src/client/pages/settings/accounts.vue4
-rw-r--r--src/client/pages/settings/reaction.vue2
-rw-r--r--src/client/pages/test.vue42
-rw-r--r--src/client/pages/timeline.vue16
-rw-r--r--src/client/pages/user-info.vue12
-rw-r--r--src/client/pages/user/clips.vue2
-rw-r--r--src/client/pages/user/follow-list.vue2
-rw-r--r--src/client/pages/user/gallery.vue2
-rw-r--r--src/client/pages/user/index.photos.vue2
-rw-r--r--src/client/pages/user/index.vue21
-rw-r--r--src/client/pages/user/pages.vue2
-rw-r--r--src/client/pages/welcome.entrance.a.vue2
-rw-r--r--src/client/pages/welcome.entrance.b.vue2
-rw-r--r--src/client/pages/welcome.entrance.c.vue2
-rw-r--r--src/client/pages/welcome.setup.vue8
65 files changed, 975 insertions, 445 deletions
diff --git a/src/client/pages/_error_.vue b/src/client/pages/_error_.vue
index 6caecd6eaf..1d67d9b14d 100644
--- a/src/client/pages/_error_.vue
+++ b/src/client/pages/_error_.vue
@@ -1,11 +1,11 @@
<template>
<transition :name="$store.state.animation ? 'zoom' : ''" appear>
- <div class="_section">
- <div class="mjndxjch _content">
- <img src="https://xn--931a.moe/assets/error.jpg" class="_ghost"/>
- <p><i class="fas fa-exclamation-triangle"></i> {{ $ts.pageLoadError }}</p>
- <p>{{ $ts.pageLoadErrorDescription }}</p>
- </div>
+ <div class="mjndxjch">
+ <img src="https://xn--931a.moe/assets/error.jpg" class="_ghost"/>
+ <p><b><i class="fas fa-exclamation-triangle"></i> {{ $ts.pageLoadError }}</b></p>
+ <p>{{ $ts.pageLoadErrorDescription }}</p>
+ <p><MkA to="/docs/general/troubleshooting" class="_link">{{ $ts.troubleshooting }}</MkA></p>
+ <p v-if="error" class="error">ERROR: {{ error }}</p>
</div>
</transition>
</template>
@@ -19,6 +19,11 @@ export default defineComponent({
components: {
MkButton,
},
+ props: {
+ error: {
+ required: false,
+ }
+ },
data() {
return {
[symbols.PAGE_INFO]: {
@@ -32,10 +37,11 @@ export default defineComponent({
<style lang="scss" scoped>
.mjndxjch {
+ padding: 32px;
text-align: center;
> p {
- margin: 0 0 8px 0;
+ margin: 0 0 12px 0;
}
> .button {
@@ -45,8 +51,12 @@ export default defineComponent({
> img {
vertical-align: bottom;
height: 128px;
- margin-bottom: 16px;
+ margin-bottom: 24px;
border-radius: 16px;
}
+
+ > .error {
+ opacity: 0.7;
+ }
}
</style>
diff --git a/src/client/pages/advanced-theme-editor.vue b/src/client/pages/advanced-theme-editor.vue
index b40d9808ca..c03d88b82d 100644
--- a/src/client/pages/advanced-theme-editor.vue
+++ b/src/client/pages/advanced-theme-editor.vue
@@ -272,7 +272,7 @@ export default defineComponent({
showTypeMenu(e: MouseEvent) {
return new Promise<ThemeValue>((resolve) => {
- os.modalMenu([{
+ os.popupMenu([{
text: this.$ts._theme.defaultValue,
action: () => resolve(null),
}, {
diff --git a/src/client/pages/api-console.vue b/src/client/pages/api-console.vue
index b153d10396..adae17658c 100644
--- a/src/client/pages/api-console.vue
+++ b/src/client/pages/api-console.vue
@@ -1,13 +1,13 @@
<template>
<div class="_root">
<div class="_block" style="padding: 24px;">
- <MkInput v-model:value="endpoint" :datalist="endpoints" @update:value="onEndpointChange()">
- <span>Endpoint</span>
+ <MkInput v-model="endpoint" :datalist="endpoints" @update:modelValue="onEndpointChange()">
+ <template #label>Endpoint</template>
</MkInput>
- <MkTextarea v-model:value="body" code>
- <span>Params (JSON or JSON5)</span>
+ <MkTextarea v-model="body" code>
+ <template #label>Params (JSON or JSON5)</template>
</MkTextarea>
- <MkSwitch v-model:value="withCredential">
+ <MkSwitch v-model="withCredential">
With credential
</MkSwitch>
<MkButton primary full @click="send" :disabled="sending">
@@ -16,8 +16,8 @@
</MkButton>
</div>
<div v-if="res" class="_block" style="padding: 24px;">
- <MkTextarea v-model:value="res" code readonly tall>
- <span>Response</span>
+ <MkTextarea v-model="res" code readonly tall>
+ <template #label>Response</template>
</MkTextarea>
</div>
</div>
diff --git a/src/client/pages/channel-editor.vue b/src/client/pages/channel-editor.vue
index bc772d34fa..eeea0b70aa 100644
--- a/src/client/pages/channel-editor.vue
+++ b/src/client/pages/channel-editor.vue
@@ -2,9 +2,13 @@
<div>
<div class="_section">
<div class="_content">
- <MkInput v-model:value="name">{{ $ts.name }}</MkInput>
+ <MkInput v-model="name">
+ <template #label>{{ $ts.name }}</template>
+ </MkInput>
- <MkTextarea v-model:value="description">{{ $ts.description }}</MkTextarea>
+ <MkTextarea v-model="description">
+ <template #label>{{ $ts.description }}</template>
+ </MkTextarea>
<div class="banner">
<MkButton v-if="bannerId == null" @click="setBannerImage"><i class="fas fa-plus"></i> {{ $ts._channel.setBanner }}</MkButton>
diff --git a/src/client/pages/clip.vue b/src/client/pages/clip.vue
index 8777975557..e4b00d5e28 100644
--- a/src/client/pages/clip.vue
+++ b/src/client/pages/clip.vue
@@ -79,7 +79,7 @@ export default defineComponent({
methods: {
menu(ev) {
- os.modalMenu([this.isOwned ? {
+ os.popupMenu([this.isOwned ? {
icon: 'fas fa-pencil-alt',
text: this.$ts.edit,
action: async () => {
diff --git a/src/client/pages/doc.vue b/src/client/pages/doc.vue
index a4cf25033e..753dd8013d 100644
--- a/src/client/pages/doc.vue
+++ b/src/client/pages/doc.vue
@@ -1,9 +1,11 @@
<template>
<div class="qyqbqfal" v-size="{ max: [500] }">
- <div class="title">{{ title }}</div>
- <div class="body" v-html="body"></div>
- <div class="footer">
- <MkLink :url="`https://github.com/misskey-dev/misskey/blob/master/src/docs/${lang}/${doc}.md`" class="at">{{ $ts.docSource }}</MkLink>
+ <div class="main">
+ <div class="title">{{ title }}</div>
+ <div class="body" v-html="body"></div>
+ <div class="footer">
+ <MkLink :url="`https://github.com/misskey-dev/misskey/blob/master/src/docs/${lang}/${doc}.md`" class="at">{{ $ts.docSource }}</MkLink>
+ </div>
</div>
</div>
</template>
@@ -62,6 +64,10 @@ export default defineComponent({
fetchDoc() {
fetch(`${url}/doc-assets/${lang}/${this.doc}.md`).then(res => res.text()).then(md => {
this.parse(md);
+ }).catch(() => {
+ fetch(`${url}/doc-assets/ja-JP/${this.doc}.md`).then(res => res.text()).then(md => {
+ this.parse(md);
+ });
});
},
@@ -105,102 +111,129 @@ export default defineComponent({
<style lang="scss" scoped>
.qyqbqfal {
padding: 32px;
- max-width: 800px;
- margin: 0 auto;
+ background: var(--panel);
+ line-height: 1.5;
&.max-width_500px {
padding: 16px;
}
- > .title {
- font-size: 1.5em;
- font-weight: bold;
- padding: 0 0 0.75em 0;
- margin: 0 0 1em 0;
- border-bottom: solid 2px var(--divider);
- }
+ > .main {
+ max-width: 800px;
+ margin: 0 auto;
- > .body {
- > *:first-child {
- margin-top: 0;
+ > .title {
+ font-size: 1.5em;
+ font-weight: bold;
+ padding: 0 0 0.75em 0;
+ margin: 0 0 1em 0;
+ border-bottom: solid 2px var(--divider);
}
- > *:last-child {
- margin-bottom: 0;
- }
+ > .body {
+ > *:first-child {
+ margin-top: 0;
+ }
- ::v-deep(a) {
- color: var(--link);
- }
+ > *:last-child {
+ margin-bottom: 0;
+ }
+
+ ::v-deep(a) {
+ color: var(--link);
+ }
- ::v-deep(blockquote) {
- display: block;
- margin: 8px;
- padding: 6px 0 6px 12px;
- color: var(--fg);
- border-left: solid 3px var(--fg);
- opacity: 0.7;
+ ::v-deep(blockquote) {
+ display: block;
+ margin: 8px;
+ padding: 6px 0 6px 12px;
+ color: var(--fg);
+ border-left: solid 3px var(--fg);
+ opacity: 0.7;
- p {
- margin: 0;
+ p {
+ margin: 0;
+ }
}
- }
- ::v-deep(h2) {
- font-size: 1.25em;
- padding: 0 0 0.5em 0;
- margin: 1.5em 0 1em 0;
- border-bottom: solid 0.5px var(--divider);
- }
+ ::v-deep(h2) {
+ font-size: 1.25em;
+ padding: 0 0 0.5em 0;
+ margin: 1.5em 0 1em 0;
+ border-bottom: solid 0.5px var(--divider);
+ }
- ::v-deep(table) {
- width: 100%;
- max-width: 100%;
- overflow: auto;
- }
+ ::v-deep(h3) {
+ margin: 1.25em 0 0.5em 0;
+ }
- ::v-deep(kbd.group) {
- display: inline-block;
- padding: 2px;
- border: 1px solid var(--divider);
- border-radius: 4px;
- box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
- }
+ ::v-deep(table) {
+ width: 100%;
+ max-width: 100%;
+ overflow: auto;
+ }
- ::v-deep(kbd.key) {
- display: inline-block;
- padding: 6px 8px;
- border: solid 0.5px var(--divider);
- border-radius: 4px;
- box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
- }
+ ::v-deep(kbd.group) {
+ display: inline-block;
+ padding: 2px;
+ border: 1px solid var(--divider);
+ border-radius: 4px;
+ box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
+ }
- ::v-deep(code) {
- display: inline-block;
- font-family: Fira code, Fira Mono, Consolas, Menlo, Courier, monospace;
- tab-size: 2;
- background: #272822;
- color: #f8f8f2;
- border-radius: 6px;
- padding: 4px 6px;
- }
+ ::v-deep(kbd.key) {
+ display: inline-block;
+ padding: 6px 8px;
+ border: solid 0.5px var(--divider);
+ border-radius: 4px;
+ box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
+ }
+
+ ::v-deep(code) {
+ display: inline-block;
+ font-family: Fira code, Fira Mono, Consolas, Menlo, Courier, monospace;
+ tab-size: 2;
+ background: #272822;
+ color: #f8f8f2;
+ border-radius: 6px;
+ padding: 4px 6px;
+ }
- ::v-deep(pre) {
- background: #272822;
- color: #f8f8f2;
- border-radius: 6px;
- padding: 12px 16px;
+ ::v-deep(pre) {
+ background: #272822;
+ color: #f8f8f2;
+ border-radius: 6px;
+ padding: 12px 16px;
- > code {
- padding: 0;
+ > code {
+ padding: 0;
+ }
+ }
+
+ ::v-deep(.info) {
+ font-size: 90%;
+ background: var(--infoBg);
+ color: var(--infoFg);
+ padding: 1em;
+ margin: 0.75em 0;
+ border-radius: 6px;
+ }
+
+ ::v-deep(.warn) {
+ font-size: 90%;
+ background: var(--infoWarnBg);
+ color: var(--infoWarnFg);
+ padding: 1em;
+ margin: 0.75em 0;
+ border-radius: 6px;
}
}
- }
- > .footer {
- padding: 1.5em 0 0 0;
- margin: 1.5em 0 0 0;
- border-top: solid 2px var(--divider);
+ > .footer {
+ padding: 1.5em 0 0 0;
+ margin: 1.5em 0 0 0;
+ border-top: solid 2px var(--divider);
+ }
}
}
</style>
diff --git a/src/client/pages/docs.vue b/src/client/pages/docs.vue
index e51528f83d..6dc5eb1ae8 100644
--- a/src/client/pages/docs.vue
+++ b/src/client/pages/docs.vue
@@ -1,14 +1,50 @@
<template>
-<div>
- <main class="_section">
- <div class="_content">
- <ul>
- <li v-for="doc in docs" :key="doc.path">
- <MkA :to="`/docs/${doc.path}`">{{ doc.title }}</MkA>
- </li>
- </ul>
+<div class="vtaihdtm">
+ <div class="search">
+ <MkInput v-model="query" :debounce="true" type="search" class="_inputNoTopMargin _inputNoBottomMargin" :placeholder="$ts.search">
+ <template #prefix><i class="fas fa-search"></i></template>
+ </MkInput>
+ </div>
+ <MkFolder>
+ <template #header>{{ $ts._docs.generalTopics }}</template>
+ <div class="docs">
+ <MkA v-for="doc in docs.filter(doc => doc.path.startsWith('general/'))" :key="doc.path" :to="`/docs/${doc.path}`" class="doc">
+ <div class="title">{{ doc.title }}</div>
+ <div class="summary">{{ doc.summary }}</div>
+ <div class="read">{{ $ts._docs.continueReading }}</div>
+ </MkA>
</div>
- </main>
+ </MkFolder>
+ <MkFolder>
+ <template #header>{{ $ts._docs.features }}</template>
+ <div class="docs">
+ <MkA v-for="doc in docs.filter(doc => doc.path.startsWith('features/'))" :key="doc.path" :to="`/docs/${doc.path}`" class="doc">
+ <div class="title">{{ doc.title }}</div>
+ <div class="summary">{{ doc.summary }}</div>
+ <div class="read">{{ $ts._docs.continueReading }}</div>
+ </MkA>
+ </div>
+ </MkFolder>
+ <MkFolder>
+ <template #header>{{ $ts._docs.advancedTopics }}</template>
+ <div class="docs">
+ <MkA v-for="doc in docs.filter(doc => doc.path.startsWith('advanced/'))" :key="doc.path" :to="`/docs/${doc.path}`" class="doc">
+ <div class="title">{{ doc.title }}</div>
+ <div class="summary">{{ doc.summary }}</div>
+ <div class="read">{{ $ts._docs.continueReading }}</div>
+ </MkA>
+ </div>
+ </MkFolder>
+ <MkFolder>
+ <template #header>{{ $ts._docs.admin }}</template>
+ <div class="docs">
+ <MkA v-for="doc in docs.filter(doc => doc.path.startsWith('admin/'))" :key="doc.path" :to="`/docs/${doc.path}`" class="doc">
+ <div class="title">{{ doc.title }}</div>
+ <div class="summary">{{ doc.summary }}</div>
+ <div class="read">{{ $ts._docs.continueReading }}</div>
+ </MkA>
+ </div>
+ </MkFolder>
</div>
</template>
@@ -16,8 +52,15 @@
import { defineComponent } from 'vue';
import { url, lang } from '@client/config';
import * as symbols from '@client/symbols';
+import MkFolder from '@client/components/ui/folder.vue';
+import MkInput from '@client/components/ui/input.vue';
export default defineComponent({
+ components: {
+ MkFolder,
+ MkInput,
+ },
+
data() {
return {
[symbols.PAGE_INFO]: {
@@ -25,13 +68,72 @@ export default defineComponent({
icon: 'fas fa-question-circle'
},
docs: [],
+ query: null,
+ }
+ },
+
+ watch: {
+ query() {
+ fetch(`${url}/docs.json?lang=${lang}&q=${this.query}`).then(res => res.json()).then(docs => {
+ this.docs = docs;
+ });
}
},
created() {
- fetch(`${url}/docs.json?lang=${lang}`).then(res => res.json()).then(docs => {
- this.docs = docs;
+ fetch(`${url}/docs.json?lang=ja-JP`).then(res => res.json()).then(jaDocs => {
+ fetch(`${url}/docs.json?lang=${lang}`).then(res => res.json()).then(docs => {
+ this.docs = jaDocs.map(doc => {
+ const exist = docs.find(d => d.path === doc.path);
+ return exist || doc;
+ });
+ });
});
},
});
</script>
+
+<style lang="scss" scoped>
+.vtaihdtm {
+ background: var(--panel);
+
+ > .search {
+ padding: 16px;
+ }
+
+ .docs {
+ display: grid;
+ grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
+ grid-gap: 12px;
+ margin: 0 16px 16px 16px;
+
+ > .doc {
+ display: inline-block;
+ padding: 16px;
+ border: solid 1px var(--divider);
+ border-radius: 6px;
+
+ &:hover {
+ border: solid 1px var(--accent);
+ text-decoration: none;
+ }
+
+ > .title {
+ font-weight: bold;
+ }
+
+ > .summary {
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ font-size: 0.9em;
+ }
+
+ > .read {
+ color: var(--link);
+ font-size: 0.9em;
+ }
+ }
+ }
+}
+</style>
diff --git a/src/client/pages/drive.vue b/src/client/pages/drive.vue
index 753114f725..9ee1ea8859 100644
--- a/src/client/pages/drive.vue
+++ b/src/client/pages/drive.vue
@@ -20,7 +20,6 @@ export default defineComponent({
[symbols.PAGE_INFO]: {
title: computed(() => this.folder ? this.folder.name : this.$ts.drive),
icon: 'fas fa-cloud',
- menu: () => this.$refs.drive.getMenu()
},
folder: null,
};
diff --git a/src/client/pages/emojis.vue b/src/client/pages/emojis.vue
new file mode 100644
index 0000000000..391aff8297
--- /dev/null
+++ b/src/client/pages/emojis.vue
@@ -0,0 +1,151 @@
+<template>
+<div class="driuhtrh">
+ <div class="query">
+ <MkInput v-model="q" class="_inputNoTopMargin _inputNoBottomMargin" :placeholder="$ts.search">
+ <template #prefix><i class="fas fa-search"></i></template>
+ </MkInput>
+ </div>
+
+ <div class="emojis">
+ <MkFolder v-if="searchEmojis">
+ <template #header>{{ $ts.searchResult }}</template>
+ <div class="zuvgdzyt">
+ <button v-for="emoji in searchEmojis" :key="emoji.name" class="emoji _button" @click="menu(emoji, $event)">
+ <img :src="emoji.url" class="img" :alt="emoji.name"/>
+ <div class="body">
+ <div class="name _monospace">{{ emoji.name }}</div>
+ <div class="info">{{ emoji.aliases.join(' ') }}</div>
+ </div>
+ </button>
+ </div>
+ </MkFolder>
+ <MkFolder v-for="category in customEmojiCategories" :key="category">
+ <template #header>{{ category || $ts.other }}</template>
+ <div class="zuvgdzyt">
+ <button v-for="emoji in customEmojis.filter(e => e.category === category)" :key="emoji.name" class="emoji _button" @click="menu(emoji, $event)">
+ <img :src="emoji.url" class="img" :alt="emoji.name"/>
+ <div class="body">
+ <div class="name _monospace">{{ emoji.name }}</div>
+ <div class="info">{{ emoji.aliases.join(' ') }}</div>
+ </div>
+ </button>
+ </div>
+ </MkFolder>
+ </div>
+</div>
+</template>
+
+<script lang="ts">
+import { defineComponent } from 'vue';
+import MkButton from '@client/components/ui/button.vue';
+import MkInput from '@client/components/ui/input.vue';
+import MkSelect from '@client/components/ui/select.vue';
+import MkFolder from '@client/components/ui/folder.vue';
+import * as os from '@client/os';
+import * as symbols from '@client/symbols';
+import { emojiCategories } from '@client/instance';
+import copyToClipboard from '@client/scripts/copy-to-clipboard';
+
+export default defineComponent({
+ components: {
+ MkButton,
+ MkInput,
+ MkSelect,
+ MkFolder,
+ },
+
+ data() {
+ return {
+ [symbols.PAGE_INFO]: {
+ title: this.$ts.customEmojis,
+ icon: 'fas fa-laugh'
+ },
+ q: '',
+ customEmojiCategories: emojiCategories,
+ customEmojis: this.$instance.emojis,
+ searchEmojis: null,
+ }
+ },
+
+ watch: {
+ q() {
+ if (this.q === '' || this.q == null) {
+ this.searchEmojis = null;
+ return;
+ }
+
+ this.searchEmojis = this.customEmojis.filter(e => e.name.includes(this.q) || e.aliases.includes(this.q));
+ }
+ },
+
+ methods: {
+ menu(emoji, ev) {
+ os.popupMenu([{
+ type: 'label',
+ text: ':' + emoji.name + ':',
+ }, {
+ text: this.$ts.copy,
+ icon: 'fas fa-copy',
+ action: () => {
+ copyToClipboard(`:${emoji.name}:`);
+ os.success();
+ }
+ }], ev.currentTarget || ev.target);
+ }
+ }
+});
+</script>
+
+<style lang="scss" scoped>
+.driuhtrh {
+ > .query {
+ background: var(--bg);
+ padding: 16px;
+ }
+
+ > .emojis {
+ .zuvgdzyt {
+ display: grid;
+ grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
+ grid-gap: 12px;
+ margin: 0 var(--margin) var(--margin) var(--margin);
+
+ > .emoji {
+ display: flex;
+ align-items: center;
+ padding: 12px;
+ text-align: left;
+ border: solid 1px var(--divider);
+ border-radius: 8px;
+
+ &:hover {
+ border-color: var(--accent);
+ }
+
+ > .img {
+ width: 42px;
+ height: 42px;
+ }
+
+ > .body {
+ padding: 0 0 0 8px;
+ white-space: nowrap;
+ overflow: hidden;
+
+ > .name {
+ text-overflow: ellipsis;
+ overflow: hidden;
+ }
+
+ > .info {
+ opacity: 0.5;
+ font-size: 0.9em;
+ text-overflow: ellipsis;
+ overflow: hidden;
+ }
+ }
+ }
+ }
+ }
+}
+</style>
diff --git a/src/client/pages/explore.vue b/src/client/pages/explore.vue
index 7bcb09d8c5..7054940a1a 100644
--- a/src/client/pages/explore.vue
+++ b/src/client/pages/explore.vue
@@ -2,7 +2,10 @@
<div class="lznhrdub _root">
<div>
<div class="_isolated">
- <MkInput v-model:value="query" :debounce="true" type="search"><template #icon><i class="fas fa-search"></i></template><span>{{ $ts.searchUser }}</span></MkInput>
+ <MkInput v-model="query" :debounce="true" type="search">
+ <template #prefix><i class="fas fa-search"></i></template>
+ <template #label>{{ $ts.searchUser }}</template>
+ </MkInput>
</div>
<XUserList v-if="query" class="_gap" :pagination="searchPagination" ref="search"/>
diff --git a/src/client/pages/instance/federation.vue b/src/client/pages/federation.vue
index 96f72fed44..4a861ac911 100644
--- a/src/client/pages/instance/federation.vue
+++ b/src/client/pages/federation.vue
@@ -1,9 +1,12 @@
<template>
-<div class="enuoauvw">
+<div class="taeiyria">
<div class="query">
- <MkInput v-model:value="host" :debounce="true"><span>{{ $ts.host }}</span></MkInput>
- <div class="inputs" style="display: flex;">
- <MkSelect v-model:value="state" style="margin: 0; flex: 1;">
+ <MkInput v-model="host" :debounce="true" class="_inputNoTopMargin">
+ <template #prefix><i class="fas fa-search"></i></template>
+ <template #label>{{ $ts.host }}</template>
+ </MkInput>
+ <div class="_inputSplit _inputNoBottomMargin">
+ <MkSelect v-model="state">
<template #label>{{ $ts.state }}</template>
<option value="all">{{ $ts.all }}</option>
<option value="federating">{{ $ts.federating }}</option>
@@ -13,7 +16,7 @@
<option value="blocked">{{ $ts.blocked }}</option>
<option value="notResponding">{{ $ts.notResponding }}</option>
</MkSelect>
- <MkSelect v-model:value="sort" style="margin: 0; flex: 1;">
+ <MkSelect v-model="sort">
<template #label>{{ $ts.sort }}</template>
<option value="+pubSub">{{ $ts.pubSub }} ({{ $ts.descendingOrder }})</option>
<option value="-pubSub">{{ $ts.pubSub }} ({{ $ts.ascendingOrder }})</option>
@@ -38,16 +41,53 @@
</div>
<MkPagination :pagination="pagination" #default="{items}" ref="instances" :key="host + state">
- <div class="ppgwaixt _block" v-for="instance in items" :key="instance.id" @click="info(instance)">
- <div class="host"><i class="fas fa-circle indicator" :class="getStatus(instance)"></i><b>{{ instance.host }}</b></div>
- <div class="status">
- <span class="sub" v-if="instance.followersCount > 0"><i class="fas fa-caret-down icon"></i>Sub</span>
- <span class="sub" v-else><i class="fas fa-caret-down icon"></i>-</span>
- <span class="pub" v-if="instance.followingCount > 0"><i class="fas fa-caret-up icon"></i>Pub</span>
- <span class="pub" v-else><i class="fas fa-caret-up icon"></i>-</span>
- <span class="lastCommunicatedAt"><i class="fas fa-exchange-alt icon"></i><MkTime :time="instance.lastCommunicatedAt"/></span>
- <span class="latestStatus"><i class="fas fa-traffic-light icon"></i>{{ instance.latestStatus || '-' }}</span>
- </div>
+ <div class="dqokceoi">
+ <MkA class="instance" v-for="instance in items" :key="instance.id" :to="`/instance-info/${instance.host}`">
+ <div class="host"><img :src="instance.faviconUrl">{{ instance.host }}</div>
+ <div class="table">
+ <div class="cell">
+ <div class="key">{{ $ts.registeredAt }}</div>
+ <div class="value"><MkTime :time="instance.caughtAt"/></div>
+ </div>
+ <div class="cell">
+ <div class="key">{{ $ts.software }}</div>
+ <div class="value">{{ instance.softwareName || `(${$ts.unknown})` }}</div>
+ </div>
+ <div class="cell">
+ <div class="key">{{ $ts.version }}</div>
+ <div class="value">{{ instance.softwareVersion || `(${$ts.unknown})` }}</div>
+ </div>
+ <div class="cell">
+ <div class="key">{{ $ts.users }}</div>
+ <div class="value">{{ instance.usersCount }}</div>
+ </div>
+ <div class="cell">
+ <div class="key">{{ $ts.notes }}</div>
+ <div class="value">{{ instance.notesCount }}</div>
+ </div>
+ <div class="cell">
+ <div class="key">{{ $ts.sent }}</div>
+ <div class="value"><MkTime v-if="instance.latestRequestSentAt" :time="instance.latestRequestSentAt"/><span v-else>N/A</span></div>
+ </div>
+ <div class="cell">
+ <div class="key">{{ $ts.received }}</div>
+ <div class="value"><MkTime v-if="instance.latestRequestReceivedAt" :time="instance.latestRequestReceivedAt"/><span v-else>N/A</span></div>
+ </div>
+ </div>
+ <div class="footer">
+ <span class="status" :class="getStatus(instance)">{{ getStatus(instance) }}</span>
+ <span class="pubSub">
+ <span class="sub" v-if="instance.followersCount > 0"><i class="fas fa-caret-down icon"></i>Sub</span>
+ <span class="sub" v-else><i class="fas fa-caret-down icon"></i>-</span>
+ <span class="pub" v-if="instance.followingCount > 0"><i class="fas fa-caret-up icon"></i>Pub</span>
+ <span class="pub" v-else><i class="fas fa-caret-up icon"></i>-</span>
+ </span>
+ <span class="right">
+ <span class="latestStatus">{{ instance.latestStatus || '-' }}</span>
+ <span class="lastCommunicatedAt"><MkTime :time="instance.lastCommunicatedAt"/></span>
+ </span>
+ </div>
+ </MkA>
</div>
</MkPagination>
</div>
@@ -59,7 +99,6 @@ import MkButton from '@client/components/ui/button.vue';
import MkInput from '@client/components/ui/input.vue';
import MkSelect from '@client/components/ui/select.vue';
import MkPagination from '@client/components/ui/pagination.vue';
-import MkInstanceInfo from './instance.vue';
import * as os from '@client/os';
import * as symbols from '@client/symbols';
@@ -117,69 +156,107 @@ export default defineComponent({
methods: {
getStatus(instance) {
- if (instance.isSuspended) return 'off';
- if (instance.isNotResponding) return 'red';
- return 'green';
+ if (instance.isSuspended) return 'suspended';
+ if (instance.isNotResponding) return 'error';
+ return 'alive';
},
-
- info(instance) {
- os.popup(MkInstanceInfo, {
- instance: instance
- }, {}, 'closed');
- }
}
});
</script>
<style lang="scss" scoped>
-.enuoauvw {
+.taeiyria {
> .query {
- margin: var(--margin);
+ background: var(--bg);
+ padding: 16px;
}
}
-.ppgwaixt {
- cursor: pointer;
+.dqokceoi {
+ display: grid;
+ grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
+ grid-gap: 12px;
padding: 16px;
- &:hover {
- color: var(--accent);
- }
+ > .instance {
+ padding: 16px;
+ border: solid 1px var(--divider);
+ border-radius: 6px;
- > .host {
- > .indicator {
- font-size: 70%;
- vertical-align: baseline;
- margin-right: 4px;
+ &:hover {
+ border: solid 1px var(--accent);
+ text-decoration: none;
+ }
- &.green {
- color: #49c5ba;
+ > .host {
+ font-weight: bold;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+
+ > img {
+ width: 18px;
+ height: 18px;
+ margin-right: 6px;
+ vertical-align: middle;
}
+ }
+
+ > .table {
+ display: grid;
+ grid-template-columns: repeat(auto-fill, minmax(60px, 1fr));
+ grid-gap: 6px;
+ margin: 6px 0;
+ font-size: 70%;
- &.yellow {
- color: #c5a549;
+ > .cell {
+ > .key, > .value {
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ }
+
+ > .key {
+ opacity: 0.7;
+ }
+
+ > .value {
+ }
}
+ }
+
+ > .footer {
+ display: flex;
+ align-items: center;
+
+ > .status {
+ &.suspended {
+ opacity: 0.5;
+ }
- &.red {
- color: #c54949;
+ &.error {
+ color: var(--error);
+ }
+
+ &.alive {
+ color: var(--success);
+ }
}
- &.off {
- color: rgba(0, 0, 0, 0.5);
+ > .pubSub {
+ margin-left: 8px;
}
- }
- }
- > .status {
- display: flex;
- align-items: center;
- font-size: 90%;
+ > .right {
+ margin-left: auto;
+ font-size: 0.9em;
- > span {
- flex: 1;
-
- > .icon {
- margin-right: 6px;
+ > .latestStatus {
+ border: solid 1px var(--divider);
+ border-radius: 4px;
+ margin: 0 8px;
+ padding: 0 4px;
+ }
}
}
}
diff --git a/src/client/pages/follow-requests.vue b/src/client/pages/follow-requests.vue
index 9f27a6baa8..6115dda454 100644
--- a/src/client/pages/follow-requests.vue
+++ b/src/client/pages/follow-requests.vue
@@ -32,7 +32,7 @@
<script lang="ts">
import { defineComponent } from 'vue';
import MkPagination from '@client/components/ui/pagination.vue';
-import { userPage, acct } from '../filters/user';
+import { userPage, acct } from '@client/filters/user';
import * as os from '@client/os';
import * as symbols from '@client/symbols';
diff --git a/src/client/pages/instance-info.vue b/src/client/pages/instance-info.vue
index c66ad50f6d..4165f73734 100644
--- a/src/client/pages/instance-info.vue
+++ b/src/client/pages/instance-info.vue
@@ -62,7 +62,7 @@
<div class="_formLabel">{{ $ts.statistics }}</div>
<div class="_formPanel cmhjzshl">
<div class="selects">
- <MkSelect v-model:value="chartSrc" style="margin: 0; flex: 1;">
+ <MkSelect v-model="chartSrc" style="margin: 0; flex: 1;">
<option value="requests">{{ $ts._instanceCharts.requests }}</option>
<option value="users">{{ $ts._instanceCharts.users }}</option>
<option value="users-total">{{ $ts._instanceCharts.usersTotal }}</option>
@@ -75,7 +75,7 @@
<option value="drive-files">{{ $ts._instanceCharts.files }}</option>
<option value="drive-files-total">{{ $ts._instanceCharts.filesTotal }}</option>
</MkSelect>
- <MkSelect v-model:value="chartSpan" style="margin: 0;">
+ <MkSelect v-model="chartSpan" style="margin: 0;">
<option value="hour">{{ $ts.perHour }}</option>
<option value="day">{{ $ts.perDay }}</option>
</MkSelect>
diff --git a/src/client/pages/instance/abuses.vue b/src/client/pages/instance/abuses.vue
index 900c9f8333..ac20ebabe5 100644
--- a/src/client/pages/instance/abuses.vue
+++ b/src/client/pages/instance/abuses.vue
@@ -3,19 +3,19 @@
<div class="_section reports">
<div class="_content">
<div class="inputs" style="display: flex;">
- <MkSelect v-model:value="state" style="margin: 0; flex: 1;">
+ <MkSelect v-model="state" style="margin: 0; flex: 1;">
<template #label>{{ $ts.state }}</template>
<option value="all">{{ $ts.all }}</option>
<option value="unresolved">{{ $ts.unresolved }}</option>
<option value="resolved">{{ $ts.resolved }}</option>
</MkSelect>
- <MkSelect v-model:value="targetUserOrigin" style="margin: 0; flex: 1;">
+ <MkSelect v-model="targetUserOrigin" style="margin: 0; flex: 1;">
<template #label>{{ $ts.targetUserOrigin }}</template>
<option value="combined">{{ $ts.all }}</option>
<option value="local">{{ $ts.local }}</option>
<option value="remote">{{ $ts.remote }}</option>
</MkSelect>
- <MkSelect v-model:value="reporterOrigin" style="margin: 0; flex: 1;">
+ <MkSelect v-model="reporterOrigin" style="margin: 0; flex: 1;">
<template #label>{{ $ts.reporterOrigin }}</template>
<option value="combined">{{ $ts.all }}</option>
<option value="local">{{ $ts.local }}</option>
@@ -68,7 +68,7 @@ import MkButton from '@client/components/ui/button.vue';
import MkInput from '@client/components/ui/input.vue';
import MkSelect from '@client/components/ui/select.vue';
import MkPagination from '@client/components/ui/pagination.vue';
-import { acct } from '../../filters/user';
+import { acct } from '@client/filters/user';
import * as os from '@client/os';
import * as symbols from '@client/symbols';
diff --git a/src/client/pages/instance/ads.vue b/src/client/pages/instance/ads.vue
index 6b536793b7..50c8c29cbf 100644
--- a/src/client/pages/instance/ads.vue
+++ b/src/client/pages/instance/ads.vue
@@ -4,11 +4,11 @@
<section class="_card _gap ads" v-for="ad in ads">
<div class="_content ad">
<MkAd v-if="ad.url" :specify="ad"/>
- <MkInput v-model:value="ad.url" type="url">
- <span>URL</span>
+ <MkInput v-model="ad.url" type="url">
+ <template #label>URL</template>
</MkInput>
- <MkInput v-model:value="ad.imageUrl">
- <span>{{ $ts.imageUrl }}</span>
+ <MkInput v-model="ad.imageUrl">
+ <template #label>{{ $ts.imageUrl }}</template>
</MkInput>
<div style="margin: 32px 0;">
<MkRadio v-model="ad.place" value="square">square</MkRadio>
@@ -23,14 +23,14 @@
<MkRadio v-model="ad.priority" value="low">{{ $ts.low }}</MkRadio>
</div>
-->
- <MkInput v-model:value="ad.ratio" type="number">
- <span>{{ $ts.ratio }}</span>
+ <MkInput v-model="ad.ratio" type="number">
+ <template #label>{{ $ts.ratio }}</template>
</MkInput>
- <MkInput v-model:value="ad.expiresAt" type="date">
- <span>{{ $ts.expiration }}</span>
+ <MkInput v-model="ad.expiresAt" type="date">
+ <template #label>{{ $ts.expiration }}</template>
</MkInput>
- <MkTextarea v-model:value="ad.memo">
- <span>{{ $ts.memo }}</span>
+ <MkTextarea v-model="ad.memo">
+ <template #label>{{ $ts.memo }}</template>
</MkTextarea>
<div class="buttons">
<MkButton class="button" inline @click="save(ad)" primary><i class="fas fa-save"></i> {{ $ts.save }}</MkButton>
diff --git a/src/client/pages/instance/announcements.vue b/src/client/pages/instance/announcements.vue
index ac0e9d5135..d48e3737ad 100644
--- a/src/client/pages/instance/announcements.vue
+++ b/src/client/pages/instance/announcements.vue
@@ -3,14 +3,14 @@
<MkButton @click="add()" primary style="margin: 0 auto 16px auto;"><i class="fas fa-plus"></i> {{ $ts.add }}</MkButton>
<section class="_card _gap announcements" v-for="announcement in announcements">
<div class="_content announcement">
- <MkInput v-model:value="announcement.title">
- <span>{{ $ts.title }}</span>
+ <MkInput v-model="announcement.title">
+ <template #label>{{ $ts.title }}</template>
</MkInput>
- <MkTextarea v-model:value="announcement.text">
- <span>{{ $ts.text }}</span>
+ <MkTextarea v-model="announcement.text">
+ <template #label>{{ $ts.text }}</template>
</MkTextarea>
- <MkInput v-model:value="announcement.imageUrl">
- <span>{{ $ts.imageUrl }}</span>
+ <MkInput v-model="announcement.imageUrl">
+ <template #label>{{ $ts.imageUrl }}</template>
</MkInput>
<p v-if="announcement.reads">{{ $t('nUsersRead', { n: announcement.reads }) }}</p>
<div class="buttons">
diff --git a/src/client/pages/instance/emoji-edit-dialog.vue b/src/client/pages/instance/emoji-edit-dialog.vue
index f7a3671584..7e9bdc80dd 100644
--- a/src/client/pages/instance/emoji-edit-dialog.vue
+++ b/src/client/pages/instance/emoji-edit-dialog.vue
@@ -11,11 +11,15 @@
<div class="_monolithic_">
<div class="yigymqpb _section">
<img :src="emoji.url" class="img"/>
- <MkInput v-model:value="name"><span>{{ $ts.name }}</span></MkInput>
- <MkInput v-model:value="category" :datalist="categories"><span>{{ $ts.category }}</span></MkInput>
- <MkInput v-model:value="aliases">
- <span>{{ $ts.tags }}</span>
- <template #desc>{{ $ts.setMultipleBySeparatingWithSpace }}</template>
+ <MkInput v-model="name">
+ <template #label>{{ $ts.name }}</template>
+ </MkInput>
+ <MkInput v-model="category" :datalist="categories">
+ <template #label>{{ $ts.category }}</template>
+ </MkInput>
+ <MkInput v-model="aliases">
+ <template #label>{{ $ts.tags }}</template>
+ <template #caption>{{ $ts.setMultipleBySeparatingWithSpace }}</template>
</MkInput>
<MkButton danger @click="del()"><i class="fas fa-trash-alt"></i> {{ $ts.delete }}</MkButton>
</div>
diff --git a/src/client/pages/instance/emojis.vue b/src/client/pages/instance/emojis.vue
index fd641703cb..7badc9da02 100644
--- a/src/client/pages/instance/emojis.vue
+++ b/src/client/pages/instance/emojis.vue
@@ -7,7 +7,10 @@
<div class="local" v-if="tab === 'local'">
<MkButton primary @click="add" style="margin: var(--margin) auto;"><i class="fas fa-plus"></i> {{ $ts.addEmoji }}</MkButton>
- <MkInput v-model:value="query" :debounce="true" type="search" style="margin: var(--margin);"><template #icon><i class="fas fa-search"></i></template><span>{{ $ts.search }}</span></MkInput>
+ <MkInput v-model="query" :debounce="true" type="search" style="margin: var(--margin);">
+ <template #prefix><i class="fas fa-search"></i></template>
+ <template #label>{{ $ts.search }}</template>
+ </MkInput>
<MkPagination :pagination="pagination" ref="emojis">
<template #empty><span>{{ $ts.noCustomEmojis }}</span></template>
<template #default="{items}">
@@ -25,8 +28,13 @@
</div>
<div class="remote" v-else-if="tab === 'remote'">
- <MkInput v-model:value="queryRemote" :debounce="true" type="search" style="margin: var(--margin);"><template #icon><i class="fas fa-search"></i></template><span>{{ $ts.search }}</span></MkInput>
- <MkInput v-model:value="host" :debounce="true" style="margin: var(--margin);"><span>{{ $ts.host }}</span></MkInput>
+ <MkInput v-model="queryRemote" :debounce="true" type="search" style="margin: var(--margin);">
+ <template #prefix><i class="fas fa-search"></i></template>
+ <template #label>{{ $ts.search }}</template>
+ </MkInput>
+ <MkInput v-model="host" :debounce="true" style="margin: var(--margin);">
+ <template #label>{{ $ts.host }}</template>
+ </MkInput>
<MkPagination :pagination="remotePagination" ref="remoteEmojis">
<template #empty><span>{{ $ts.noCustomEmojis }}</span></template>
<template #default="{items}">
@@ -138,7 +146,7 @@ export default defineComponent({
},
remoteMenu(emoji, ev) {
- os.modalMenu([{
+ os.popupMenu([{
type: 'label',
text: ':' + emoji.name + ':',
}, {
diff --git a/src/client/pages/instance/file-dialog.vue b/src/client/pages/instance/file-dialog.vue
index 74a755fa15..be6bf6cbf2 100644
--- a/src/client/pages/instance/file-dialog.vue
+++ b/src/client/pages/instance/file-dialog.vue
@@ -16,7 +16,7 @@
</div>
<div class="_section">
<div class="_content">
- <MkSwitch @update:value="toggleIsSensitive" v-model:value="isSensitive">NSFW</MkSwitch>
+ <MkSwitch @update:modelValue="toggleIsSensitive" v-model="isSensitive">NSFW</MkSwitch>
</div>
</div>
<div class="_section">
diff --git a/src/client/pages/instance/files.vue b/src/client/pages/instance/files.vue
index 427c5b411a..b7f472b7c8 100644
--- a/src/client/pages/instance/files.vue
+++ b/src/client/pages/instance/files.vue
@@ -9,8 +9,8 @@
<div class="_section lookup">
<div class="_title"><i class="fas fa-search"></i> {{ $ts.lookup }}</div>
<div class="_content">
- <MkInput class="target" v-model:value="q" type="text" @enter="find()">
- <span>{{ $ts.fileIdOrUrl }}</span>
+ <MkInput class="target" v-model="q" type="text" @enter="find()">
+ <template #label>{{ $ts.fileIdOrUrl }}</template>
</MkInput>
<MkButton @click="find()" primary><i class="fas fa-search"></i> {{ $ts.lookup }}</MkButton>
</div>
@@ -19,19 +19,19 @@
<div class="_section">
<div class="_content">
<div class="inputs" style="display: flex;">
- <MkSelect v-model:value="origin" style="margin: 0; flex: 1;">
+ <MkSelect v-model="origin" style="margin: 0; flex: 1;">
<template #label>{{ $ts.instance }}</template>
<option value="combined">{{ $ts.all }}</option>
<option value="local">{{ $ts.local }}</option>
<option value="remote">{{ $ts.remote }}</option>
</MkSelect>
- <MkInput v-model:value="searchHost" :debounce="true" type="search" style="margin: 0; flex: 1;" :disabled="pagination.params().origin === 'local'">
- <span>{{ $ts.host }}</span>
+ <MkInput v-model="searchHost" :debounce="true" type="search" style="margin: 0; flex: 1;" :disabled="pagination.params().origin === 'local'">
+ <template #label>{{ $ts.host }}</template>
</MkInput>
</div>
<div class="inputs" style="display: flex; padding-top: 1.2em;">
- <MkInput v-model:value="type" :debounce="true" type="search" style="margin: 0; flex: 1;">
- <span>{{ $ts.type }}</span>
+ <MkInput v-model="type" :debounce="true" type="search" style="margin: 0; flex: 1;">
+ <template #label>{{ $ts.type }}</template>
</MkInput>
</div>
<MkPagination :pagination="pagination" #default="{items}" class="urempief" ref="files">
diff --git a/src/client/pages/instance/index.vue b/src/client/pages/instance/index.vue
index acd46518f5..612bfa762a 100644
--- a/src/client/pages/instance/index.vue
+++ b/src/client/pages/instance/index.vue
@@ -100,7 +100,7 @@ export default defineComponent({
case 'overview': return defineAsyncComponent(() => import('./overview.vue'));
case 'users': return defineAsyncComponent(() => import('./users.vue'));
case 'emojis': return defineAsyncComponent(() => import('./emojis.vue'));
- case 'federation': return defineAsyncComponent(() => import('./federation.vue'));
+ case 'federation': return defineAsyncComponent(() => import('../federation.vue'));
case 'queue': return defineAsyncComponent(() => import('./queue.vue'));
case 'files': return defineAsyncComponent(() => import('./files.vue'));
case 'announcements': return defineAsyncComponent(() => import('./announcements.vue'));
@@ -167,7 +167,7 @@ export default defineComponent({
};
const lookup = (ev) => {
- os.modalMenu([{
+ os.popupMenu([{
text: i18n.locale.user,
icon: 'fas fa-user',
action: () => {
diff --git a/src/client/pages/instance/instance.vue b/src/client/pages/instance/instance.vue
index 75a24bcb80..c39f0d1ecb 100644
--- a/src/client/pages/instance/instance.vue
+++ b/src/client/pages/instance/instance.vue
@@ -77,7 +77,7 @@
<div class="header">
<span class="label">{{ $ts.charts }}</span>
<div class="selects">
- <MkSelect v-model:value="chartSrc" style="margin: 0; flex: 1;">
+ <MkSelect v-model="chartSrc" style="margin: 0; flex: 1;">
<option value="requests">{{ $ts._instanceCharts.requests }}</option>
<option value="users">{{ $ts._instanceCharts.users }}</option>
<option value="users-total">{{ $ts._instanceCharts.usersTotal }}</option>
@@ -90,7 +90,7 @@
<option value="drive-files">{{ $ts._instanceCharts.files }}</option>
<option value="drive-files-total">{{ $ts._instanceCharts.filesTotal }}</option>
</MkSelect>
- <MkSelect v-model:value="chartSpan" style="margin: 0;">
+ <MkSelect v-model="chartSpan" style="margin: 0;">
<option value="hour">{{ $ts.perHour }}</option>
<option value="day">{{ $ts.perDay }}</option>
</MkSelect>
@@ -102,8 +102,8 @@
</div>
<div class="operations section">
<span class="label">{{ $ts.operations }}</span>
- <MkSwitch v-model:value="isSuspended" class="switch">{{ $ts.stopActivityDelivery }}</MkSwitch>
- <MkSwitch :value="isBlocked" class="switch" @update:value="changeBlock">{{ $ts.blockThisInstance }}</MkSwitch>
+ <MkSwitch v-model="isSuspended" class="switch">{{ $ts.stopActivityDelivery }}</MkSwitch>
+ <MkSwitch :model-value="isBlocked" class="switch" @update:modelValue="changeBlock">{{ $ts.blockThisInstance }}</MkSwitch>
<details>
<summary>{{ $ts.deleteAllFiles }}</summary>
<MkButton @click="deleteAllFiles()" style="margin: 0.5em 0 0.5em 0;"><i class="fas fa-trash-alt"></i> {{ $ts.deleteAllFiles }}</MkButton>
@@ -131,8 +131,8 @@ import MkSelect from '@client/components/ui/select.vue';
import MkButton from '@client/components/ui/button.vue';
import MkSwitch from '@client/components/ui/switch.vue';
import MkInfo from '@client/components/ui/info.vue';
-import bytes from '../../filters/bytes';
-import number from '../../filters/number';
+import bytes from '@client/filters/bytes';
+import number from '@client/filters/number';
import * as os from '@client/os';
const chartLimit = 90;
diff --git a/src/client/pages/instance/logs.vue b/src/client/pages/instance/logs.vue
index 112b0f66d0..4eee816f96 100644
--- a/src/client/pages/instance/logs.vue
+++ b/src/client/pages/instance/logs.vue
@@ -1,10 +1,10 @@
<template>
<div class="_section">
<div class="_inputs">
- <MkInput v-model:value="logDomain" :debounce="true">
- <span>{{ $ts.domain }}</span>
+ <MkInput v-model="logDomain" :debounce="true">
+ <template #label>{{ $ts.domain }}</template>
</MkInput>
- <MkSelect v-model:value="logLevel">
+ <MkSelect v-model="logLevel">
<template #label>Level</template>
<option value="all">All</option>
<option value="info">Info</option>
diff --git a/src/client/pages/instance/metrics.vue b/src/client/pages/instance/metrics.vue
index 131af37c7f..283b5939f0 100644
--- a/src/client/pages/instance/metrics.vue
+++ b/src/client/pages/instance/metrics.vue
@@ -60,8 +60,8 @@ import MkContainer from '@client/components/ui/container.vue';
import MkFolder from '@client/components/ui/folder.vue';
import MkwFederation from '../../widgets/federation.vue';
import { version, url } from '@client/config';
-import bytes from '../../filters/bytes';
-import number from '../../filters/number';
+import bytes from '@client/filters/bytes';
+import number from '@client/filters/number';
import MkInstanceInfo from './instance.vue';
const alpha = (hex, a) => {
diff --git a/src/client/pages/instance/overview.vue b/src/client/pages/instance/overview.vue
index cb9cff9fc5..0d7a5d1501 100644
--- a/src/client/pages/instance/overview.vue
+++ b/src/client/pages/instance/overview.vue
@@ -62,8 +62,8 @@ import MkInput from '@client/components/ui/input.vue';
import MkContainer from '@client/components/ui/container.vue';
import MkFolder from '@client/components/ui/folder.vue';
import { version, url } from '@client/config';
-import bytes from '../../filters/bytes';
-import number from '../../filters/number';
+import bytes from '@client/filters/bytes';
+import number from '@client/filters/number';
import MkInstanceInfo from './instance.vue';
import XMetrics from './metrics.vue';
import * as os from '@client/os';
diff --git a/src/client/pages/instance/queue.chart.vue b/src/client/pages/instance/queue.chart.vue
index 0cd983127f..53d790598a 100644
--- a/src/client/pages/instance/queue.chart.vue
+++ b/src/client/pages/instance/queue.chart.vue
@@ -29,7 +29,7 @@
<script lang="ts">
import { defineComponent, markRaw } from 'vue';
import Chart from 'chart.js';
-import number from '../../filters/number';
+import number from '@client/filters/number';
const alpha = (hex, a) => {
const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex)!;
diff --git a/src/client/pages/instance/users.vue b/src/client/pages/instance/users.vue
index 2808b70fba..8db62683ba 100644
--- a/src/client/pages/instance/users.vue
+++ b/src/client/pages/instance/users.vue
@@ -7,14 +7,14 @@
<div class="users">
<div class="inputs" style="display: flex;">
- <MkSelect v-model:value="sort" style="margin: 0; flex: 1;">
+ <MkSelect v-model="sort" style="margin: 0; flex: 1;">
<template #label>{{ $ts.sort }}</template>
<option value="-createdAt">{{ $ts.registeredDate }} ({{ $ts.ascendingOrder }})</option>
<option value="+createdAt">{{ $ts.registeredDate }} ({{ $ts.descendingOrder }})</option>
<option value="-updatedAt">{{ $ts.lastUsed }} ({{ $ts.ascendingOrder }})</option>
<option value="+updatedAt">{{ $ts.lastUsed }} ({{ $ts.descendingOrder }})</option>
</MkSelect>
- <MkSelect v-model:value="state" style="margin: 0; flex: 1;">
+ <MkSelect v-model="state" style="margin: 0; flex: 1;">
<template #label>{{ $ts.state }}</template>
<option value="all">{{ $ts.all }}</option>
<option value="available">{{ $ts.normal }}</option>
@@ -23,7 +23,7 @@
<option value="silenced">{{ $ts.silence }}</option>
<option value="suspended">{{ $ts.suspend }}</option>
</MkSelect>
- <MkSelect v-model:value="origin" style="margin: 0; flex: 1;">
+ <MkSelect v-model="origin" style="margin: 0; flex: 1;">
<template #label>{{ $ts.instance }}</template>
<option value="combined">{{ $ts.all }}</option>
<option value="local">{{ $ts.local }}</option>
@@ -31,11 +31,11 @@
</MkSelect>
</div>
<div class="inputs" style="display: flex; padding-top: 1.2em;">
- <MkInput v-model:value="searchUsername" style="margin: 0; flex: 1;" type="text" spellcheck="false" @update:value="$refs.users.reload()">
- <span>{{ $ts.username }}</span>
+ <MkInput v-model="searchUsername" style="margin: 0; flex: 1;" type="text" spellcheck="false" @update:modelValue="$refs.users.reload()">
+ <template #label>{{ $ts.username }}</template>
</MkInput>
- <MkInput v-model:value="searchHost" style="margin: 0; flex: 1;" type="text" spellcheck="false" @update:value="$refs.users.reload()" :disabled="pagination.params().origin === 'local'">
- <span>{{ $ts.host }}</span>
+ <MkInput v-model="searchHost" style="margin: 0; flex: 1;" type="text" spellcheck="false" @update:modelValue="$refs.users.reload()" :disabled="pagination.params().origin === 'local'">
+ <template #label>{{ $ts.host }}</template>
</MkInput>
</div>
@@ -70,7 +70,7 @@ import MkButton from '@client/components/ui/button.vue';
import MkInput from '@client/components/ui/input.vue';
import MkSelect from '@client/components/ui/select.vue';
import MkPagination from '@client/components/ui/pagination.vue';
-import { acct } from '../../filters/user';
+import { acct } from '@client/filters/user';
import * as os from '@client/os';
import * as symbols from '@client/symbols';
import { lookupUser } from '@client/scripts/lookup-user';
diff --git a/src/client/pages/messaging/index.vue b/src/client/pages/messaging/index.vue
index b9c29492c6..1e0d4dc64c 100644
--- a/src/client/pages/messaging/index.vue
+++ b/src/client/pages/messaging/index.vue
@@ -40,7 +40,7 @@
import { defineAsyncComponent, defineComponent, markRaw } from 'vue';
import { getAcct } from '@/misc/acct';
import MkButton from '@client/components/ui/button.vue';
-import { acct } from '../../filters/user';
+import { acct } from '@client/filters/user';
import * as os from '@client/os';
import * as symbols from '@client/symbols';
@@ -116,7 +116,7 @@ export default defineComponent({
},
start(ev) {
- os.modalMenu([{
+ os.popupMenu([{
text: this.$ts.messagingWithUser,
icon: 'fas fa-user',
action: () => { this.startUser() }
diff --git a/src/client/pages/messaging/messaging-room.vue b/src/client/pages/messaging/messaging-room.vue
index 396f5f56fd..b6a2fbd3d4 100644
--- a/src/client/pages/messaging/messaging-room.vue
+++ b/src/client/pages/messaging/messaging-room.vue
@@ -29,7 +29,7 @@
<button class="_buttonPrimary" @click="onIndicatorClick"><i class="fas fa-arrow-circle-down"></i>{{ $ts.newMessageExists }}</button>
</div>
</transition>
- <XForm v-if="!fetching" :user="user" :group="group" ref="form"/>
+ <XForm v-if="!fetching" :user="user" :group="group" ref="form" class="form"/>
</footer>
</div>
</div>
@@ -320,7 +320,7 @@ const Component = defineComponent({
menu(ev) {
const path = this.groupId ? `/my/messaging/group/${this.groupId}` : `/my/messaging/${this.userAcct}`;
- os.modalMenu([this.inWindow ? undefined : {
+ os.popupMenu([this.inWindow ? undefined : {
text: this.$ts.openInWindow,
icon: 'fas fa-window-maximize',
action: () => {
@@ -452,6 +452,10 @@ export default Component;
}
}
}
+
+ > .form {
+ border-top: solid 0.5px var(--divider);
+ }
}
}
diff --git a/src/client/pages/mfm-cheat-sheet.vue b/src/client/pages/mfm-cheat-sheet.vue
index 5227855236..751dccd7a1 100644
--- a/src/client/pages/mfm-cheat-sheet.vue
+++ b/src/client/pages/mfm-cheat-sheet.vue
@@ -7,7 +7,7 @@
<p>{{ $ts._mfm.mentionDescription }}</p>
<div class="preview">
<Mfm :text="preview_mention"/>
- <MkTextarea v-model:value="preview_mention"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_mention"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -17,7 +17,7 @@
<p>{{ $ts._mfm.hashtagDescription }}</p>
<div class="preview">
<Mfm :text="preview_hashtag"/>
- <MkTextarea v-model:value="preview_hashtag"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_hashtag"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -27,7 +27,7 @@
<p>{{ $ts._mfm.urlDescription }}</p>
<div class="preview">
<Mfm :text="preview_url"/>
- <MkTextarea v-model:value="preview_url"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_url"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -37,7 +37,7 @@
<p>{{ $ts._mfm.linkDescription }}</p>
<div class="preview">
<Mfm :text="preview_link"/>
- <MkTextarea v-model:value="preview_link"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_link"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -47,7 +47,7 @@
<p>{{ $ts._mfm.emojiDescription }}</p>
<div class="preview">
<Mfm :text="preview_emoji"/>
- <MkTextarea v-model:value="preview_emoji"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_emoji"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -57,7 +57,7 @@
<p>{{ $ts._mfm.boldDescription }}</p>
<div class="preview">
<Mfm :text="preview_bold"/>
- <MkTextarea v-model:value="preview_bold"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_bold"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -67,7 +67,7 @@
<p>{{ $ts._mfm.smallDescription }}</p>
<div class="preview">
<Mfm :text="preview_small"/>
- <MkTextarea v-model:value="preview_small"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_small"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -77,7 +77,7 @@
<p>{{ $ts._mfm.quoteDescription }}</p>
<div class="preview">
<Mfm :text="preview_quote"/>
- <MkTextarea v-model:value="preview_quote"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_quote"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -87,7 +87,7 @@
<p>{{ $ts._mfm.centerDescription }}</p>
<div class="preview">
<Mfm :text="preview_center"/>
- <MkTextarea v-model:value="preview_center"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_center"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -97,7 +97,7 @@
<p>{{ $ts._mfm.inlineCodeDescription }}</p>
<div class="preview">
<Mfm :text="preview_inlineCode"/>
- <MkTextarea v-model:value="preview_inlineCode"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_inlineCode"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -107,7 +107,7 @@
<p>{{ $ts._mfm.blockCodeDescription }}</p>
<div class="preview">
<Mfm :text="preview_blockCode"/>
- <MkTextarea v-model:value="preview_blockCode"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_blockCode"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -117,7 +117,7 @@
<p>{{ $ts._mfm.inlineMathDescription }}</p>
<div class="preview">
<Mfm :text="preview_inlineMath"/>
- <MkTextarea v-model:value="preview_inlineMath"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_inlineMath"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -127,7 +127,7 @@
<p>{{ $ts._mfm.searchDescription }}</p>
<div class="preview">
<Mfm :text="preview_search"/>
- <MkTextarea v-model:value="preview_search"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_search"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -137,7 +137,7 @@
<p>{{ $ts._mfm.flipDescription }}</p>
<div class="preview">
<Mfm :text="preview_flip"/>
- <MkTextarea v-model:value="preview_flip"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_flip"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -147,7 +147,7 @@
<p>{{ $ts._mfm.fontDescription }}</p>
<div class="preview">
<Mfm :text="preview_font"/>
- <MkTextarea v-model:value="preview_font"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_font"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -157,7 +157,7 @@
<p>{{ $ts._mfm.x2Description }}</p>
<div class="preview">
<Mfm :text="preview_x2"/>
- <MkTextarea v-model:value="preview_x2"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_x2"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -167,7 +167,7 @@
<p>{{ $ts._mfm.x3Description }}</p>
<div class="preview">
<Mfm :text="preview_x3"/>
- <MkTextarea v-model:value="preview_x3"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_x3"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -177,7 +177,7 @@
<p>{{ $ts._mfm.x4Description }}</p>
<div class="preview">
<Mfm :text="preview_x4"/>
- <MkTextarea v-model:value="preview_x4"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_x4"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -187,7 +187,7 @@
<p>{{ $ts._mfm.blurDescription }}</p>
<div class="preview">
<Mfm :text="preview_blur"/>
- <MkTextarea v-model:value="preview_blur"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_blur"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -197,7 +197,7 @@
<p>{{ $ts._mfm.jellyDescription }}</p>
<div class="preview">
<Mfm :text="preview_jelly"/>
- <MkTextarea v-model:value="preview_jelly"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_jelly"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -207,7 +207,7 @@
<p>{{ $ts._mfm.tadaDescription }}</p>
<div class="preview">
<Mfm :text="preview_tada"/>
- <MkTextarea v-model:value="preview_tada"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_tada"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -217,7 +217,7 @@
<p>{{ $ts._mfm.jumpDescription }}</p>
<div class="preview">
<Mfm :text="preview_jump"/>
- <MkTextarea v-model:value="preview_jump"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_jump"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -227,7 +227,7 @@
<p>{{ $ts._mfm.bounceDescription }}</p>
<div class="preview">
<Mfm :text="preview_bounce"/>
- <MkTextarea v-model:value="preview_bounce"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_bounce"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -237,7 +237,7 @@
<p>{{ $ts._mfm.spinDescription }}</p>
<div class="preview">
<Mfm :text="preview_spin"/>
- <MkTextarea v-model:value="preview_spin"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_spin"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -247,7 +247,7 @@
<p>{{ $ts._mfm.shakeDescription }}</p>
<div class="preview">
<Mfm :text="preview_shake"/>
- <MkTextarea v-model:value="preview_shake"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_shake"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -257,7 +257,17 @@
<p>{{ $ts._mfm.twitchDescription }}</p>
<div class="preview">
<Mfm :text="preview_twitch"/>
- <MkTextarea v-model:value="preview_twitch"><span>MFM</span></MkTextarea>
+ <MkTextarea v-model="preview_twitch"><template #label>MFM</template></MkTextarea>
+ </div>
+ </div>
+ </div>
+ <div class="section _block">
+ <div class="title">{{ $ts._mfm.rainbow }}</div>
+ <div class="content">
+ <p>{{ $ts._mfm.rainbowDescription }}</p>
+ <div class="preview">
+ <Mfm :text="preview_rainbow"/>
+ <MkTextarea v-model="preview_rainbow"><template #label>MFM</template></MkTextarea>
</div>
</div>
</div>
@@ -306,6 +316,7 @@ export default defineComponent({
preview_x3: `$[x3 🍮]`,
preview_x4: `$[x4 🍮]`,
preview_blur: `$[blur ${this.$ts._mfm.dummy}]`,
+ preview_rainbow: `$[rainbow 🍮]`,
}
},
});
@@ -313,6 +324,8 @@ export default defineComponent({
<style lang="scss" scoped>
.mwysmxbg {
+ background: var(--bg);
+
> .section {
> .title {
position: sticky;
diff --git a/src/client/pages/my-antennas/create.vue b/src/client/pages/my-antennas/create.vue
new file mode 100644
index 0000000000..d4762411e7
--- /dev/null
+++ b/src/client/pages/my-antennas/create.vue
@@ -0,0 +1,51 @@
+<template>
+<div class="geegznzt">
+ <XAntenna :antenna="draft" @created="onAntennaCreated"/>
+</div>
+</template>
+
+<script lang="ts">
+import { defineComponent } from 'vue';
+import MkButton from '@client/components/ui/button.vue';
+import XAntenna from './editor.vue';
+import * as symbols from '@client/symbols';
+
+export default defineComponent({
+ components: {
+ MkButton,
+ XAntenna,
+ },
+
+ data() {
+ return {
+ [symbols.PAGE_INFO]: {
+ title: this.$ts.manageAntennas,
+ icon: 'fas fa-satellite',
+ },
+ draft: {
+ name: '',
+ src: 'all',
+ userListId: null,
+ userGroupId: null,
+ users: [],
+ keywords: [],
+ excludeKeywords: [],
+ withReplies: false,
+ caseSensitive: false,
+ withFile: false,
+ notify: false
+ },
+ };
+ },
+
+ methods: {
+ onAntennaCreated() {
+ this.$router.push('/my/antennas');
+ },
+ }
+});
+</script>
+
+<style lang="scss" scoped>
+
+</style>
diff --git a/src/client/pages/my-antennas/edit.vue b/src/client/pages/my-antennas/edit.vue
new file mode 100644
index 0000000000..9deafb4235
--- /dev/null
+++ b/src/client/pages/my-antennas/edit.vue
@@ -0,0 +1,56 @@
+<template>
+<div class="">
+ <XAntenna v-if="antenna" :antenna="antenna" @updated="onAntennaUpdated"/>
+</div>
+</template>
+
+<script lang="ts">
+import { defineComponent } from 'vue';
+import MkButton from '@client/components/ui/button.vue';
+import XAntenna from './editor.vue';
+import * as symbols from '@client/symbols';
+import * as os from '@client/os';
+
+export default defineComponent({
+ components: {
+ MkButton,
+ XAntenna,
+ },
+
+ props: {
+ antennaId: {
+ type: String,
+ required: true,
+ }
+ },
+
+ data() {
+ return {
+ [symbols.PAGE_INFO]: {
+ title: this.$ts.manageAntennas,
+ icon: 'fas fa-satellite',
+ },
+ antenna: null,
+ };
+ },
+
+ watch: {
+ antennaId: {
+ async handler() {
+ this.antenna = await os.api('antennas/show', { antennaId: this.antennaId });
+ },
+ immediate: true,
+ }
+ },
+
+ methods: {
+ onAntennaUpdated() {
+ this.$router.push('/my/antennas');
+ },
+ }
+});
+</script>
+
+<style lang="scss" scoped>
+
+</style>
diff --git a/src/client/pages/my-antennas/index.antenna.vue b/src/client/pages/my-antennas/editor.vue
index fcb7559a98..882d48e643 100644
--- a/src/client/pages/my-antennas/index.antenna.vue
+++ b/src/client/pages/my-antennas/editor.vue
@@ -1,11 +1,10 @@
<template>
-<div class="shaynizk _card">
- <div class="_title" v-if="antenna.name">{{ antenna.name }}</div>
- <div class="_content body">
- <MkInput v-model:value="name">
- <span>{{ $ts.name }}</span>
+<div class="shaynizk">
+ <div class="form">
+ <MkInput v-model="name" class="_inputNoTopMargin">
+ <template #label>{{ $ts.name }}</template>
</MkInput>
- <MkSelect v-model:value="src">
+ <MkSelect v-model="src">
<template #label>{{ $ts.antennaSource }}</template>
<option value="all">{{ $ts._antennaSources.all }}</option>
<option value="home">{{ $ts._antennaSources.homeTimeline }}</option>
@@ -13,34 +12,34 @@
<option value="list">{{ $ts._antennaSources.userList }}</option>
<option value="group">{{ $ts._antennaSources.userGroup }}</option>
</MkSelect>
- <MkSelect v-model:value="userListId" v-if="src === 'list'">
+ <MkSelect v-model="userListId" v-if="src === 'list'">
<template #label>{{ $ts.userList }}</template>
<option v-for="list in userLists" :value="list.id" :key="list.id">{{ list.name }}</option>
</MkSelect>
- <MkSelect v-model:value="userGroupId" v-else-if="src === 'group'">
+ <MkSelect v-model="userGroupId" v-else-if="src === 'group'">
<template #label>{{ $ts.userGroup }}</template>
<option v-for="group in userGroups" :value="group.id" :key="group.id">{{ group.name }}</option>
</MkSelect>
- <MkTextarea v-model:value="users" v-else-if="src === 'users'">
- <span>{{ $ts.users }}</span>
- <template #desc>{{ $ts.antennaUsersDescription }} <button class="_textButton" @click="addUser">{{ $ts.addUser }}</button></template>
+ <MkTextarea v-model="users" v-else-if="src === 'users'">
+ <template #label>{{ $ts.users }}</template>
+ <template #caption>{{ $ts.antennaUsersDescription }} <button class="_textButton" @click="addUser">{{ $ts.addUser }}</button></template>
</MkTextarea>
- <MkSwitch v-model:value="withReplies">{{ $ts.withReplies }}</MkSwitch>
- <MkTextarea v-model:value="keywords">
- <span>{{ $ts.antennaKeywords }}</span>
- <template #desc>{{ $ts.antennaKeywordsDescription }}</template>
+ <MkSwitch v-model="withReplies">{{ $ts.withReplies }}</MkSwitch>
+ <MkTextarea v-model="keywords">
+ <template #label>{{ $ts.antennaKeywords }}</template>
+ <template #caption>{{ $ts.antennaKeywordsDescription }}</template>
</MkTextarea>
- <MkTextarea v-model:value="excludeKeywords">
- <span>{{ $ts.antennaExcludeKeywords }}</span>
- <template #desc>{{ $ts.antennaKeywordsDescription }}</template>
+ <MkTextarea v-model="excludeKeywords">
+ <template #label>{{ $ts.antennaExcludeKeywords }}</template>
+ <template #caption>{{ $ts.antennaKeywordsDescription }}</template>
</MkTextarea>
- <MkSwitch v-model:value="caseSensitive">{{ $ts.caseSensitive }}</MkSwitch>
- <MkSwitch v-model:value="withFile">{{ $ts.withFileAntenna }}</MkSwitch>
- <MkSwitch v-model:value="notify">{{ $ts.notifyAntenna }}</MkSwitch>
+ <MkSwitch v-model="caseSensitive">{{ $ts.caseSensitive }}</MkSwitch>
+ <MkSwitch v-model="withFile">{{ $ts.withFileAntenna }}</MkSwitch>
+ <MkSwitch v-model="notify">{{ $ts.notifyAntenna }}</MkSwitch>
</div>
- <div class="_footer">
+ <div class="actions">
<MkButton inline @click="saveAntenna()" primary><i class="fas fa-save"></i> {{ $ts.save }}</MkButton>
- <MkButton inline @click="deleteAntenna()" v-if="antenna.id != null"><i class="fas fa-trash"></i> {{ $ts.delete }}</MkButton>
+ <MkButton inline @click="deleteAntenna()" v-if="antenna.id != null" danger><i class="fas fa-trash"></i> {{ $ts.delete }}</MkButton>
</div>
</div>
</template>
@@ -117,7 +116,7 @@ export default defineComponent({
methods: {
async saveAntenna() {
if (this.antenna.id == null) {
- await os.api('antennas/create', {
+ await os.apiWithDialog('antennas/create', {
name: this.name,
src: this.src,
userListId: this.userListId,
@@ -132,7 +131,7 @@ export default defineComponent({
});
this.$emit('created');
} else {
- await os.api('antennas/update', {
+ await os.apiWithDialog('antennas/update', {
antennaId: this.antenna.id,
name: this.name,
src: this.src,
@@ -146,9 +145,8 @@ export default defineComponent({
keywords: this.keywords.trim().split('\n').map(x => x.trim().split(' ')),
excludeKeywords: this.excludeKeywords.trim().split('\n').map(x => x.trim().split(' ')),
});
+ this.$emit('updated');
}
-
- os.success();
},
async deleteAntenna() {
@@ -180,9 +178,13 @@ export default defineComponent({
<style lang="scss" scoped>
.shaynizk {
- > .body {
- max-height: 250px;
- overflow: auto;
+ > .form {
+ padding: 32px;
+ }
+
+ > .actions {
+ padding: 24px 32px;
+ border-top: solid 0.5px var(--divider);
}
}
</style>
diff --git a/src/client/pages/my-antennas/index.vue b/src/client/pages/my-antennas/index.vue
index 57c55cefdd..c27bb2c15e 100644
--- a/src/client/pages/my-antennas/index.vue
+++ b/src/client/pages/my-antennas/index.vue
@@ -1,12 +1,12 @@
<template>
<div class="ieepwinx _section">
- <MkButton @click="create" primary class="add"><i class="fas fa-plus"></i> {{ $ts.add }}</MkButton>
+ <MkButton :link="true" to="/my/antennas/create" primary class="add"><i class="fas fa-plus"></i> {{ $ts.add }}</MkButton>
<div class="_content">
- <XAntenna v-if="draft" :antenna="draft" @created="onAntennaCreated" style="margin-bottom: var(--margin);"/>
-
- <MkPagination :pagination="pagination" #default="{items}" class="antennas" ref="list">
- <XAntenna v-for="(antenna, i) in items" :key="antenna.id" :antenna="antenna" @deleted="onAntennaDeleted"/>
+ <MkPagination :pagination="pagination" #default="{items}" ref="list">
+ <MkA class="ljoevbzj" v-for="antenna in items" :key="antenna.id" :to="`/my/antennas/${antenna.id}`">
+ <div class="name">{{ antenna.name }}</div>
+ </MkA>
</MkPagination>
</div>
</div>
@@ -16,14 +16,12 @@
import { defineComponent } from 'vue';
import MkPagination from '@client/components/ui/pagination.vue';
import MkButton from '@client/components/ui/button.vue';
-import XAntenna from './index.antenna.vue';
import * as symbols from '@client/symbols';
export default defineComponent({
components: {
MkPagination,
MkButton,
- XAntenna,
},
data() {
@@ -40,43 +38,34 @@ export default defineComponent({
endpoint: 'antennas/list',
limit: 10,
},
- draft: null,
};
},
-
- methods: {
- create() {
- this.draft = {
- name: '',
- src: 'all',
- userListId: null,
- userGroupId: null,
- users: [],
- keywords: [],
- excludeKeywords: [],
- withReplies: false,
- caseSensitive: false,
- withFile: false,
- notify: false
- };
- },
-
- onAntennaCreated() {
- this.$refs.list.reload();
- this.draft = null;
- },
-
- onAntennaDeleted() {
- this.$refs.list.reload();
- },
- }
});
</script>
<style lang="scss" scoped>
.ieepwinx {
+ padding: 16px;
+
> .add {
margin: 0 auto 16px auto;
}
+
+ .ljoevbzj {
+ display: block;
+ padding: 16px;
+ margin-bottom: 8px;
+ border: solid 1px var(--divider);
+ border-radius: 6px;
+
+ &:hover {
+ border: solid 1px var(--accent);
+ text-decoration: none;
+ }
+
+ > .name {
+ font-weight: bold;
+ }
+ }
}
</style>
diff --git a/src/client/pages/page-editor/els/page-editor.el.button.vue b/src/client/pages/page-editor/els/page-editor.el.button.vue
index 6e9036faac..3a43817cf6 100644
--- a/src/client/pages/page-editor/els/page-editor.el.button.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.button.vue
@@ -3,9 +3,9 @@
<template #header><i class="fas fa-bolt"></i> {{ $ts._pages.blocks.button }}</template>
<section class="xfhsjczc">
- <MkInput v-model:value="value.text"><span>{{ $ts._pages.blocks._button.text }}</span></MkInput>
- <MkSwitch v-model:value="value.primary"><span>{{ $ts._pages.blocks._button.colored }}</span></MkSwitch>
- <MkSelect v-model:value="value.action">
+ <MkInput v-model="value.text"><template #label>{{ $ts._pages.blocks._button.text }}</template></MkInput>
+ <MkSwitch v-model="value.primary"><span>{{ $ts._pages.blocks._button.colored }}</span></MkSwitch>
+ <MkSelect v-model="value.action">
<template #label>{{ $ts._pages.blocks._button.action }}</template>
<option value="dialog">{{ $ts._pages.blocks._button._action.dialog }}</option>
<option value="resetRandom">{{ $ts._pages.blocks._button._action.resetRandom }}</option>
@@ -13,12 +13,12 @@
<option value="callAiScript">{{ $ts._pages.blocks._button._action.callAiScript }}</option>
</MkSelect>
<template v-if="value.action === 'dialog'">
- <MkInput v-model:value="value.content"><span>{{ $ts._pages.blocks._button._action._dialog.content }}</span></MkInput>
+ <MkInput v-model="value.content"><template #label>{{ $ts._pages.blocks._button._action._dialog.content }}</template></MkInput>
</template>
<template v-else-if="value.action === 'pushEvent'">
- <MkInput v-model:value="value.event"><span>{{ $ts._pages.blocks._button._action._pushEvent.event }}</span></MkInput>
- <MkInput v-model:value="value.message"><span>{{ $ts._pages.blocks._button._action._pushEvent.message }}</span></MkInput>
- <MkSelect v-model:value="value.var">
+ <MkInput v-model="value.event"><template #label>{{ $ts._pages.blocks._button._action._pushEvent.event }}</template></MkInput>
+ <MkInput v-model="value.message"><template #label>{{ $ts._pages.blocks._button._action._pushEvent.message }}</template></MkInput>
+ <MkSelect v-model="value.var">
<template #label>{{ $ts._pages.blocks._button._action._pushEvent.variable }}</template>
<option :value="null">{{ $t('_pages.blocks._button._action._pushEvent.no-variable') }}</option>
<option v-for="v in hpml.getVarsByType()" :value="v.name">{{ v.name }}</option>
@@ -31,7 +31,7 @@
</MkSelect>
</template>
<template v-else-if="value.action === 'callAiScript'">
- <MkInput v-model:value="value.fn"><span>{{ $ts._pages.blocks._button._action._callAiScript.functionName }}</span></MkInput>
+ <MkInput v-model="value.fn"><template #label>{{ $ts._pages.blocks._button._action._callAiScript.functionName }}</template></MkInput>
</template>
</section>
</XContainer>
diff --git a/src/client/pages/page-editor/els/page-editor.el.canvas.vue b/src/client/pages/page-editor/els/page-editor.el.canvas.vue
index 59d29b9b71..d8d5b990ca 100644
--- a/src/client/pages/page-editor/els/page-editor.el.canvas.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.canvas.vue
@@ -3,9 +3,18 @@
<template #header><i class="fas fa-paint-brush"></i> {{ $ts._pages.blocks.canvas }}</template>
<section style="padding: 0 16px 0 16px;">
- <MkInput v-model:value="value.name"><template #prefix><i class="fas fa-magic"></i></template><span>{{ $ts._pages.blocks._canvas.id }}</span></MkInput>
- <MkInput v-model:value="value.width" type="number"><span>{{ $ts._pages.blocks._canvas.width }}</span><template #suffix>px</template></MkInput>
- <MkInput v-model:value="value.height" type="number"><span>{{ $ts._pages.blocks._canvas.height }}</span><template #suffix>px</template></MkInput>
+ <MkInput v-model="value.name">
+ <template #prefix><i class="fas fa-magic"></i></template>
+ <template #label>{{ $ts._pages.blocks._canvas.id }}</template>
+ </MkInput>
+ <MkInput v-model="value.width" type="number">
+ <template #label>{{ $ts._pages.blocks._canvas.width }}</template>
+ <template #suffix>px</template>
+ </MkInput>
+ <MkInput v-model="value.height" type="number">
+ <template #label>{{ $ts._pages.blocks._canvas.height }}</template>
+ <template #suffix>px</template>
+ </MkInput>
</section>
</XContainer>
</template>
diff --git a/src/client/pages/page-editor/els/page-editor.el.counter.vue b/src/client/pages/page-editor/els/page-editor.el.counter.vue
index 3394817b53..973de50fc2 100644
--- a/src/client/pages/page-editor/els/page-editor.el.counter.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.counter.vue
@@ -3,9 +3,16 @@
<template #header><i class="fas fa-bolt"></i> {{ $ts._pages.blocks.counter }}</template>
<section style="padding: 0 16px 0 16px;">
- <MkInput v-model:value="value.name"><template #prefix><i class="fas fa-magic"></i></template><span>{{ $ts._pages.blocks._counter.name }}</span></MkInput>
- <MkInput v-model:value="value.text"><span>{{ $ts._pages.blocks._counter.text }}</span></MkInput>
- <MkInput v-model:value="value.inc" type="number"><span>{{ $ts._pages.blocks._counter.inc }}</span></MkInput>
+ <MkInput v-model="value.name">
+ <template #prefix><i class="fas fa-magic"></i></template>
+ <template #label>{{ $ts._pages.blocks._counter.name }}</template>
+ </MkInput>
+ <MkInput v-model="value.text">
+ <template #label>{{ $ts._pages.blocks._counter.text }}</template>
+ </MkInput>
+ <MkInput v-model="value.inc" type="number">
+ <template #label>{{ $ts._pages.blocks._counter.inc }}</template>
+ </MkInput>
</section>
</XContainer>
</template>
diff --git a/src/client/pages/page-editor/els/page-editor.el.if.vue b/src/client/pages/page-editor/els/page-editor.el.if.vue
index 7f4ed458aa..6eb0c7709f 100644
--- a/src/client/pages/page-editor/els/page-editor.el.if.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.if.vue
@@ -8,7 +8,7 @@
</template>
<section class="romcojzs">
- <MkSelect v-model:value="value.var">
+ <MkSelect v-model="value.var">
<template #label>{{ $ts._pages.blocks._if.variable }}</template>
<option v-for="v in hpml.getVarsByType('boolean')" :value="v.name">{{ v.name }}</option>
<optgroup :label="$ts._pages.script.pageVariables">
diff --git a/src/client/pages/page-editor/els/page-editor.el.note.vue b/src/client/pages/page-editor/els/page-editor.el.note.vue
index d4801f3059..5766564c1a 100644
--- a/src/client/pages/page-editor/els/page-editor.el.note.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.note.vue
@@ -3,11 +3,11 @@
<template #header><i class="fas fa-sticky-note"></i> {{ $ts._pages.blocks.note }}</template>
<section style="padding: 0 16px 0 16px;">
- <MkInput v-model:value="id">
- <span>{{ $ts._pages.blocks._note.id }}</span>
- <template #desc>{{ $ts._pages.blocks._note.idDescription }}</template>
+ <MkInput v-model="id">
+ <template #label>{{ $ts._pages.blocks._note.id }}</template>
+ <template #caption>{{ $ts._pages.blocks._note.idDescription }}</template>
</MkInput>
- <MkSwitch v-model:value="value.detailed"><span>{{ $ts._pages.blocks._note.detailed }}</span></MkSwitch>
+ <MkSwitch v-model="value.detailed"><span>{{ $ts._pages.blocks._note.detailed }}</span></MkSwitch>
<XNote v-if="note && !value.detailed" v-model:note="note" :key="note.id + ':normal'" style="margin-bottom: 16px;"/>
<XNoteDetailed v-if="note && value.detailed" v-model:note="note" :key="note.id + ':detail'" style="margin-bottom: 16px;"/>
diff --git a/src/client/pages/page-editor/els/page-editor.el.number-input.vue b/src/client/pages/page-editor/els/page-editor.el.number-input.vue
index 8058d941c1..892e7e1caa 100644
--- a/src/client/pages/page-editor/els/page-editor.el.number-input.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.number-input.vue
@@ -3,9 +3,16 @@
<template #header><i class="fas fa-bolt"></i> {{ $ts._pages.blocks.numberInput }}</template>
<section style="padding: 0 16px 0 16px;">
- <MkInput v-model:value="value.name"><template #prefix><i class="fas fa-magic"></i></template><span>{{ $ts._pages.blocks._numberInput.name }}</span></MkInput>
- <MkInput v-model:value="value.text"><span>{{ $ts._pages.blocks._numberInput.text }}</span></MkInput>
- <MkInput v-model:value="value.default" type="number"><span>{{ $ts._pages.blocks._numberInput.default }}</span></MkInput>
+ <MkInput v-model="value.name">
+ <template #prefix><i class="fas fa-magic"></i></template>
+ <template #label>{{ $ts._pages.blocks._numberInput.name }}</template>
+ </MkInput>
+ <MkInput v-model="value.text">
+ <template #label>{{ $ts._pages.blocks._numberInput.text }}</template>
+ </MkInput>
+ <MkInput v-model="value.default" type="number">
+ <template #label>{{ $ts._pages.blocks._numberInput.default }}</template>
+ </MkInput>
</section>
</XContainer>
</template>
diff --git a/src/client/pages/page-editor/els/page-editor.el.post.vue b/src/client/pages/page-editor/els/page-editor.el.post.vue
index 1ed7f860c8..4215b159d3 100644
--- a/src/client/pages/page-editor/els/page-editor.el.post.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.post.vue
@@ -3,9 +3,9 @@
<template #header><i class="fas fa-paper-plane"></i> {{ $ts._pages.blocks.post }}</template>
<section style="padding: 16px;">
- <MkTextarea v-model:value="value.text">{{ $ts._pages.blocks._post.text }}</MkTextarea>
- <MkSwitch v-model:value="value.attachCanvasImage"><span>{{ $ts._pages.blocks._post.attachCanvasImage }}</span></MkSwitch>
- <MkInput v-if="value.attachCanvasImage" v-model:value="value.canvasId"><span>{{ $ts._pages.blocks._post.canvasId }}</span></MkInput>
+ <MkTextarea v-model="value.text"><template #label>{{ $ts._pages.blocks._post.text }}</template></MkTextarea>
+ <MkSwitch v-model="value.attachCanvasImage"><span>{{ $ts._pages.blocks._post.attachCanvasImage }}</span></MkSwitch>
+ <MkInput v-if="value.attachCanvasImage" v-model="value.canvasId"><template #label>{{ $ts._pages.blocks._post.canvasId }}</template></MkInput>
</section>
</XContainer>
</template>
diff --git a/src/client/pages/page-editor/els/page-editor.el.radio-button.vue b/src/client/pages/page-editor/els/page-editor.el.radio-button.vue
index 97715ed69c..88be96f35d 100644
--- a/src/client/pages/page-editor/els/page-editor.el.radio-button.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.radio-button.vue
@@ -3,10 +3,10 @@
<template #header><i class="fas fa-bolt"></i> {{ $ts._pages.blocks.radioButton }}</template>
<section style="padding: 0 16px 16px 16px;">
- <MkInput v-model:value="value.name"><template #prefix><i class="fas fa-magic"></i></template><span>{{ $ts._pages.blocks._radioButton.name }}</span></MkInput>
- <MkInput v-model:value="value.title"><span>{{ $ts._pages.blocks._radioButton.title }}</span></MkInput>
- <MkTextarea v-model:value="values"><span>{{ $ts._pages.blocks._radioButton.values }}</span></MkTextarea>
- <MkInput v-model:value="value.default"><span>{{ $ts._pages.blocks._radioButton.default }}</span></MkInput>
+ <MkInput v-model="value.name"><template #prefix><i class="fas fa-magic"></i></template><template #label>{{ $ts._pages.blocks._radioButton.name }}</template></MkInput>
+ <MkInput v-model="value.title"><template #label>{{ $ts._pages.blocks._radioButton.title }}</template></MkInput>
+ <MkTextarea v-model="values"><template #label>{{ $ts._pages.blocks._radioButton.values }}</template></MkTextarea>
+ <MkInput v-model="value.default"><template #label>{{ $ts._pages.blocks._radioButton.default }}</template></MkInput>
</section>
</XContainer>
</template>
diff --git a/src/client/pages/page-editor/els/page-editor.el.switch.vue b/src/client/pages/page-editor/els/page-editor.el.switch.vue
index 564d5e22c3..ade1291410 100644
--- a/src/client/pages/page-editor/els/page-editor.el.switch.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.switch.vue
@@ -3,9 +3,9 @@
<template #header><i class="fas fa-bolt"></i> {{ $ts._pages.blocks.switch }}</template>
<section class="kjuadyyj">
- <MkInput v-model:value="value.name"><template #prefix><i class="fas fa-magic"></i></template><span>{{ $ts._pages.blocks._switch.name }}</span></MkInput>
- <MkInput v-model:value="value.text"><span>{{ $ts._pages.blocks._switch.text }}</span></MkInput>
- <MkSwitch v-model:value="value.default"><span>{{ $ts._pages.blocks._switch.default }}</span></MkSwitch>
+ <MkInput v-model="value.name"><template #prefix><i class="fas fa-magic"></i></template><template #label>{{ $ts._pages.blocks._switch.name }}</template></MkInput>
+ <MkInput v-model="value.text"><template #label>{{ $ts._pages.blocks._switch.text }}</template></MkInput>
+ <MkSwitch v-model="value.default"><span>{{ $ts._pages.blocks._switch.default }}</span></MkSwitch>
</section>
</XContainer>
</template>
diff --git a/src/client/pages/page-editor/els/page-editor.el.text-input.vue b/src/client/pages/page-editor/els/page-editor.el.text-input.vue
index 4435d9b841..3c8fcc04af 100644
--- a/src/client/pages/page-editor/els/page-editor.el.text-input.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.text-input.vue
@@ -3,9 +3,9 @@
<template #header><i class="fas fa-bolt"></i> {{ $ts._pages.blocks.textInput }}</template>
<section style="padding: 0 16px 0 16px;">
- <MkInput v-model:value="value.name"><template #prefix><i class="fas fa-magic"></i></template><span>{{ $ts._pages.blocks._textInput.name }}</span></MkInput>
- <MkInput v-model:value="value.text"><span>{{ $ts._pages.blocks._textInput.text }}</span></MkInput>
- <MkInput v-model:value="value.default" type="text"><span>{{ $ts._pages.blocks._textInput.default }}</span></MkInput>
+ <MkInput v-model="value.name"><template #prefix><i class="fas fa-magic"></i></template><template #label>{{ $ts._pages.blocks._textInput.name }}</template></MkInput>
+ <MkInput v-model="value.text"><template #label>{{ $ts._pages.blocks._textInput.text }}</template></MkInput>
+ <MkInput v-model="value.default" type="text"><template #label>{{ $ts._pages.blocks._textInput.default }}</template></MkInput>
</section>
</XContainer>
</template>
diff --git a/src/client/pages/page-editor/els/page-editor.el.textarea-input.vue b/src/client/pages/page-editor/els/page-editor.el.textarea-input.vue
index cf3b9f93f4..a4fbb08ffe 100644
--- a/src/client/pages/page-editor/els/page-editor.el.textarea-input.vue
+++ b/src/client/pages/page-editor/els/page-editor.el.textarea-input.vue
@@ -3,9 +3,9 @@
<template #header><i class="fas fa-bolt"></i> {{ $ts._pages.blocks.textareaInput }}</template>
<section style="padding: 0 16px 16px 16px;">
- <MkInput v-model:value="value.name"><template #prefix><i class="fas fa-magic"></i></template><span>{{ $ts._pages.blocks._textareaInput.name }}</span></MkInput>
- <MkInput v-model:value="value.text"><span>{{ $ts._pages.blocks._textareaInput.text }}</span></MkInput>
- <MkTextarea v-model:value="value.default"><span>{{ $ts._pages.blocks._textareaInput.default }}</span></MkTextarea>
+ <MkInput v-model="value.name"><template #prefix><i class="fas fa-magic"></i></template><template #label>{{ $ts._pages.blocks._textareaInput.name }}</template></MkInput>
+ <MkInput v-model="value.text"><template #label>{{ $ts._pages.blocks._textareaInput.text }}</template></MkInput>
+ <MkTextarea v-model="value.default"><template #label>{{ $ts._pages.blocks._textareaInput.default }}</template></MkTextarea>
</section>
</XContainer>
</template>
diff --git a/src/client/pages/page-editor/page-editor.script-block.vue b/src/client/pages/page-editor/page-editor.script-block.vue
index 65ac731e47..fedcd7b317 100644
--- a/src/client/pages/page-editor/page-editor.script-block.vue
+++ b/src/client/pages/page-editor/page-editor.script-block.vue
@@ -40,9 +40,9 @@
<input v-model="value.value"/>
</section>
<section v-else-if="value.type === 'fn'" class="" style="padding:0 16px 16px 16px;">
- <MkTextarea v-model:value="slots">
- <span>{{ $ts._pages.script.blocks._fn.slots }}</span>
- <template #desc>{{ $t('_pages.script.blocks._fn.slots-info') }}</template>
+ <MkTextarea v-model="slots">
+ <template #label>{{ $ts._pages.script.blocks._fn.slots }}</template>
+ <template #caption>{{ $t('_pages.script.blocks._fn.slots-info') }}</template>
</MkTextarea>
<XV v-if="value.value.expression" v-model:value="value.value.expression" :title="$t(`_pages.script.blocks._fn.arg1`)" :get-expected-type="() => null" :hpml="hpml" :fn-slots="value.value.slots" :name="name"/>
</section>
diff --git a/src/client/pages/page-editor/page-editor.vue b/src/client/pages/page-editor/page-editor.vue
index e96e1faaf2..dc6896ba12 100644
--- a/src/client/pages/page-editor/page-editor.vue
+++ b/src/client/pages/page-editor/page-editor.vue
@@ -11,28 +11,28 @@
<MkContainer :foldable="true" :expanded="true" class="_gap">
<template #header><i class="fas fa-cog"></i> {{ $ts._pages.pageSetting }}</template>
<div style="padding: 16px;">
- <MkInput v-model:value="title">
- <span>{{ $ts._pages.title }}</span>
+ <MkInput v-model="title">
+ <template #label>{{ $ts._pages.title }}</template>
</MkInput>
- <MkInput v-model:value="summary">
- <span>{{ $ts._pages.summary }}</span>
+ <MkInput v-model="summary">
+ <template #label>{{ $ts._pages.summary }}</template>
</MkInput>
- <MkInput v-model:value="name">
+ <MkInput v-model="name">
<template #prefix>{{ url }}/@{{ author.username }}/pages/</template>
- <span>{{ $ts._pages.url }}</span>
+ <template #label>{{ $ts._pages.url }}</template>
</MkInput>
- <MkSwitch v-model:value="alignCenter">{{ $ts._pages.alignCenter }}</MkSwitch>
+ <MkSwitch v-model="alignCenter">{{ $ts._pages.alignCenter }}</MkSwitch>
- <MkSelect v-model:value="font">
+ <MkSelect v-model="font">
<template #label>{{ $ts._pages.font }}</template>
<option value="serif">{{ $ts._pages.fontSerif }}</option>
<option value="sans-serif">{{ $ts._pages.fontSansSerif }}</option>
</MkSelect>
- <MkSwitch v-model:value="hideTitleWhenPinned">{{ $ts._pages.hideTitleWhenPinned }}</MkSwitch>
+ <MkSwitch v-model="hideTitleWhenPinned">{{ $ts._pages.hideTitleWhenPinned }}</MkSwitch>
<div class="eyeCatch">
<MkButton v-if="eyeCatchingImageId == null && !readonly" @click="setEyeCatchingImage"><i class="fas fa-plus"></i> {{ $ts._pages.eyeCatchingImageSet }}</MkButton>
@@ -77,7 +77,7 @@
<MkContainer :foldable="true" :expanded="true" class="_gap">
<template #header><i class="fas fa-code"></i> {{ $ts.script }}</template>
<div>
- <MkTextarea class="_code" v-model:value="script"/>
+ <MkTextarea class="_code" v-model="script"/>
</div>
</MkContainer>
</div>
diff --git a/src/client/pages/reversi/game.setting.vue b/src/client/pages/reversi/game.setting.vue
index 341aa7d658..1cc623b790 100644
--- a/src/client/pages/reversi/game.setting.vue
+++ b/src/client/pages/reversi/game.setting.vue
@@ -57,9 +57,9 @@
</header>
<div>
- <MkSwitch v-model:value="game.isLlotheo" @update:value="updateSettings('isLlotheo')">{{ $ts._reversi.isLlotheo }}</MkSwitch>
- <MkSwitch v-model:value="game.loopedBoard" @update:value="updateSettings('loopedBoard')">{{ $ts._reversi.loopedMap }}</MkSwitch>
- <MkSwitch v-model:value="game.canPutEverywhere" @update:value="updateSettings('canPutEverywhere')">{{ $ts._reversi.canPutEverywhere }}</MkSwitch>
+ <MkSwitch v-model="game.isLlotheo" @update:modelValue="updateSettings('isLlotheo')">{{ $ts._reversi.isLlotheo }}</MkSwitch>
+ <MkSwitch v-model="game.loopedBoard" @update:modelValue="updateSettings('loopedBoard')">{{ $ts._reversi.loopedMap }}</MkSwitch>
+ <MkSwitch v-model="game.canPutEverywhere" @update:modelValue="updateSettings('canPutEverywhere')">{{ $ts._reversi.canPutEverywhere }}</MkSwitch>
</div>
</div>
@@ -70,7 +70,7 @@
<div>
<template v-for="item in form">
- <MkSwitch v-if="item.type == 'switch'" v-model:value="item.value" :key="item.id" @change="onChangeForm(item)">{{ item.label || item.desc || '' }}</MkSwitch>
+ <MkSwitch v-if="item.type == 'switch'" v-model="item.value" :key="item.id" @change="onChangeForm(item)">{{ item.label || item.desc || '' }}</MkSwitch>
<div class="card" v-if="item.type == 'radio'" :key="item.id">
<header>
diff --git a/src/client/pages/room/room.vue b/src/client/pages/room/room.vue
index 61650e067f..365ed5b803 100644
--- a/src/client/pages/room/room.vue
+++ b/src/client/pages/room/room.vue
@@ -31,7 +31,7 @@
<MkButton @click="add()"><i class="fas fa-box-open"></i> {{ $ts._rooms.addFurniture }}</MkButton>
</div>
<div class="_content">
- <MkSelect :value="roomType" @update:value="updateRoomType($event)">
+ <MkSelect :model-value="roomType" @update:modelValue="updateRoomType($event)">
<template #label>{{ $ts._rooms.roomType }}</template>
<option value="default">{{ $ts._rooms._roomType.default }}</option>
<option value="washitsu">{{ $ts._rooms._roomType.washitsu }}</option>
diff --git a/src/client/pages/settings/2fa.vue b/src/client/pages/settings/2fa.vue
index aa14f91d71..48b06eaa24 100644
--- a/src/client/pages/settings/2fa.vue
+++ b/src/client/pages/settings/2fa.vue
@@ -20,7 +20,7 @@
</div>
</div>
- <MkSwitch v-model:value="usePasswordLessLogin" @update:value="updatePasswordLessLogin" v-if="$i.securityKeysList.length > 0">{{ $ts.passwordLessLogin }}</MkSwitch>
+ <MkSwitch v-model="usePasswordLessLogin" @update:modelValue="updatePasswordLessLogin" v-if="$i.securityKeysList.length > 0">{{ $ts.passwordLessLogin }}</MkSwitch>
<MkInfo warn v-if="registration && registration.error">{{ $ts.error }} {{ registration.error }}</MkInfo>
<MkButton v-if="!registration || registration.error" @click="addSecurityKey">{{ $ts._2fa.registerKey }}</MkButton>
@@ -32,8 +32,8 @@
</li>
<li v-if="registration.stage >= 1">
<MkForm :disabled="registration.stage != 1 || registration.saving">
- <MkInput v-model:value="keyName" :max="30">
- <span>{{ $ts.securityKeyName }}</span>
+ <MkInput v-model="keyName" :max="30">
+ <template #label>{{ $ts.securityKeyName }}</template>
</MkInput>
<MkButton @click="registerKey" :disabled="keyName.length == 0">{{ $ts.registerSecurityKey }}</MkButton>
<i v-if="registration.saving && registration.stage == 1" class="fas fa-spinner fa-pulse fa-fw"></i>
@@ -56,7 +56,7 @@
</li>
<li>{{ $ts._2fa.step2 }}<br><img :src="data.qr"></li>
<li>{{ $ts._2fa.step3 }}<br>
- <MkInput v-model:value="token" type="text" pattern="^[0-9]{6}$" autocomplete="off" spellcheck="false">{{ $ts.token }}</MkInput>
+ <MkInput v-model="token" type="text" pattern="^[0-9]{6}$" autocomplete="off" spellcheck="false"><template #label>{{ $ts.token }}</template></MkInput>
<MkButton primary @click="submit">{{ $ts.done }}</MkButton>
</li>
</ol>
diff --git a/src/client/pages/settings/accounts.vue b/src/client/pages/settings/accounts.vue
index a3fa0d4eb0..53e28bdf6f 100644
--- a/src/client/pages/settings/accounts.vue
+++ b/src/client/pages/settings/accounts.vue
@@ -64,7 +64,7 @@ export default defineComponent({
methods: {
menu(account, ev) {
- os.modalMenu([{
+ os.popupMenu([{
text: this.$ts.switch,
icon: 'fas fa-exchange-alt',
action: () => this.switchAccount(account),
@@ -77,7 +77,7 @@ export default defineComponent({
},
addAccount(ev) {
- os.modalMenu([{
+ os.popupMenu([{
text: this.$ts.existingAccount,
action: () => { this.addExistingAccount(); },
}, {
diff --git a/src/client/pages/settings/reaction.vue b/src/client/pages/settings/reaction.vue
index 9bffd5f903..a0024234e4 100644
--- a/src/client/pages/settings/reaction.vue
+++ b/src/client/pages/settings/reaction.vue
@@ -94,7 +94,7 @@ export default defineComponent({
},
remove(reaction, ev) {
- os.modalMenu([{
+ os.popupMenu([{
text: this.$ts.remove,
action: () => {
this.reactions = this.reactions.filter(x => x !== reaction)
diff --git a/src/client/pages/test.vue b/src/client/pages/test.vue
index 9a06d31090..131571e9dd 100644
--- a/src/client/pages/test.vue
+++ b/src/client/pages/test.vue
@@ -4,23 +4,23 @@
<div class="_card _gap">
<div class="_title">Dialog</div>
<div class="_content">
- <MkInput v-model:value="dialogTitle">
- <span>Title</span>
+ <MkInput v-model="dialogTitle">
+ <template #label>Title</template>
</MkInput>
- <MkInput v-model:value="dialogBody">
- <span>Body</span>
+ <MkInput v-model="dialogBody">
+ <template #label>Body</template>
</MkInput>
<MkRadio v-model="dialogType" value="info">Info</MkRadio>
<MkRadio v-model="dialogType" value="success">Success</MkRadio>
<MkRadio v-model="dialogType" value="warning">Warn</MkRadio>
<MkRadio v-model="dialogType" value="error">Error</MkRadio>
- <MkSwitch v-model:value="dialogCancel">
+ <MkSwitch v-model="dialogCancel">
<span>With cancel button</span>
</MkSwitch>
- <MkSwitch v-model:value="dialogCancelByBgClick">
+ <MkSwitch v-model="dialogCancelByBgClick">
<span>Can cancel by modal bg click</span>
</MkSwitch>
- <MkSwitch v-model:value="dialogInput">
+ <MkSwitch v-model="dialogInput">
<span>With input field</span>
</MkSwitch>
<MkButton @click="showDialog()">Show</MkButton>
@@ -33,11 +33,11 @@
<div class="_card _gap">
<div class="_title">Form</div>
<div class="_content">
- <MkInput v-model:value="formTitle">
- <span>Title</span>
+ <MkInput v-model="formTitle">
+ <template #label>Title</template>
</MkInput>
- <MkTextarea v-model:value="formForm">
- <span>Form</span>
+ <MkTextarea v-model="formForm">
+ <template #label>Form</template>
</MkTextarea>
<MkButton @click="form()">Show</MkButton>
</div>
@@ -49,8 +49,8 @@
<div class="_card _gap">
<div class="_title">MFM</div>
<div class="_content">
- <MkTextarea v-model:value="mfm">
- <span>MFM</span>
+ <MkTextarea v-model="mfm">
+ <template #label>MFM</template>
</MkTextarea>
</div>
<div class="_content">
@@ -61,7 +61,7 @@
<div class="_card _gap">
<div class="_title">selectDriveFile</div>
<div class="_content">
- <MkSwitch v-model:value="selectDriveFileMultiple">
+ <MkSwitch v-model="selectDriveFileMultiple">
<span>Multiple</span>
</MkSwitch>
<MkButton @click="selectDriveFile()">selectDriveFile</MkButton>
@@ -74,7 +74,7 @@
<div class="_card _gap">
<div class="_title">selectDriveFolder</div>
<div class="_content">
- <MkSwitch v-model:value="selectDriveFolderMultiple">
+ <MkSwitch v-model="selectDriveFolderMultiple">
<span>Multiple</span>
</MkSwitch>
<MkButton @click="selectDriveFolder()">selectDriveFolder</MkButton>
@@ -97,14 +97,14 @@
<div class="_card _gap">
<div class="_title">Notification</div>
<div class="_content">
- <MkInput v-model:value="notificationIconUrl">
- <span>Icon URL</span>
+ <MkInput v-model="notificationIconUrl">
+ <template #label>Icon URL</template>
</MkInput>
- <MkInput v-model:value="notificationHeader">
- <span>Header</span>
+ <MkInput v-model="notificationHeader">
+ <template #label>Header</template>
</MkInput>
- <MkTextarea v-model:value="notificationBody">
- <span>Body</span>
+ <MkTextarea v-model="notificationBody">
+ <template #label>Body</template>
</MkTextarea>
<MkButton @click="createNotification()">createNotification</MkButton>
</div>
diff --git a/src/client/pages/timeline.vue b/src/client/pages/timeline.vue
index 966146d92b..a6a0e6987f 100644
--- a/src/client/pages/timeline.vue
+++ b/src/client/pages/timeline.vue
@@ -1,8 +1,8 @@
<template>
<div class="cmuxhskf _root" v-hotkey.global="keymap">
- <XTutorial v-if="$store.reactiveState.tutorial.value != -1" class="tutorial _block"/>
- <XPostForm v-if="$store.reactiveState.showFixedPostForm.value" class="post-form _block" fixed/>
- <div class="tabs _block">
+ <XTutorial v-if="$store.reactiveState.tutorial.value != -1" class="tutorial _block _isolated"/>
+ <XPostForm v-if="$store.reactiveState.showFixedPostForm.value" class="post-form _block _isolated" fixed/>
+ <div class="tabs">
<div class="left">
<button class="_button tab" @click="() => { src = 'home'; saveSrc(); }" :class="{ active: src === 'home' }" v-tooltip="$ts._timelines.home"><i class="fas fa-home"></i></button>
<button class="_button tab" @click="() => { src = 'local'; saveSrc(); }" :class="{ active: src === 'local' }" v-tooltip="$ts._timelines.local" v-if="isLocalTimelineAvailable"><i class="fas fa-comments"></i></button>
@@ -20,7 +20,6 @@
</div>
<div class="new" v-if="queue > 0"><button class="_buttonPrimary" @click="top()">{{ $ts.newNoteRecived }}</button></div>
<XTimeline ref="tl"
- class="_gap"
:key="src === 'list' ? `list:${list.id}` : src === 'antenna' ? `antenna:${antenna.id}` : src === 'channel' ? `channel:${channel.id}` : src"
:src="src"
:list="list ? list.id : null"
@@ -62,6 +61,7 @@ export default defineComponent({
queue: 0,
[symbols.PAGE_INFO]: computed(() => ({
title: this.$ts.timeline,
+ subtitle: this.src === 'local' ? this.$ts._timelines.local : this.src === 'social' ? this.$ts._timelines.social : this.src === 'global' ? this.$ts._timelines.global : this.$ts._timelines.home,
icon: this.src === 'local' ? 'fas fa-comments' : this.src === 'social' ? 'fas fa-share-alt' : this.src === 'global' ? 'fas fa-globe' : 'fas fa-home',
actions: [{
icon: 'fas fa-calendar-alt',
@@ -147,7 +147,7 @@ export default defineComponent({
this.saveSrc();
}
}));
- os.modalMenu(items, ev.currentTarget || ev.target);
+ os.popupMenu(items, ev.currentTarget || ev.target);
},
async chooseAntenna(ev) {
@@ -161,7 +161,7 @@ export default defineComponent({
this.saveSrc();
}
}));
- os.modalMenu(items, ev.currentTarget || ev.target);
+ os.popupMenu(items, ev.currentTarget || ev.target);
},
async chooseChannel(ev) {
@@ -177,7 +177,7 @@ export default defineComponent({
this.$router.push(`/channels/${channel.id}`);
}
}));
- os.modalMenu(items, ev.currentTarget || ev.target);
+ os.popupMenu(items, ev.currentTarget || ev.target);
},
saveSrc() {
@@ -211,6 +211,8 @@ export default defineComponent({
<style lang="scss" scoped>
.cmuxhskf {
+ background: var(--bg);
+
> .new {
position: sticky;
top: calc(var(--stickyTop, 0px) + 16px);
diff --git a/src/client/pages/user-info.vue b/src/client/pages/user-info.vue
index 51bd5016bb..503982652b 100644
--- a/src/client/pages/user-info.vue
+++ b/src/client/pages/user-info.vue
@@ -167,13 +167,13 @@ export default defineComponent({
},
async resetPassword() {
- os.apiWithDialog('admin/reset-password', {
+ const { password } = await os.api('admin/reset-password', {
userId: this.user.id,
- }, undefined, ({ password }) => {
- os.dialog({
- type: 'success',
- text: this.$t('newPasswordIs', { password })
- });
+ });
+
+ os.dialog({
+ type: 'success',
+ text: this.$t('newPasswordIs', { password })
});
},
diff --git a/src/client/pages/user/clips.vue b/src/client/pages/user/clips.vue
index 9c77bbad47..fc40d583c6 100644
--- a/src/client/pages/user/clips.vue
+++ b/src/client/pages/user/clips.vue
@@ -12,7 +12,7 @@
<script lang="ts">
import { defineComponent } from 'vue';
import MkPagination from '@client/components/ui/pagination.vue';
-import { userPage, acct } from '../../filters/user';
+import { userPage, acct } from '@client/filters/user';
export default defineComponent({
components: {
diff --git a/src/client/pages/user/follow-list.vue b/src/client/pages/user/follow-list.vue
index 1fce74ec17..f6df28309f 100644
--- a/src/client/pages/user/follow-list.vue
+++ b/src/client/pages/user/follow-list.vue
@@ -12,7 +12,7 @@
import { defineComponent } from 'vue';
import MkUserInfo from '@client/components/user-info.vue';
import MkPagination from '@client/components/ui/pagination.vue';
-import { userPage, acct } from '../../filters/user';
+import { userPage, acct } from '@client/filters/user';
export default defineComponent({
components: {
diff --git a/src/client/pages/user/gallery.vue b/src/client/pages/user/gallery.vue
index 2a4c4e03f4..67a5fac109 100644
--- a/src/client/pages/user/gallery.vue
+++ b/src/client/pages/user/gallery.vue
@@ -12,7 +12,7 @@
import { defineComponent } from 'vue';
import MkGalleryPostPreview from '@client/components/gallery-post-preview.vue';
import MkPagination from '@client/components/ui/pagination.vue';
-import { userPage, acct } from '../../filters/user';
+import { userPage, acct } from '@client/filters/user';
export default defineComponent({
components: {
diff --git a/src/client/pages/user/index.photos.vue b/src/client/pages/user/index.photos.vue
index a899b116e5..5029c3feec 100644
--- a/src/client/pages/user/index.photos.vue
+++ b/src/client/pages/user/index.photos.vue
@@ -20,7 +20,7 @@
<script lang="ts">
import { defineComponent } from 'vue';
import { getStaticImageUrl } from '@client/scripts/get-static-image-url';
-import notePage from '../../filters/note';
+import notePage from '@client/filters/note';
import * as os from '@client/os';
import MkContainer from '@client/components/ui/container.vue';
import ImgWithBlurhash from '@client/components/img-with-blurhash.vue';
diff --git a/src/client/pages/user/index.vue b/src/client/pages/user/index.vue
index f5c5a0694c..9cf424b127 100644
--- a/src/client/pages/user/index.vue
+++ b/src/client/pages/user/index.vue
@@ -1,9 +1,9 @@
<template>
<transition name="fade" mode="out-in">
<div class="ftskorzw wide" v-if="user && narrow === false">
- <MkRemoteCaution v-if="user.host != null" :href="user.url" class="_gap"/>
+ <MkRemoteCaution v-if="user.host != null" :href="user.url"/>
- <div class="banner-container _gap" :style="style">
+ <div class="banner-container" :style="style">
<div class="banner" ref="banner" :style="style"></div>
</div>
<div class="contents">
@@ -237,8 +237,8 @@ import Progress from '@client/scripts/loading';
import { parseAcct } from '@/misc/acct';
import { getScrollPosition } from '@client/scripts/scroll';
import { getUserMenu } from '@client/scripts/get-user-menu';
-import number from '../../filters/number';
-import { userPage, acct as getAcct } from '../../filters/user';
+import number from '@client/filters/number';
+import { userPage, acct as getAcct } from '@client/filters/user';
import * as os from '@client/os';
import * as symbols from '@client/symbols';
@@ -276,13 +276,13 @@ export default defineComponent({
return {
[symbols.PAGE_INFO]: computed(() => this.user ? {
title: this.user.name ? `${this.user.name} (@${this.user.username})` : `@${this.user.username}`,
+ subtitle: `@${getAcct(this.user)}`,
userName: this.user,
avatar: this.user,
path: `/@${this.user.username}`,
share: {
title: this.user.name,
},
- menu: () => getUserMenu(this.user),
} : null),
user: null,
error: null,
@@ -314,7 +314,7 @@ export default defineComponent({
mounted() {
window.requestAnimationFrame(this.parallaxLoop);
- this.narrow = true; //this.$el.clientWidth < 1000;
+ this.narrow = this.$el.clientWidth < 1000;
},
beforeUnmount() {
@@ -338,7 +338,7 @@ export default defineComponent({
},
menu(ev) {
- os.modalMenu(getUserMenu(this.user), ev.currentTarget || ev.target);
+ os.popupMenu(getUserMenu(this.user), ev.currentTarget || ev.target);
},
parallaxLoop() {
@@ -382,13 +382,10 @@ export default defineComponent({
}
.ftskorzw.wide {
- max-width: 1150px;
- margin: 0 auto;
> .banner-container {
position: relative;
- height: 450px;
- border-radius: 16px;
+ height: 300px;
overflow: hidden;
background-size: cover;
background-position: center;
@@ -405,6 +402,7 @@ export default defineComponent({
> .contents {
display: flex;
+ padding: 16px;
> .side {
width: 360px;
@@ -562,6 +560,7 @@ export default defineComponent({
.ftskorzw.narrow {
box-sizing: border-box;
overflow: clip;
+ background: var(--bg);
> .punished {
font-size: 0.8em;
diff --git a/src/client/pages/user/pages.vue b/src/client/pages/user/pages.vue
index 34ac9d1ba6..819bd9f2ef 100644
--- a/src/client/pages/user/pages.vue
+++ b/src/client/pages/user/pages.vue
@@ -10,7 +10,7 @@
import { defineComponent } from 'vue';
import MkPagePreview from '@client/components/page-preview.vue';
import MkPagination from '@client/components/ui/pagination.vue';
-import { userPage, acct } from '../../filters/user';
+import { userPage, acct } from '@client/filters/user';
export default defineComponent({
components: {
diff --git a/src/client/pages/welcome.entrance.a.vue b/src/client/pages/welcome.entrance.a.vue
index da3c694265..299271c347 100644
--- a/src/client/pages/welcome.entrance.a.vue
+++ b/src/client/pages/welcome.entrance.a.vue
@@ -117,7 +117,7 @@ export default defineComponent({
},
showMenu(ev) {
- os.modalMenu([{
+ os.popupMenu([{
text: this.$t('aboutX', { x: instanceName }),
icon: 'fas fa-info-circle',
action: () => {
diff --git a/src/client/pages/welcome.entrance.b.vue b/src/client/pages/welcome.entrance.b.vue
index d108eb7d94..a5c12f09e2 100644
--- a/src/client/pages/welcome.entrance.b.vue
+++ b/src/client/pages/welcome.entrance.b.vue
@@ -101,7 +101,7 @@ export default defineComponent({
},
showMenu(ev) {
- os.modalMenu([{
+ os.popupMenu([{
text: this.$t('aboutX', { x: instanceName }),
icon: 'fas fa-info-circle',
action: () => {
diff --git a/src/client/pages/welcome.entrance.c.vue b/src/client/pages/welcome.entrance.c.vue
index 93811e98fb..2c8db6e264 100644
--- a/src/client/pages/welcome.entrance.c.vue
+++ b/src/client/pages/welcome.entrance.c.vue
@@ -121,7 +121,7 @@ export default defineComponent({
},
showMenu(ev) {
- os.modalMenu([{
+ os.popupMenu([{
text: this.$t('aboutX', { x: instanceName }),
icon: 'fas fa-info-circle',
action: () => {
diff --git a/src/client/pages/welcome.setup.vue b/src/client/pages/welcome.setup.vue
index 79464b814a..5ed1ae49c4 100644
--- a/src/client/pages/welcome.setup.vue
+++ b/src/client/pages/welcome.setup.vue
@@ -3,13 +3,13 @@
<h1>Welcome to Misskey!</h1>
<div>
<p>{{ $ts.intro }}</p>
- <MkInput v-model:value="username" pattern="^[a-zA-Z0-9_]{1,20}$" spellcheck="false" required>
- <span>{{ $ts.username }}</span>
+ <MkInput v-model="username" pattern="^[a-zA-Z0-9_]{1,20}$" spellcheck="false" required>
+ <template #label>{{ $ts.username }}</template>
<template #prefix>@</template>
<template #suffix>@{{ host }}</template>
</MkInput>
- <MkInput v-model:value="password" type="password">
- <span>{{ $ts.password }}</span>
+ <MkInput v-model="password" type="password">
+ <template #label>{{ $ts.password }}</template>
<template #prefix><i class="fas fa-lock"></i></template>
</MkInput>
<footer>