hippofish/packages/client/src/components/MkVisibility.vue

87 lines
1.8 KiB
Vue
Raw Normal View History

<template>
2023-04-08 02:01:42 +02:00
<span v-if="note.visibility !== 'public'" :class="$style.visibility">
<i
v-if="note.visibility === 'home'"
v-tooltip="i18n.ts._visibility.home"
:class="icon('ph-house')"
></i>
2023-04-08 02:01:42 +02:00
<i
v-else-if="note.visibility === 'followers'"
v-tooltip="i18n.ts._visibility.followers"
:class="icon('ph-lock')"
2023-04-08 02:01:42 +02:00
></i>
<i
2024-02-20 23:24:52 +01:00
v-else-if="
note.visibility === 'specified' &&
note.visibleUserIds != null &&
note.visibleUserIds.length > 0
"
2023-04-08 02:01:42 +02:00
ref="specified"
:class="icon('ph-envelope-simple-open')"
2023-04-08 02:01:42 +02:00
></i>
2024-02-20 23:24:52 +01:00
<i
v-else-if="note.visibility === 'specified'"
2024-02-21 10:02:13 +01:00
v-tooltip="i18n.ts.private"
2024-02-20 23:24:52 +01:00
ref="specified"
:class="icon('ph-eye-slash')"
></i>
2023-04-08 02:01:42 +02:00
</span>
<span v-if="note.localOnly" :class="$style.localOnly"
2023-10-21 23:52:46 +02:00
><i
v-tooltip="i18n.ts._visibility.localOnly"
:class="icon('ph-users')"
></i
2023-04-08 02:01:42 +02:00
></span>
</template>
<script lang="ts" setup>
import { ref } from "vue";
2023-04-08 02:01:42 +02:00
import XDetails from "@/components/MkUsersTooltip.vue";
import * as os from "@/os";
import { useTooltip } from "@/scripts/use-tooltip";
import { i18n } from "@/i18n";
import icon from "@/scripts/icon";
const props = defineProps<{
note: {
visibility: string;
localOnly?: boolean;
visibleUserIds?: string[];
2023-04-08 02:01:42 +02:00
};
}>();
const specified = ref<HTMLElement>();
2024-02-20 23:24:52 +01:00
if (
props.note.visibility === "specified" &&
props.note.visibleUserIds != null &&
props.note.visibleUserIds.length > 0
) {
useTooltip(specified, async (showing) => {
2023-04-08 02:01:42 +02:00
const users = await os.api("users/show", {
userIds: props.note.visibleUserIds,
limit: 10,
});
2023-04-08 02:01:42 +02:00
os.popup(
XDetails,
{
showing,
users,
count: props.note.visibleUserIds.length,
targetElement: specified.value,
2023-04-08 02:01:42 +02:00
},
{},
2023-07-06 03:28:27 +02:00
"closed",
2023-04-08 02:01:42 +02:00
);
});
}
</script>
<style lang="scss" module>
2023-04-08 02:01:42 +02:00
.visibility,
.localOnly {
margin-left: 0.5em;
}
</style>