2023-01-04 19:41:19 +09:00
|
|
|
<script setup lang="ts">
|
|
|
|
const { editing } = defineProps<{
|
|
|
|
editing?: boolean
|
|
|
|
}>()
|
|
|
|
|
2023-04-12 21:35:35 +09:00
|
|
|
let { modelValue } = $defineModels<{
|
2023-01-04 19:41:19 +09:00
|
|
|
modelValue: string
|
|
|
|
}>()
|
|
|
|
|
|
|
|
const currentVisibility = $computed(() =>
|
|
|
|
statusVisibilities.find(v => v.value === modelValue) || statusVisibilities[0],
|
|
|
|
)
|
|
|
|
|
2023-03-31 04:01:24 +09:00
|
|
|
function chooseVisibility(visibility: string) {
|
2023-01-04 19:41:19 +09:00
|
|
|
modelValue = visibility
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<CommonTooltip placement="top" :content="editing ? $t(`visibility.${currentVisibility.value}`) : $t('tooltip.change_content_visibility')">
|
|
|
|
<CommonDropdown placement="bottom">
|
|
|
|
<slot :visibility="currentVisibility" />
|
|
|
|
<template #popper>
|
|
|
|
<CommonDropdownItem
|
|
|
|
v-for="visibility in statusVisibilities"
|
|
|
|
:key="visibility.value"
|
|
|
|
:icon="visibility.icon"
|
|
|
|
:text="$t(`visibility.${visibility.value}`)"
|
|
|
|
:description="$t(`visibility.${visibility.value}_desc`)"
|
|
|
|
:checked="visibility.value === modelValue"
|
|
|
|
@click="chooseVisibility(visibility.value)"
|
|
|
|
/>
|
|
|
|
</template>
|
|
|
|
</CommonDropdown>
|
|
|
|
</CommonTooltip>
|
|
|
|
</template>
|