forked from mirror/misskey
51 lines
1.8 KiB
Vue
51 lines
1.8 KiB
Vue
<template>
|
|
<!-- TODO: リファクタの余地がありそう -->
|
|
<XWidgetsColumn v-if="column.type === 'widgets'" :column="column" :is-stacked="isStacked" v-on="$listeners"/>
|
|
<XNotificationsColumn v-else-if="column.type === 'notifications'" :column="column" :is-stacked="isStacked" v-on="$listeners"/>
|
|
<XTlColumn v-else-if="column.type === 'tl'" :column="column" :is-stacked="isStacked" v-on="$listeners"/>
|
|
<XListColumn v-else-if="column.type === 'list'" :column="column" :is-stacked="isStacked" v-on="$listeners"/>
|
|
<XAntennaColumn v-else-if="column.type === 'antenna'" :column="column" :is-stacked="isStacked" v-on="$listeners"/>
|
|
<!-- TODO: <XTlColumn v-else-if="column.type === 'hashtag'" :column="column" :is-stacked="isStacked" v-on="$listeners"/> -->
|
|
<XMentionsColumn v-else-if="column.type === 'mentions'" :column="column" :is-stacked="isStacked" v-on="$listeners"/>
|
|
<XDirectColumn v-else-if="column.type === 'direct'" :column="column" :is-stacked="isStacked" v-on="$listeners"/>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { defineComponent } from 'vue';
|
|
import XTlColumn from './tl-column.vue';
|
|
import XAntennaColumn from './antenna-column.vue';
|
|
import XListColumn from './list-column.vue';
|
|
import XNotificationsColumn from './notifications-column.vue';
|
|
import XWidgetsColumn from './widgets-column.vue';
|
|
import XMentionsColumn from './mentions-column.vue';
|
|
import XDirectColumn from './direct-column.vue';
|
|
|
|
export default defineComponent({
|
|
components: {
|
|
XTlColumn,
|
|
XAntennaColumn,
|
|
XListColumn,
|
|
XNotificationsColumn,
|
|
XWidgetsColumn,
|
|
XMentionsColumn,
|
|
XDirectColumn
|
|
},
|
|
props: {
|
|
column: {
|
|
type: Object,
|
|
required: true
|
|
},
|
|
isStacked: {
|
|
type: Boolean,
|
|
required: false,
|
|
default: false
|
|
}
|
|
},
|
|
methods: {
|
|
focus() {
|
|
this.$children[0].focus();
|
|
}
|
|
}
|
|
});
|
|
</script>
|