|
1 | 1 | <script setup lang="ts"> |
2 | | -import { useNotionBlock, defineNotionProps } from "@/lib/blockable" |
3 | | -import { getTextContent } from "@/lib/utils" |
4 | | -import DefaultPageIcon from "./default-page-icon.vue" |
| 2 | +import { useNotionBlock, defineNotionProps } from "@/lib/blockable"; |
| 3 | +import { getTextContent } from "@/lib/utils"; |
| 4 | +import DefaultPageIcon from "./default-page-icon.vue"; |
5 | 5 |
|
6 | | -const props = defineProps({ big: Boolean, ...defineNotionProps }) |
| 6 | +const props = defineProps({ big: Boolean, ...defineNotionProps }); |
7 | 7 | //@ts-ignore |
8 | | -const { icon, format, block, title } = useNotionBlock(props) |
| 8 | +const { icon, format, block, title } = useNotionBlock(props); |
9 | 9 | </script> |
10 | 10 |
|
11 | 11 | <script lang="ts"> |
12 | 12 | export default { |
13 | 13 | name: "NotionPageIcon", |
14 | | -} |
| 14 | +}; |
15 | 15 | </script> |
16 | 16 |
|
17 | 17 | <template> |
18 | | - <img |
19 | | - v-if="icon?.includes('http')" |
20 | | - :class="[format.page_cover && 'notion-page-icon-offset', big ? 'notion-page-icon-cover' : 'notion-page-icon']" |
21 | | - :src="props.mapImageUrl(icon, block)" |
22 | | - :alt="title ? getTextContent(title) : 'Icon'" |
23 | | - /> |
24 | | - <span |
25 | | - v-else-if="icon" |
26 | | - role="img" |
27 | | - :aria-label="icon" |
28 | | - :class="[ |
29 | | - 'notion-emoji', |
30 | | - format.page_cover && 'notion-page-icon-offset', |
31 | | - big ? 'notion-page-icon-cover' : 'notion-page-icon', |
32 | | - ]" |
33 | | - > |
34 | | - {{ icon }} |
35 | | - </span> |
36 | | - <DefaultPageIcon class="notion-page-icon" v-else-if="!big"></DefaultPageIcon> |
| 18 | + <div :class="[format.page_cover && 'notion-page-icon-offset', big ? 'notion-page-icon-cover' : 'notion-page-icon']"> |
| 19 | + <img |
| 20 | + v-if="icon?.includes('http')" |
| 21 | + :src="props.mapImageUrl(icon, block)" |
| 22 | + :alt="title ? getTextContent(title) : 'Icon'" |
| 23 | + class="notion-page-icon" |
| 24 | + /> |
| 25 | + <span v-else-if="icon" role="img" :aria-label="icon" class="notion-page-icon"> |
| 26 | + {{ icon }} |
| 27 | + </span> |
| 28 | + <DefaultPageIcon class="notion-page-icon" v-else-if="!big"></DefaultPageIcon> |
| 29 | + </div> |
37 | 30 | </template> |
0 commit comments