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

63 lines
1.3 KiB
Vue
Raw Normal View History

<template>
2023-04-08 09:01:42 +09:00
<span v-if="note.visibility !== 'public'" :class="$style.visibility">
<i v-if="note.visibility === 'home'" class="ph-house ph-bold ph-lg"></i>
<i
v-else-if="note.visibility === 'followers'"
class="ph-lock-simple-open ph-bold ph-lg"
></i>
<i
v-else-if="note.visibility === 'specified'"
ref="specified"
class="ph-envelope-simple-open ph-bold ph-lg"
></i>
</span>
<span v-if="note.localOnly" :class="$style.localOnly"
><i class="ph-hand-fist ph-bold ph-lg"></i
></span>
</template>
<script lang="ts" setup>
2023-04-08 09:01:42 +09:00
import { ref } from "vue";
import XDetails from "@/components/MkUsersTooltip.vue";
import * as os from "@/os";
import { useTooltip } from "@/scripts/use-tooltip";
const props = defineProps<{
note: {
visibility: string;
localOnly?: boolean;
visibleUserIds?: string[];
2023-04-08 09:01:42 +09:00
};
}>();
const specified = $ref<HTMLElement>();
2023-04-08 09:01:42 +09:00
if (props.note.visibility === "specified") {
useTooltip($$(specified), async (showing) => {
2023-04-08 09:01:42 +09:00
const users = await os.api("users/show", {
userIds: props.note.visibleUserIds,
limit: 10,
});
2023-04-08 09:01:42 +09:00
os.popup(
XDetails,
{
showing,
users,
count: props.note.visibleUserIds.length,
targetElement: specified,
},
{},
"closed"
);
});
}
</script>
<style lang="scss" module>
2023-04-08 09:01:42 +09:00
.visibility,
.localOnly {
margin-left: 0.5em;
}
</style>