erudit 3.0.0-dev.4 → 3.0.0-dev.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (243) hide show
  1. package/app/app.vue +195 -172
  2. package/app/components/Loading.vue +23 -23
  3. package/app/components/SiteAside.vue +393 -382
  4. package/app/components/SiteMain.vue +35 -35
  5. package/app/components/ads/BannerTemplate.vue +51 -51
  6. package/app/components/ads/BottomBanner.vue +45 -45
  7. package/app/components/ads/LeftBanner.vue +50 -50
  8. package/app/components/aside/AsideListItem.vue +74 -74
  9. package/app/components/aside/AsideMajor.vue +56 -56
  10. package/app/components/aside/AsideMinor.vue +71 -71
  11. package/app/components/aside/major/PaneContentScroll.vue +23 -23
  12. package/app/components/aside/major/PaneSwitch.vue +54 -54
  13. package/app/components/aside/major/PaneSwitchButton.vue +63 -63
  14. package/app/components/aside/major/SiteInfo.vue +85 -85
  15. package/app/components/aside/major/panes/Language.vue +79 -79
  16. package/app/components/aside/major/panes/Pages.vue +34 -34
  17. package/app/components/aside/major/panes/Search.vue +11 -11
  18. package/app/components/aside/major/panes/nav/Nav.vue +87 -91
  19. package/app/components/aside/major/panes/nav/NavBook.vue +87 -87
  20. package/app/components/aside/major/panes/nav/NavBookLoading.vue +24 -24
  21. package/app/components/aside/major/panes/nav/NavGlobal.vue +16 -16
  22. package/app/components/aside/major/panes/nav/fnav/FNav.vue +105 -105
  23. package/app/components/aside/major/panes/nav/fnav/FNavBook.vue +32 -32
  24. package/app/components/aside/major/panes/nav/fnav/FNavFlags.vue +40 -40
  25. package/app/components/aside/major/panes/nav/fnav/FNavFolder.vue +60 -60
  26. package/app/components/aside/major/panes/nav/fnav/FNavItem.vue +34 -34
  27. package/app/components/aside/major/panes/nav/fnav/FNavSeparator.vue +80 -80
  28. package/app/components/aside/major/panes/nav/fnav/FNavTopic.vue +24 -24
  29. package/app/components/aside/major/panes/other/ItemContent.vue +29 -29
  30. package/app/components/aside/major/panes/other/ItemGenerator.vue +15 -15
  31. package/app/components/aside/major/panes/other/ItemTheme.vue +54 -54
  32. package/app/components/aside/major/panes/other/Other.vue +16 -16
  33. package/app/components/aside/minor/AsideMinorContributor.vue +5 -5
  34. package/app/components/aside/minor/AsideMinorNews.vue +11 -11
  35. package/app/components/aside/minor/AsideMinorPane.vue +15 -15
  36. package/app/components/aside/minor/AsideMinorTopLink.vue +67 -67
  37. package/app/components/aside/minor/Contribute.vue +145 -145
  38. package/app/components/aside/minor/content/AsideMinorContent.vue +92 -92
  39. package/app/components/aside/minor/topic/AsideMinorTopic.vue +32 -32
  40. package/app/components/aside/minor/topic/TopicContributors.vue +177 -177
  41. package/app/components/aside/minor/topic/TopicNav.vue +49 -49
  42. package/app/components/aside/minor/topic/TopicToc.vue +219 -203
  43. package/app/components/aside/minor/topic/TopicTocItem.vue +30 -31
  44. package/app/components/aside/utils/AsideOverlayPane.vue +40 -40
  45. package/app/components/bitran/BitranContent.vue +70 -63
  46. package/app/components/bitran/RenderWrapper.vue +10 -10
  47. package/app/components/contributor/ContributorAvatar.vue +43 -43
  48. package/app/components/contributor/ContributorListItem.vue +35 -35
  49. package/app/components/main/topic/MainTopic.vue +79 -79
  50. package/app/components/main/topic/TopicPartSwitch.vue +118 -118
  51. package/app/components/main/utils/Breadcrumb.vue +75 -75
  52. package/app/components/main/utils/ContentDecoration.vue +29 -29
  53. package/app/components/main/utils/ContentDescription.vue +19 -19
  54. package/app/components/main/utils/ContentPopover.vue +188 -176
  55. package/app/components/main/utils/ContentPopovers.vue +105 -105
  56. package/app/components/main/utils/ContentReferences.vue +70 -70
  57. package/app/components/main/utils/ContentSection.vue +45 -45
  58. package/app/components/main/utils/ContentTitle.vue +63 -39
  59. package/app/components/main/utils/reference/ReferenceGroup.vue +38 -38
  60. package/app/components/main/utils/reference/ReferenceItem.vue +68 -68
  61. package/app/components/main/utils/reference/ReferenceSource.vue +116 -116
  62. package/app/components/preview/Preview.vue +186 -177
  63. package/app/components/preview/PreviewDisplay.vue +139 -139
  64. package/app/components/preview/PreviewFooterAction.vue +73 -73
  65. package/app/components/preview/PreviewLoading.vue +14 -14
  66. package/app/components/preview/PreviewScreen.vue +141 -99
  67. package/app/components/preview/display/Alert.vue +50 -50
  68. package/app/components/preview/display/Custom.vue +18 -18
  69. package/app/components/preview/display/GenericLink.vue +48 -48
  70. package/app/components/preview/display/PageLink.vue +20 -20
  71. package/app/components/preview/display/Unique.vue +49 -49
  72. package/app/components/transition/Fade.vue +19 -19
  73. package/app/components/tree/TreeContainer.vue +11 -11
  74. package/app/components/tree/TreeItem.vue +89 -89
  75. package/app/composables/bitran.ts +129 -127
  76. package/app/composables/bitranContent.ts +39 -39
  77. package/app/composables/bitranLocation.ts +7 -7
  78. package/app/composables/contentData.ts +36 -36
  79. package/app/composables/contentPage.ts +157 -156
  80. package/app/composables/contentRoute.ts +45 -45
  81. package/app/composables/darkMagic.ts +24 -24
  82. package/app/composables/externalApi.ts +63 -63
  83. package/app/composables/favicon.ts +8 -8
  84. package/app/composables/formatText.ts +86 -86
  85. package/app/composables/majorPane.ts +60 -60
  86. package/app/composables/phrases.ts +81 -81
  87. package/app/composables/theme.ts +29 -29
  88. package/app/composables/url.ts +33 -33
  89. package/app/pages/_test/preview.vue +110 -110
  90. package/app/pages/article/[...articleId].vue +3 -3
  91. package/app/pages/book/[...bookId].vue +47 -47
  92. package/app/pages/group/[...groupId].vue +65 -65
  93. package/app/pages/index.vue +32 -32
  94. package/app/pages/members.vue +6 -6
  95. package/app/pages/practice/[...practice].vue +3 -3
  96. package/app/pages/summary/[...summaryId].vue +3 -3
  97. package/app/public/favicon/article.svg +9 -9
  98. package/app/public/favicon/default.svg +3 -3
  99. package/app/public/favicon/practice.svg +3 -3
  100. package/app/public/favicon/summary.svg +4 -4
  101. package/app/public/logotype.svg +2 -2
  102. package/app/scripts/_immediate.js +9 -9
  103. package/app/scripts/aside/index.ts +59 -59
  104. package/app/scripts/aside/major/nav.ts +26 -26
  105. package/app/scripts/aside/minor/state.ts +37 -37
  106. package/app/scripts/aside/minor/topic.ts +3 -3
  107. package/app/scripts/flag.ts +28 -28
  108. package/app/scripts/og.ts +27 -27
  109. package/app/scripts/preview/build.ts +73 -73
  110. package/app/scripts/preview/data/alert.ts +19 -19
  111. package/app/scripts/preview/data/custom.ts +8 -8
  112. package/app/scripts/preview/data/genericLink.ts +24 -24
  113. package/app/scripts/preview/data/pageLink.ts +22 -22
  114. package/app/scripts/preview/data/unique.ts +71 -71
  115. package/app/scripts/preview/data.ts +24 -24
  116. package/app/scripts/preview/display.ts +37 -37
  117. package/app/scripts/preview/footer.ts +9 -9
  118. package/app/scripts/preview/request.ts +51 -51
  119. package/app/scripts/preview/state.ts +63 -63
  120. package/app/styles/_immediate.css +7 -7
  121. package/app/styles/_util.scss +43 -43
  122. package/app/styles/_utils.scss +44 -44
  123. package/app/styles/app.scss +91 -91
  124. package/app/styles/def/_bp.scss +27 -27
  125. package/app/styles/def/_size.scss +7 -7
  126. package/app/styles/def/_z.scss +5 -5
  127. package/app/styles/normalize.scss +63 -63
  128. package/app/styles/partials/_darkMagic.scss +5 -5
  129. package/app/styles/partials/_fnav.scss +15 -15
  130. package/app/styles/partials/_preview.scss +5 -5
  131. package/globalPath.ts +21 -21
  132. package/globals/bitran.ts +2 -47
  133. package/globals/content.ts +22 -22
  134. package/globals/contributor.ts +5 -5
  135. package/globals/erudit.ts +5 -5
  136. package/globals/register.ts +18 -18
  137. package/languages/en.ts +95 -95
  138. package/languages/ru.ts +99 -99
  139. package/module/bitran.ts +35 -34
  140. package/module/config.ts +34 -34
  141. package/module/imports.ts +50 -46
  142. package/module/index.ts +47 -47
  143. package/module/logger.ts +10 -10
  144. package/module/paths.ts +22 -22
  145. package/module/restart.ts +61 -61
  146. package/nuxt.config.ts +138 -112
  147. package/package.json +7 -8
  148. package/server/api/aside/major/nav/bookIds.ts +5 -5
  149. package/server/api/aside/major/nav/bookNav/[...bookId].ts +20 -20
  150. package/server/api/aside/major/nav/global.ts +7 -7
  151. package/server/api/aside/minor/news.ts +7 -7
  152. package/server/api/aside/minor/path.ts +78 -78
  153. package/server/api/bitran/content/[location].ts +8 -8
  154. package/server/api/bitran/toc/[location].ts +7 -7
  155. package/server/api/content/data.ts +72 -72
  156. package/server/api/contributor/count.ts +6 -6
  157. package/server/api/fake/content.ts +11 -11
  158. package/server/api/fake/shared/languages.ts +12 -12
  159. package/server/api/language/functions.ts +12 -12
  160. package/server/api/language/phrase/[phraseId].ts +19 -19
  161. package/server/api/language/phraseIds.ts +8 -8
  162. package/server/api/preview/page/[...parts].ts +51 -51
  163. package/server/api/preview/unique/[location].ts +57 -57
  164. package/server/plugin/bitran/content.ts +187 -187
  165. package/server/plugin/bitran/location.ts +25 -25
  166. package/server/plugin/bitran/products/include.ts +230 -230
  167. package/server/plugin/bitran/products/link.ts +116 -116
  168. package/server/plugin/bitran/setup.ts +11 -9
  169. package/server/plugin/bitran/toc.ts +83 -83
  170. package/server/plugin/bitran/transpiler.ts +48 -46
  171. package/server/plugin/build/close.ts +10 -10
  172. package/server/plugin/build/jobs/content/builderArgs.ts +8 -8
  173. package/server/plugin/build/jobs/content/generic.ts +176 -176
  174. package/server/plugin/build/jobs/content/parse.ts +100 -100
  175. package/server/plugin/build/jobs/content/path.ts +6 -6
  176. package/server/plugin/build/jobs/content/type/book.ts +9 -9
  177. package/server/plugin/build/jobs/content/type/group.ts +37 -37
  178. package/server/plugin/build/jobs/content/type/topic.ts +36 -36
  179. package/server/plugin/build/jobs/contributors.ts +66 -66
  180. package/server/plugin/build/jobs/language.ts +36 -36
  181. package/server/plugin/build/jobs/nav.ts +210 -210
  182. package/server/plugin/build/process.ts +25 -25
  183. package/server/plugin/build/rebuild.ts +55 -55
  184. package/server/plugin/build/setup.ts +21 -21
  185. package/server/plugin/content/absoluteId.ts +94 -94
  186. package/server/plugin/content/context.ts +112 -112
  187. package/server/plugin/db/entities/Book.ts +7 -7
  188. package/server/plugin/db/entities/Content.ts +49 -49
  189. package/server/plugin/db/entities/Contribution.ts +10 -10
  190. package/server/plugin/db/entities/Contributor.ts +16 -16
  191. package/server/plugin/db/entities/Group.ts +14 -14
  192. package/server/plugin/db/entities/Hash.ts +15 -15
  193. package/server/plugin/db/entities/Topic.ts +20 -20
  194. package/server/plugin/db/entities/Unique.ts +21 -21
  195. package/server/plugin/db/setup.ts +34 -34
  196. package/server/plugin/global.ts +17 -18
  197. package/server/plugin/importer.ts +12 -12
  198. package/server/plugin/index.ts +9 -9
  199. package/server/plugin/logger.ts +23 -23
  200. package/server/plugin/nav/node.ts +26 -26
  201. package/server/plugin/nav/utils.ts +129 -129
  202. package/server/plugin/repository/book.ts +21 -21
  203. package/server/plugin/repository/content.ts +238 -238
  204. package/server/plugin/repository/contributor.ts +8 -8
  205. package/server/plugin/repository/frontNav.ts +148 -148
  206. package/server/plugin/repository/topic.ts +32 -32
  207. package/server/tsconfig.json +9 -9
  208. package/shared/aside/minor.ts +50 -50
  209. package/shared/asset.ts +15 -15
  210. package/shared/bitran/context.ts +8 -8
  211. package/shared/bitran/default.ts +46 -46
  212. package/shared/bitran/link/Link.vue +166 -167
  213. package/shared/bitran/link/factory.ts +24 -24
  214. package/shared/bitran/link/languages/en.ts +7 -7
  215. package/shared/bitran/link/languages/ru.ts +7 -7
  216. package/shared/bitran/link/renderer.ts +21 -21
  217. package/shared/bitran/link/shared.ts +17 -17
  218. package/shared/bitran/link/target.ts +134 -134
  219. package/shared/bitran/link/transpiler.ts +10 -10
  220. package/shared/bitran/location.ts +166 -166
  221. package/shared/bitran/toc.ts +8 -8
  222. package/shared/content/context.ts +9 -9
  223. package/shared/content/data/base.ts +32 -32
  224. package/shared/content/data/index.ts +5 -5
  225. package/shared/content/data/type/book.ts +5 -5
  226. package/shared/content/data/type/group.ts +6 -6
  227. package/shared/content/data/type/topic.ts +11 -11
  228. package/shared/content/previousNext.ts +9 -9
  229. package/shared/contributor.ts +5 -5
  230. package/shared/frontNav.ts +41 -41
  231. package/shared/icons.ts +38 -38
  232. package/shared/image.ts +5 -5
  233. package/shared/link.ts +25 -25
  234. package/shared/popover.ts +8 -0
  235. package/shared/types/language.ts +75 -75
  236. package/shared/utils/objectsEqual.ts +4 -4
  237. package/shared/utils/stringColor.ts +9 -9
  238. package/test/bitran/link/target.test.ts +141 -141
  239. package/test/bitran/location.test.ts +143 -143
  240. package/tsconfig.json +8 -8
  241. package/utils/stress.ts +9 -9
  242. package/app/components/main/utils/ContentFlag.vue +0 -15
  243. package/app/styles/default.scss +0 -83
