|
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