リプライとリノートも復元する

This commit is contained in:
Xeltica 2020-03-08 22:20:54 +09:00
parent e292009229
commit f23f7f8d78

View file

@ -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,