@@ -1,16 +1,16 @@
1
- <script lang="ts" setup>
2
- import { getAsideMajorNavPayload } from '@app/scripts/aside/major/nav';
3
-
4
- import FNav from './fnav/FNav.vue';
5
- import PaneContentScroll from '../../PaneContentScroll.vue';
6
-
7
- const contentRoute = useContentRoute();
8
- const asideMajorNav = getAsideMajorNavPayload();
9
- const globalNav = asideMajorNav.globalNav;
10
- </script>
11
-
12
- <template>
13
- <PaneContentScroll>
14
- <FNav :nav="globalNav" :contentId="contentRoute?.contentId" />
15
- </PaneContentScroll>
16
- </template>
1
+ <script lang="ts" setup>
2
+ import { getAsideMajorNavPayload } from '@app/scripts/aside/major/nav';
3
+
4
+ import FNav from './fnav/FNav.vue';
5
+ import PaneContentScroll from '../../PaneContentScroll.vue';
6
+
7
+ const contentRoute = useContentRoute();
8
+ const asideMajorNav = getAsideMajorNavPayload();
9
+ const globalNav = asideMajorNav.globalNav;
10
+ </script>
11
+
12
+ <template>
13
+ <PaneContentScroll>
14
+ <FNav :nav="globalNav" :contentId="contentRoute?.contentId" />
15
+ </PaneContentScroll>
16
+ </template>
@@ -1,105 +1,105 @@
1
- <script lang="ts" setup>
2
- import type {
3
- FrontNav,
4
- FrontNavContainer,
5
- FrontNavItem,
6
- } from '@shared/frontNav';
7
- import { navStateKey, type NavState } from '@app/scripts/aside/major/nav';
8
-
9
- import FNavItem from './FNavItem.vue';
10
-
11
- const props = defineProps<{ nav: FrontNav; contentId?: string }>();
12
- const hashNav = shallowRef<Record<string, FrontNavItem>>();
13
- const navState = shallowRef<NavState>();
14
-
15
- function setupHashNav() {
16
- hashNav.value = {};
17
-
18
- if (!props.nav) return;
19
-
20
- function addNavItem(navItem: FrontNavItem) {
21
- hashNav.value![navItem.fullId] = navItem;
22
- for (const child of (navItem as FrontNavContainer).children || [])
23
- addNavItem(child);
24
- }
25
-
26
- for (const topNavItem of props.nav) addNavItem(topNavItem);
27
- }
28
-
29
- function setupNavState() {
30
- // We create a ref for every nav item to check wheter it is active or not.
31
- // Yes, it uses a lot of memory, but it is still better than messing with recursive tree recreations.
32
-
33
- navState.value = {};
34
-
35
- for (const navItem of Object.values(hashNav.value!))
36
- navState.value[navItem.id] = shallowRef(null);
37
- }
38
-
39
- function updateNavState() {
40
- // We watch current content route and update navigation state for each item.
41
- // United watcher here instead of watcher on each navigation item instance.
42
-
43
- if (!hashNav.value || !navState.value) return;
44
-
45
- let currentFullId: string | undefined;
46
-
47
- for (const navItem of Object.values(hashNav.value)) {
48
- navState.value[navItem.id]!.value = null;
49
- if (props.contentId?.startsWith(navItem.id))
50
- currentFullId = navItem.fullId;
51
- }
52
-
53
- if (!currentFullId) return;
54
-
55
- const idParts = currentFullId.split('/');
56
- while (idParts.length) {
57
- const _fullId = idParts.join('/');
58
- const navItem = hashNav.value[_fullId];
59
-
60
- if (navItem)
61
- navState.value[navItem.id]!.value =
62
- _fullId === currentFullId ? 'active' : 'activePart';
63
-
64
- idParts.pop();
65
- }
66
- }
67
-
68
- setupHashNav();
69
- setupNavState();
70
- updateNavState();
71
-
72
- watch(
73
- () => props.nav,
74
- () => {
75
- setupHashNav();
76
- setupNavState();
77
- updateNavState();
78
- },
79
- );
80
-
81
- watch(() => props.contentId, updateNavState);
82
-
83
- // @ts-ignore
84
- provide(navStateKey, navState);
85
-
86
- const phrase = await usePhrases('empty_nav');
87
- </script>
88
-
89
- <template>
90
- <TreeContainer v-if="nav && nav.length > 0">
91
- <slot name="before"></slot>
92
- <FNavItem v-for="navItem of nav" :navItem />
93
- </TreeContainer>
94
- <div v-else :class="$style.emptyNav">
95
- {{ phrase.empty_nav }}
96
- </div>
97
- </template>
98
-
99
- <style lang="scss" module>
100
- .emptyNav {
101
- padding: var(--gap);
102
- color: var(--textMuted);
103
- text-align: center;
104
- }
105
- </style>
1
+ <script lang="ts" setup>
2
+ import type {
3
+ FrontNav,
4
+ FrontNavContainer,
5
+ FrontNavItem,
6
+ } from '@shared/frontNav';
7
+ import { navStateKey, type NavState } from '@app/scripts/aside/major/nav';
8
+
9
+ import FNavItem from './FNavItem.vue';
10
+
11
+ const props = defineProps<{ nav: FrontNav; contentId?: string }>();
12
+ const hashNav = shallowRef<Record<string, FrontNavItem>>();
13
+ const navState = shallowRef<NavState>();
14
+
15
+ function setupHashNav() {
16
+ hashNav.value = {};
17
+
18
+ if (!props.nav) return;
19
+
20
+ function addNavItem(navItem: FrontNavItem) {
21
+ hashNav.value![navItem.fullId] = navItem;
22
+ for (const child of (navItem as FrontNavContainer).children || [])
23
+ addNavItem(child);
24
+ }
25
+
26
+ for (const topNavItem of props.nav) addNavItem(topNavItem);
27
+ }
28
+
29
+ function setupNavState() {
30
+ // We create a ref for every nav item to check wheter it is active or not.
31
+ // Yes, it uses a lot of memory, but it is still better than messing with recursive tree recreations.
32
+
33
+ navState.value = {};
34
+
35
+ for (const navItem of Object.values(hashNav.value!))
36
+ navState.value[navItem.id] = shallowRef(null);
37
+ }
38
+
39
+ function updateNavState() {
40
+ // We watch current content route and update navigation state for each item.
41
+ // United watcher here instead of watcher on each navigation item instance.
42
+
43
+ if (!hashNav.value || !navState.value) return;
44
+
45
+ let currentFullId: string | undefined;
46
+
47
+ for (const navItem of Object.values(hashNav.value)) {
48
+ navState.value[navItem.id]!.value = null;
49
+ if (props.contentId?.startsWith(navItem.id))
50
+ currentFullId = navItem.fullId;
51
+ }
52
+
53
+ if (!currentFullId) return;
54
+
55
+ const idParts = currentFullId.split('/');
56
+ while (idParts.length) {
57
+ const _fullId = idParts.join('/');
58
+ const navItem = hashNav.value[_fullId];
59
+
60
+ if (navItem)
61
+ navState.value[navItem.id]!.value =
62
+ _fullId === currentFullId ? 'active' : 'activePart';
63
+
64
+ idParts.pop();
65
+ }
66
+ }
67
+
68
+ setupHashNav();
69
+ setupNavState();
70
+ updateNavState();
71
+
72
+ watch(
73
+ () => props.nav,
74
+ () => {
75
+ setupHashNav();
76
+ setupNavState();
77
+ updateNavState();
78
+ },
79
+ );
80
+
81
+ watch(() => props.contentId, updateNavState);
82
+
83
+ // @ts-ignore
84
+ provide(navStateKey, navState);
85
+
86
+ const phrase = await usePhrases('empty_nav');
87
+ </script>
88
+
89
+ <template>
90
+ <TreeContainer v-if="nav && nav.length > 0">
91
+ <slot name="before"></slot>
92
+ <FNavItem v-for="navItem of nav" :navItem />
93
+ </TreeContainer>
94
+ <div v-else :class="$style.emptyNav">
95
+ {{ phrase.empty_nav }}
96
+ </div>
97
+ </template>
98
+
99
+ <style lang="scss" module>
100
+ .emptyNav {
101
+ padding: var(--gap);
102
+ color: var(--textMuted);
103
+ text-align: center;
104
+ }
105
+ </style>
@@ -1,32 +1,32 @@
1
- <script lang="ts" setup>
2
- import type { FrontNavBook } from '@shared/frontNav';
3
- import {
4
- insideNavBook,
5
- navBookId,
6
- navStateKey,
7
- } from '@app/scripts/aside/major/nav';
8
-
9
- import FNavFlags from './FNavFlags.vue';
10
-
11
- const props = defineProps<{ navItem: FrontNavBook }>();
12
- const navState = inject(navStateKey);
13
- const active = computed(() => !!navState!.value[props.navItem.id]!.value);
14
-
15
- function bookClick() {
16
- navBookId.value = props.navItem.id;
17
- insideNavBook.value = true;
18
- }
19
- </script>
20
-
21
- <template>
22
- <TreeItem
23
- icon="outline/book"
24
- :label="navItem.label"
25
- :level="navItem.level"
26
- :link="active ? undefined : `/book/${navItem.id}`"
27
- @click="bookClick"
28
- :active
29
- >
30
- <FNavFlags v-if="navItem.flags" :flags="navItem.flags" />
31
- </TreeItem>
32
- </template>
1
+ <script lang="ts" setup>
2
+ import type { FrontNavBook } from '@shared/frontNav';
3
+ import {
4
+ insideNavBook,
5
+ navBookId,
6
+ navStateKey,
7
+ } from '@app/scripts/aside/major/nav';
8
+
9
+ import FNavFlags from './FNavFlags.vue';
10
+
11
+ const props = defineProps<{ navItem: FrontNavBook }>();
12
+ const navState = inject(navStateKey);
13
+ const active = computed(() => !!navState!.value[props.navItem.id]!.value);
14
+
15
+ function bookClick() {
16
+ navBookId.value = props.navItem.id;
17
+ insideNavBook.value = true;
18
+ }
19
+ </script>
20
+
21
+ <template>
22
+ <TreeItem
23
+ icon="outline/book"
24
+ :label="navItem.label"
25
+ :level="navItem.level"
26
+ :link="active ? undefined : `/book/${navItem.id}`"
27
+ @click="bookClick"
28
+ :active
29
+ >
30
+ <FNavFlags v-if="navItem.flags" :flags="navItem.flags" />
31
+ </TreeItem>
32
+ </template>
@@ -1,40 +1,40 @@
1
- <script lang="ts" setup>
2
- import type { ContentFlag } from 'erudit-cog/schema';
3
- import { flagsData } from '@app/scripts/flag';
4
-
5
- defineProps<{ flags: Record<ContentFlag, boolean> }>();
6
-
7
- const phrases = Object.values(flagsData).map((data) => data.title);
8
- const phrase = await usePhrases(...phrases);
9
- </script>
10
-
11
- <template>
12
- <div :class="$style.flags">
13
- <MyIcon
14
- v-for="(value, flag) in flags"
15
- :name="flagsData[flag].icon"
16
- :title="phrase[flagsData[flag].title]"
17
- :class="$style.flag"
18
- />
19
- </div>
20
- </template>
21
-
22
- <style lang="scss" module>
23
- .flags {
24
- display: flex;
25
- align-items: center;
26
- gap: var(--gapSmall);
27
- }
28
-
29
- .flag {
30
- cursor: help;
31
- font-size: 16px;
32
- color: var(--textDimmed);
33
- opacity: 0.65;
34
- @include transition(opacity);
35
-
36
- &:hover {
37
- opacity: 1;
38
- }
39
- }
40
- </style>
1
+ <script lang="ts" setup>
2
+ import type { ContentFlag } from 'erudit-cog/schema';
3
+ import { flagsData } from '@app/scripts/flag';
4
+
5
+ defineProps<{ flags: Record<ContentFlag, boolean> }>();
6
+
7
+ const phrases = Object.values(flagsData).map((data) => data.title);
8
+ const phrase = await usePhrases(...phrases);
9
+ </script>
10
+
11
+ <template>
12
+ <div :class="$style.flags">
13
+ <MyIcon
14
+ v-for="(value, flag) in flags"
15
+ :name="flagsData[flag].icon"
16
+ :title="phrase[flagsData[flag].title]"
17
+ :class="$style.flag"
18
+ />
19
+ </div>
20
+ </template>
21
+
22
+ <style lang="scss" module>
23
+ .flags {
24
+ display: flex;
25
+ align-items: center;
26
+ gap: var(--gapSmall);
27
+ }
28
+
29
+ .flag {
30
+ cursor: help;
31
+ font-size: 16px;
32
+ color: var(--textDimmed);
33
+ opacity: 0.65;
34
+ @include transition(opacity);
35
+
36
+ &:hover {
37
+ opacity: 1;
38
+ }
39
+ }
40
+ </style>
@@ -1,60 +1,60 @@
1
- <script lang="ts" setup>
2
- import type { FrontNavFolder } from '@shared/frontNav';
3
- import { navStateKey } from '@app/scripts/aside/major/nav';
4
-
5
- import FNavItem from './FNavItem.vue';
6
- import FNavFlags from './FNavFlags.vue';
7
-
8
- const props = defineProps<{ navItem: FrontNavFolder }>();
9
- const navState = inject(navStateKey);
10
-
11
- const active = ref(false);
12
- const accent = ref(false);
13
-
14
- function onStateUpdate() {
15
- const newState = navState!.value[props.navItem.id]!.value;
16
- active.value = newState === 'active';
17
- accent.value = newState === 'activePart';
18
- }
19
-
20
- onStateUpdate();
21
- watch(navState!.value[props.navItem.id]!, onStateUpdate);
22
-
23
- const visible = computed(() => active.value || accent.value);
24
- </script>
25
-
26
- <template>
27
- <div>
28
- <TreeItem
29
- :icon="`folder${visible ? '-open' : ''}`"
30
- :link="`/group/${navItem.id}`"
31
- :label="navItem.label"
32
- :active
33
- :accent
34
- :level="navItem.level"
35
- >
36
- <FNavFlags v-if="navItem.flags" :flags="navItem.flags" />
37
- </TreeItem>
38
-
39
- <div :class="[$style.groupBody, visible && $style.visible]">
40
- <FNavItem
41
- v-for="childItem of navItem.children"
42
- :navItem="childItem"
43
- />
44
- </div>
45
- </div>
46
- </template>
47
-
48
- <style lang="scss" module>
49
- @use '$/partials/fnav';
50
-
51
- .groupBody {
52
- overflow: hidden;
53
- height: 0;
54
- @include transition(height);
55
-
56
- &.visible {
57
- height: auto;
58
- }
59
- }
60
- </style>
1
+ <script lang="ts" setup>
2
+ import type { FrontNavFolder } from '@shared/frontNav';
3
+ import { navStateKey } from '@app/scripts/aside/major/nav';
4
+
5
+ import FNavItem from './FNavItem.vue';
6
+ import FNavFlags from './FNavFlags.vue';
7
+
8
+ const props = defineProps<{ navItem: FrontNavFolder }>();
9
+ const navState = inject(navStateKey);
10
+
11
+ const active = ref(false);
12
+ const accent = ref(false);
13
+
14
+ function onStateUpdate() {
15
+ const newState = navState!.value[props.navItem.id]!.value;
16
+ active.value = newState === 'active';
17
+ accent.value = newState === 'activePart';
18
+ }
19
+
20
+ onStateUpdate();
21
+ watch(navState!.value[props.navItem.id]!, onStateUpdate);
22
+
23
+ const visible = computed(() => active.value || accent.value);
24
+ </script>
25
+
26
+ <template>
27
+ <div>
28
+ <TreeItem
29
+ :icon="`folder${visible ? '-open' : ''}`"
30
+ :link="`/group/${navItem.id}`"
31
+ :label="navItem.label"
32
+ :active
33
+ :accent
34
+ :level="navItem.level"
35
+ >
36
+ <FNavFlags v-if="navItem.flags" :flags="navItem.flags" />
37
+ </TreeItem>
38
+
39
+ <div :class="[$style.groupBody, visible && $style.visible]">
40
+ <FNavItem
41
+ v-for="childItem of navItem.children"
42
+ :navItem="childItem"
43
+ />
44
+ </div>
45
+ </div>
46
+ </template>
47
+
48
+ <style lang="scss" module>
49
+ @use '$/partials/fnav';
50
+
51
+ .groupBody {
52
+ overflow: hidden;
53
+ height: 0;
54
+ @include transition(height);
55
+
56
+ &.visible {
57
+ height: auto;
58
+ }
59
+ }
60
+ </style>
@@ -1,34 +1,34 @@
1
- <script lang="ts" setup>
2
- import type { FrontNavItem, FrontNavType } from '@shared/frontNav';
3
-
4
- import FNavBook from './FNavBook.vue';
5
- import FNavSeparator from './FNavSeparator.vue';
6
- import FNavFolder from './FNavFolder.vue';
7
- import FNavTopic from './FNavTopic.vue';
8
-
9
- defineProps<{ navItem: FrontNavItem }>();
10
-
11
- const navComponent: Record<FrontNavType, Component> = {
12
- book: FNavBook,
13
- separator: FNavSeparator,
14
- folder: FNavFolder,
15
- topic: FNavTopic,
16
- };
17
- </script>
18
-
19
- <template>
20
- <component
21
- :is="navComponent[navItem.type]"
22
- :navItem
23
- :class="[
24
- $style.frontNavItem,
25
- $style[
26
- `frontNav${navItem.type[0]!.toUpperCase() + navItem.type.substring(1)}`
27
- ],
28
- ]"
29
- />
30
- </template>
31
-
32
- <style lang="scss" module>
33
- @use '$/partials/fnav';
34
- </style>
1
+ <script lang="ts" setup>
2
+ import type { FrontNavItem, FrontNavType } from '@shared/frontNav';
3
+
4
+ import FNavBook from './FNavBook.vue';
5
+ import FNavSeparator from './FNavSeparator.vue';
6
+ import FNavFolder from './FNavFolder.vue';
7
+ import FNavTopic from './FNavTopic.vue';
8
+
9
+ defineProps<{ navItem: FrontNavItem }>();
10
+
11
+ const navComponent: Record<FrontNavType, Component> = {
12
+ book: FNavBook,
13
+ separator: FNavSeparator,
14
+ folder: FNavFolder,
15
+ topic: FNavTopic,
16
+ };
17
+ </script>
18
+
19
+ <template>
20
+ <component
21
+ :is="navComponent[navItem.type]"
22
+ :navItem
23
+ :class="[
24
+ $style.frontNavItem,
25
+ $style[
26
+ `frontNav${navItem.type[0]!.toUpperCase() + navItem.type.substring(1)}`
27
+ ],
28
+ ]"
29
+ />
30
+ </template>
31
+
32
+ <style lang="scss" module>
33
+ @use '$/partials/fnav';
34
+ </style>