リプライとリノートも復元する
This commit is contained in:
parent
e292009229
commit
f23f7f8d78
|
@ -19,8 +19,8 @@
|
||||||
</div>
|
</div>
|
||||||
</header>
|
</header>
|
||||||
<div class="form" :class="{ fixed }">
|
<div class="form" :class="{ fixed }">
|
||||||
<x-note-preview class="preview" v-if="reply" :note="reply"/>
|
<x-note-preview class="preview" v-if="attachedReply" :note="attachedReply"/>
|
||||||
<x-note-preview class="preview" v-if="renote" :note="renote"/>
|
<x-note-preview class="preview" v-if="attachedRenote" :note="attachedRenote"/>
|
||||||
<div class="with-quote" v-if="quoteId"><fa icon="quote-left"/> {{ $t('quoteAttached') }}<button @click="quoteId = null"><fa icon="times"/></button></div>
|
<div class="with-quote" v-if="quoteId"><fa icon="quote-left"/> {{ $t('quoteAttached') }}<button @click="quoteId = null"><fa icon="times"/></button></div>
|
||||||
<div v-if="visibility === 'specified'" class="to-specified">
|
<div v-if="visibility === 'specified'" class="to-specified">
|
||||||
<span style="margin-right: 8px;">{{ $t('recipient') }}</span>
|
<span style="margin-right: 8px;">{{ $t('recipient') }}</span>
|
||||||
|
@ -134,6 +134,8 @@ export default Vue.extend({
|
||||||
autocomplete: null,
|
autocomplete: null,
|
||||||
draghover: false,
|
draghover: false,
|
||||||
quoteId: null,
|
quoteId: null,
|
||||||
|
attachedReply: null,
|
||||||
|
attachedRenote: null,
|
||||||
recentHashtags: JSON.parse(localStorage.getItem('hashtags') || '[]'),
|
recentHashtags: JSON.parse(localStorage.getItem('hashtags') || '[]'),
|
||||||
faReply, faQuoteRight, faPaperPlane, faTimes, faUpload, faChartPie, faGlobe, faHome, faUnlock, faEnvelope, faEyeSlash, faLaughSquint, faPlus, faPhotoVideo, faCloud, faLink, faAt, faBiohazard
|
faReply, faQuoteRight, faPaperPlane, faTimes, faUpload, faChartPie, faGlobe, faHome, faUnlock, faEnvelope, faEyeSlash, faLaughSquint, faPlus, faPhotoVideo, faCloud, faLink, faAt, faBiohazard
|
||||||
};
|
};
|
||||||
|
@ -141,10 +143,10 @@ export default Vue.extend({
|
||||||
|
|
||||||
computed: {
|
computed: {
|
||||||
draftId(): string {
|
draftId(): string {
|
||||||
return this.renote
|
return this.attachedRenote
|
||||||
? `renote:${this.renote.id}`
|
? `renote:${this.attachedRenote.id}`
|
||||||
: this.reply
|
: this.attachedReply
|
||||||
? `reply:${this.reply.id}`
|
? `reply:${this.attachedReply.id}`
|
||||||
: 'note';
|
: 'note';
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -159,24 +161,24 @@ export default Vue.extend({
|
||||||
];
|
];
|
||||||
const x = xs[Math.floor(Math.random() * xs.length)];
|
const x = xs[Math.floor(Math.random() * xs.length)];
|
||||||
|
|
||||||
return this.renote
|
return this.attachedRenote
|
||||||
? this.$t('_postForm.quotePlaceholder')
|
? this.$t('_postForm.quotePlaceholder')
|
||||||
: this.reply
|
: this.attachedReply
|
||||||
? this.$t('_postForm.replyPlaceholder')
|
? this.$t('_postForm.replyPlaceholder')
|
||||||
: x;
|
: x;
|
||||||
},
|
},
|
||||||
|
|
||||||
submitText(): string {
|
submitText(): string {
|
||||||
return this.renote
|
return this.attachedRenote
|
||||||
? this.$t('quote')
|
? this.$t('quote')
|
||||||
: this.reply
|
: this.attachedReply
|
||||||
? this.$t('reply')
|
? this.$t('reply')
|
||||||
: this.$t('note');
|
: this.$t('note');
|
||||||
},
|
},
|
||||||
|
|
||||||
canPost(): boolean {
|
canPost(): boolean {
|
||||||
return !this.posting &&
|
return !this.posting &&
|
||||||
(1 <= this.text.length || 1 <= this.files.length || this.poll || this.renote) &&
|
(1 <= this.text.length || 1 <= this.files.length || this.poll || this.attachedRenote) &&
|
||||||
(length(this.text.trim()) <= this.max) &&
|
(length(this.text.trim()) <= this.max) &&
|
||||||
(!this.poll || this.pollChoices.length >= 2);
|
(!this.poll || this.pollChoices.length >= 2);
|
||||||
},
|
},
|
||||||
|
@ -202,12 +204,15 @@ export default Vue.extend({
|
||||||
this.text += ' ';
|
this.text += ' ';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.reply && this.reply.user.host != null) {
|
this.attachedReply = this.reply;
|
||||||
this.text = `@${this.reply.user.username}@${toASCII(this.reply.user.host)} `;
|
this.attachedRenote = this.renote;
|
||||||
|
|
||||||
|
if (this.attachedReply && this.attachedReply.user.host != null) {
|
||||||
|
this.text = `@${this.attachedReply.user.username}@${toASCII(this.attachedReply.user.host)} `;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.reply && this.reply.text != null) {
|
if (this.attachedReply && this.attachedReply.text != null) {
|
||||||
const ast = parse(this.reply.text);
|
const ast = parse(this.attachedReply.text);
|
||||||
|
|
||||||
for (const x of extractMentions(ast)) {
|
for (const x of extractMentions(ast)) {
|
||||||
const mention = x.host ? `@${x.username}@${toASCII(x.host)}` : `@${x.username}`;
|
const mention = x.host ? `@${x.username}@${toASCII(x.host)}` : `@${x.username}`;
|
||||||
|
@ -229,17 +234,17 @@ export default Vue.extend({
|
||||||
this.localOnly = this.$store.state.settings.rememberNoteVisibility ? this.$store.state.deviceUser.localOnly : this.$store.state.settings.defaultNoteLocalOnly;
|
this.localOnly = this.$store.state.settings.rememberNoteVisibility ? this.$store.state.deviceUser.localOnly : this.$store.state.settings.defaultNoteLocalOnly;
|
||||||
|
|
||||||
// 公開以外へのリプライ時は元の公開範囲を引き継ぐ
|
// 公開以外へのリプライ時は元の公開範囲を引き継ぐ
|
||||||
if (this.reply && ['home', 'followers', 'specified'].includes(this.reply.visibility)) {
|
if (this.attachedReply && ['home', 'followers', 'specified'].includes(this.attachedReply.visibility)) {
|
||||||
this.visibility = this.reply.visibility;
|
this.visibility = this.attachedReply.visibility;
|
||||||
if (this.reply.visibility === 'specified') {
|
if (this.attachedReply.visibility === 'specified') {
|
||||||
this.$root.api('users/show', {
|
this.$root.api('users/show', {
|
||||||
userIds: this.reply.visibleUserIds.filter(uid => uid !== this.$store.state.i.id && uid !== this.reply.userId)
|
userIds: this.attachedReply.visibleUserIds.filter(uid => uid !== this.$store.state.i.id && uid !== this.attachedReply.userId)
|
||||||
}).then(users => {
|
}).then(users => {
|
||||||
this.visibleUsers.push(...users);
|
this.visibleUsers.push(...users);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (this.reply.userId !== this.$store.state.i.id) {
|
if (this.attachedReply.userId !== this.$store.state.i.id) {
|
||||||
this.$root.api('users/show', { userId: this.reply.userId }).then(user => {
|
this.$root.api('users/show', { userId: this.attachedReply.userId }).then(user => {
|
||||||
this.visibleUsers.push(user);
|
this.visibleUsers.push(user);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -252,9 +257,9 @@ export default Vue.extend({
|
||||||
}
|
}
|
||||||
|
|
||||||
// keep cw when reply
|
// keep cw when reply
|
||||||
if (this.$store.state.settings.keepCw && this.reply && this.reply.cw) {
|
if (this.$store.state.settings.keepCw && this.attachedReply && this.attachedReply.cw) {
|
||||||
this.useCw = true;
|
this.useCw = true;
|
||||||
this.cw = this.reply.cw;
|
this.cw = this.attachedReply.cw;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.focus();
|
this.focus();
|
||||||
|
@ -301,7 +306,8 @@ export default Vue.extend({
|
||||||
}
|
}
|
||||||
this.visibility = init.visibility;
|
this.visibility = init.visibility;
|
||||||
this.localOnly = init.localOnly;
|
this.localOnly = init.localOnly;
|
||||||
this.quoteId = init.renote ? init.renote.id : null;
|
this.attachedRenote = init.renote;
|
||||||
|
this.attachedReply = init.reply;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.$nextTick(() => this.watch());
|
this.$nextTick(() => this.watch());
|
||||||
|
@ -446,7 +452,7 @@ export default Vue.extend({
|
||||||
|
|
||||||
const paste = e.clipboardData.getData('text');
|
const paste = e.clipboardData.getData('text');
|
||||||
|
|
||||||
if (!this.renote && !this.quoteId && paste.startsWith(url + '/notes/')) {
|
if (!this.attachedRenote && !this.quoteId && paste.startsWith(url + '/notes/')) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
|
||||||
this.$root.dialog({
|
this.$root.dialog({
|
||||||
|
@ -537,8 +543,8 @@ export default Vue.extend({
|
||||||
this.$root.api('notes/create', {
|
this.$root.api('notes/create', {
|
||||||
text: this.text == '' ? undefined : this.text,
|
text: this.text == '' ? undefined : this.text,
|
||||||
fileIds: this.files.length > 0 ? this.files.map(f => f.id) : undefined,
|
fileIds: this.files.length > 0 ? this.files.map(f => f.id) : undefined,
|
||||||
replyId: this.reply ? this.reply.id : undefined,
|
replyId: this.attachedReply ? this.attachedReply.id : undefined,
|
||||||
renoteId: this.renote ? this.renote.id : this.quoteId ? this.quoteId : undefined,
|
renoteId: this.attachedRenote ? this.attachedRenote.id : this.quoteId ? this.quoteId : undefined,
|
||||||
poll: this.poll ? (this.$refs.poll as any).get() : undefined,
|
poll: this.poll ? (this.$refs.poll as any).get() : undefined,
|
||||||
cw: this.useCw ? this.cw || '' : undefined,
|
cw: this.useCw ? this.cw || '' : undefined,
|
||||||
localOnly: this.localOnly,
|
localOnly: this.localOnly,
|
||||||
|
|
Loading…
Reference in a new issue