3963ed8ff7
* wip * tabun ok * better msg * oops * fix lint * Update gulpfile.ts Co-authored-by: Acid Chicken (硫酸鶏) <root@acid-chicken.com> * Update src/client/scripts/set-i18n-contexts.ts Co-authored-by: Acid Chicken (硫酸鶏) <root@acid-chicken.com> * refactor Co-authored-by: acid-chicken <root@acid-chicken.com> * ✨ * wip * fix lint * たぶんおk * fix flush * Translate Notification * remove console.log * fix * add notifications * remove san * wip * ok * ✌️ * Update src/prelude/array.ts Co-authored-by: Acid Chicken (硫酸鶏) <root@acid-chicken.com> * wip * i18n refactor * Update init.ts * ✌️ Co-authored-by: Acid Chicken (硫酸鶏) <root@acid-chicken.com> Co-authored-by: syuilo <syuilotan@yahoo.co.jp>
71 lines
1.3 KiB
Vue
71 lines
1.3 KiB
Vue
<template>
|
|
<button class="nrvgflfuaxwgkxoynpnumyookecqrrvh _button" @click="toggle">
|
|
<b>{{ value ? this.$t('_cw.hide') : this.$t('_cw.show') }}</b>
|
|
<span v-if="!value">{{ this.label }}</span>
|
|
</button>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import Vue from 'vue';
|
|
import { length } from 'stringz';
|
|
import { concat } from '../../prelude/array';
|
|
|
|
export default Vue.extend({
|
|
props: {
|
|
value: {
|
|
type: Boolean,
|
|
required: true
|
|
},
|
|
note: {
|
|
type: Object,
|
|
required: true
|
|
}
|
|
},
|
|
|
|
computed: {
|
|
label(): string {
|
|
return concat([
|
|
this.note.text ? [this.$t('_cw.chars', { count: length(this.note.text) })] : [],
|
|
this.note.files && this.note.files.length !== 0 ? [this.$t('_cw.files', { count: this.note.files.length }) ] : [],
|
|
this.note.poll != null ? [this.$t('_cw.poll')] : []
|
|
] as string[][]).join(' / ');
|
|
}
|
|
},
|
|
|
|
methods: {
|
|
length,
|
|
|
|
toggle() {
|
|
this.$emit('input', !this.value);
|
|
}
|
|
}
|
|
});
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.nrvgflfuaxwgkxoynpnumyookecqrrvh {
|
|
display: inline-block;
|
|
padding: 4px 8px;
|
|
font-size: 0.7em;
|
|
color: var(--cwFg);
|
|
background: var(--cwBg);
|
|
border-radius: 2px;
|
|
|
|
&:hover {
|
|
background: var(--cwHoverBg);
|
|
}
|
|
|
|
> span {
|
|
margin-left: 4px;
|
|
|
|
&:before {
|
|
content: '(';
|
|
}
|
|
|
|
&:after {
|
|
content: ')';
|
|
}
|
|
}
|
|
}
|
|
</style>
|