erudit 3.0.0-dev.4 → 3.0.0-dev.6

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 +5 -5
  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 +99 -112
  147. package/package.json +10 -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 +214 -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 +116 -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,63 +1,70 @@
1
- <script lang="ts" setup>
2
- import { Bitran, type BitranContent } from '@bitran-js/renderer-vue';
3
-
4
- import type { BitranContext } from '@shared/bitran/context';
5
-
6
- import RenderWrapper from './RenderWrapper.vue';
7
-
8
- const props = defineProps<{
9
- content: BitranContent;
10
- context: BitranContext;
11
- }>();
12
-
13
- const bitranTranspiler = await useBitranTranspiler();
14
- const bitranRenderers = await useBitranRenderers();
15
-
16
- const formatText = useFormatText();
17
-
18
- // onMounted(() => {
19
- // watch(urlElement, () => {
20
- // //console.log('Highlighting product:', urlElement.value);
21
- // }, { immediate: true });
22
- // });
23
- </script>
24
-
25
- <template>
26
- <Bitran
27
- :class="$style.eruditBitranContainer"
28
- :transpiler="bitranTranspiler"
29
- :renderers="bitranRenderers"
30
- :content
31
- :editMode="false"
32
- :formatText
33
- :RenderWrapper
34
- />
35
- </template>
36
-
37
- <style lang="scss" module>
38
- @use '@bitran-js/renderer-vue/scss/def' as bitranDef;
39
-
40
- .eruditBitranContainer {
41
- padding: var(--_pMainY) var(--_pMainX);
42
- padding-left: calc(var(--_pMainX) - #{bitranDef.$asideWidth});
43
-
44
- // Setting up Bitran
45
-
46
- --bitran_gap: var(--gap);
47
- --bitran_gapSmall: var(--gapSmall);
48
- --bitran_gapBig: var(--gapBig);
49
- --bitran_gapBlocks: var(--gapBig);
50
-
51
- --bitran_xPadding: var(--_pMainX);
52
- --bitran_transitionSpeed: var(--transitionSpeed);
53
- --bitran_transitionFunction: var(--transitionFunction);
54
-
55
- --bitran_fontMain: 'Noto Sans', sans-serif;
56
- --bitran_fontAlt: 'Noto Serif', serif;
57
-
58
- --bitran_text: var(--text);
59
- --bitran_textMuted: var(--textMuted);
60
- --bitran_textDimmed: var(--textDimmed);
61
- --bitran_textDisabled: var(--textDisabled);
62
- }
63
- </style>
1
+ <script lang="ts" setup>
2
+ import { Bitran, type BitranContent } from '@bitran-js/renderer-vue';
3
+
4
+ import type { BitranContext } from '@shared/bitran/context';
5
+
6
+ import RenderWrapper from './RenderWrapper.vue';
7
+
8
+ const props = defineProps<{
9
+ content: BitranContent;
10
+ context: BitranContext;
11
+ }>();
12
+
13
+ const bitranTranspiler = await useBitranTranspiler();
14
+ const bitranRenderers = await useBitranRenderers();
15
+
16
+ const formatText = useFormatText();
17
+
18
+ // onMounted(() => {
19
+ // watch(urlElement, () => {
20
+ // //console.log('Highlighting product:', urlElement.value);
21
+ // }, { immediate: true });
22
+ // });
23
+
24
+ const isDev = import.meta.dev;
25
+ const isServer = import.meta.server;
26
+ </script>
27
+
28
+ <template>
29
+ <Bitran
30
+ :class="$style.eruditBitranContainer"
31
+ :transpiler="bitranTranspiler"
32
+ :renderers="bitranRenderers"
33
+ :content
34
+ :editMode="false"
35
+ :formatText
36
+ :RenderWrapper
37
+ :isDev
38
+ :isServer
39
+ />
40
+ </template>
41
+
42
+ <style lang="scss" module>
43
+ @use '@bitran-js/renderer-vue/scss/def' as bitranDef;
44
+
45
+ .eruditBitranContainer {
46
+ padding: var(--_pMainY) var(--_pMainX);
47
+ padding-left: calc(var(--_pMainX) - #{bitranDef.$asideWidth});
48
+
49
+ // Setting up Bitran
50
+
51
+ --bitran_gap: var(--gap);
52
+ --bitran_gapSmall: var(--gapSmall);
53
+ --bitran_gapBig: var(--gapBig);
54
+ --bitran_gapBlocks: var(--gapBig);
55
+
56
+ --bitran_xPadding: var(--_pMainX);
57
+ --bitran_transitionSpeed: var(--transitionSpeed);
58
+ --bitran_transitionFunction: var(--transitionFunction);
59
+
60
+ --bitran_fontMain: 'Noto Sans', sans-serif;
61
+ --bitran_fontAlt: 'Noto Serif', serif;
62
+
63
+ --bitran_text: var(--text);
64
+ --bitran_textMuted: var(--textMuted);
65
+ --bitran_textDimmed: var(--textDimmed);
66
+ --bitran_textDisabled: var(--textDisabled);
67
+
68
+ --bitran_colorBrand: var(--brand);
69
+ }
70
+ </style>
@@ -1,10 +1,10 @@
1
- <script lang="ts" setup>
2
- defineProps<{ mode: 'hybrid' | 'client' }>();
3
- </script>
4
-
5
- <template>
6
- <slot v-if="mode !== 'client'"></slot>
7
- <ClientOnly v-else>
8
- <slot></slot>
9
- </ClientOnly>
10
- </template>
1
+ <script lang="ts" setup>
2
+ defineProps<{ mode: 'hybrid' | 'client' }>();
3
+ </script>
4
+
5
+ <template>
6
+ <slot v-if="mode !== 'client'"></slot>
7
+ <ClientOnly v-else>
8
+ <slot></slot>
9
+ </ClientOnly>
10
+ </template>
@@ -1,43 +1,43 @@
1
- <script lang="ts" setup>
2
- const props = defineProps<{ contributorId: string; avatar?: string }>();
3
- const baseUrlPath = useBaseUrlPath();
4
-
5
- const hasAvatar = computed(() => !!props.avatar);
6
- </script>
7
-
8
- <template>
9
- <div
10
- :class="[$style.contributorAvatar, !hasAvatar && $style.noAvatar]"
11
- :style="{ '--_avatarBlendColor': stringColor(props.contributorId) }"
12
- >
13
- <img
14
- v-if="hasAvatar"
15
- :src="baseUrlPath(contributorAsset(avatar!))"
16
- loading="lazy"
17
- />
18
- </div>
19
- </template>
20
-
21
- <style lang="scss" module>
22
- .contributorAvatar {
23
- $avatarSize: 40px;
24
- --_avatarBlendColor: var(--brand);
25
-
26
- position: relative;
27
- width: #{$avatarSize};
28
- height: #{$avatarSize};
29
- border-radius: 50%;
30
- overflow: hidden;
31
- background: var(--border);
32
-
33
- &.noAvatar {
34
- background-image: url('/_erudit-asset/user.svg');
35
- background-color: var(--_avatarBlendColor);
36
- background-blend-mode: hard-light;
37
- }
38
-
39
- > img {
40
- display: block;
41
- }
42
- }
43
- </style>
1
+ <script lang="ts" setup>
2
+ const props = defineProps<{ contributorId: string; avatar?: string }>();
3
+ const baseUrlPath = useBaseUrlPath();
4
+
5
+ const hasAvatar = computed(() => !!props.avatar);
6
+ </script>
7
+
8
+ <template>
9
+ <div
10
+ :class="[$style.contributorAvatar, !hasAvatar && $style.noAvatar]"
11
+ :style="{ '--_avatarBlendColor': stringColor(props.contributorId) }"
12
+ >
13
+ <img
14
+ v-if="hasAvatar"
15
+ :src="baseUrlPath(contributorAsset(avatar!))"
16
+ loading="lazy"
17
+ />
18
+ </div>
19
+ </template>
20
+
21
+ <style lang="scss" module>
22
+ .contributorAvatar {
23
+ $avatarSize: 40px;
24
+ --_avatarBlendColor: var(--brand);
25
+
26
+ position: relative;
27
+ width: #{$avatarSize};
28
+ height: #{$avatarSize};
29
+ border-radius: 50%;
30
+ overflow: hidden;
31
+ background: var(--border);
32
+
33
+ &.noAvatar {
34
+ background-image: url('/_erudit-asset/user.svg');
35
+ background-color: var(--_avatarBlendColor);
36
+ background-blend-mode: hard-light;
37
+ }
38
+
39
+ > img {
40
+ display: block;
41
+ }
42
+ }
43
+ </style>
@@ -1,35 +1,35 @@
1
- <script lang="ts" setup>
2
- import { type ContentContributor } from '@shared/contributor';
3
- import { createContributorLink } from '@shared/link';
4
-
5
- defineProps<ContentContributor>();
6
-
7
- const Link = defineNuxtLink({ prefetch: false });
8
- </script>
9
-
10
- <template>
11
- <Link
12
- :class="$style.contributor"
13
- :to="createContributorLink(contributorId)"
14
- >
15
- <ContributorAvatar :contributorId :avatar />
16
- <span>{{ displayName || contributorId }}</span>
17
- </Link>
18
- </template>
19
-
20
- <style lang="scss" module>
21
- .contributor {
22
- display: flex;
23
- align-items: center;
24
- gap: var(--gap);
25
- padding: var(--gap);
26
- color: var(--text);
27
- text-decoration: none;
28
-
29
- @include transition(background);
30
-
31
- &:hover {
32
- background: var(--bgAccent);
33
- }
34
- }
35
- </style>
1
+ <script lang="ts" setup>
2
+ import { type ContentContributor } from '@shared/contributor';
3
+ import { createContributorLink } from '@shared/link';
4
+
5
+ defineProps<ContentContributor>();
6
+
7
+ const Link = defineNuxtLink({ prefetch: false });
8
+ </script>
9
+
10
+ <template>
11
+ <Link
12
+ :class="$style.contributor"
13
+ :to="createContributorLink(contributorId)"
14
+ >
15
+ <ContributorAvatar :contributorId :avatar />
16
+ <span>{{ displayName || contributorId }}</span>
17
+ </Link>
18
+ </template>
19
+
20
+ <style lang="scss" module>
21
+ .contributor {
22
+ display: flex;
23
+ align-items: center;
24
+ gap: var(--gap);
25
+ padding: var(--gap);
26
+ color: var(--text);
27
+ text-decoration: none;
28
+
29
+ @include transition(background);
30
+
31
+ &:hover {
32
+ background: var(--bgAccent);
33
+ }
34
+ }
35
+ </style>
@@ -1,79 +1,79 @@
1
- <script lang="ts" setup>
2
- import type { TopicPart } from 'erudit-cog/schema';
3
- import { NO_ALIASES } from '@erudit-js/bitran-elements/aliases/shared';
4
-
5
- import eruditConfig from '#erudit/config';
6
-
7
- import { type ContentTopicData } from '@erudit/shared/content/data/type/topic';
8
- import { topicLocation } from '@app/scripts/aside/minor/topic';
9
-
10
- import ContentDecoration from '../utils/ContentDecoration.vue';
11
- import ContentTitle from '../utils/ContentTitle.vue';
12
- import ContentDescription from '../utils/ContentDescription.vue';
13
- import TopicPartSwitch from './TopicPartSwitch.vue';
14
- import Breadcrumb from '../utils/Breadcrumb.vue';
15
- import ContentPopovers from '../utils/ContentPopovers.vue';
16
- import ContentReferences from '../utils/ContentReferences.vue';
17
- import ContentSection from '../utils/ContentSection.vue';
18
- import { TOPIC_PART_ICON } from '@erudit/shared/icons';
19
-
20
- const location = useBitranLocation();
21
- const topicPart = computed(() => location.value?.type as TopicPart);
22
-
23
- const topicData = await useContentData<ContentTopicData>();
24
- await useContentPage(topicData);
25
-
26
- const phrase = await usePhrases('article', 'summary', 'practice');
27
-
28
- const content = await useBitranContent(location);
29
-
30
- onMounted(() => {
31
- watchEffect(() => {
32
- // Telling live toc that content is mounted
33
- topicLocation.value = location.value;
34
- });
35
- });
36
- </script>
37
-
38
- <template>
39
- <ContentDecoration
40
- v-if="topicData.generic.decoration"
41
- :decoration="topicData.generic.decoration"
42
- />
43
-
44
- <Breadcrumb
45
- v-if="topicData.generic.context?.length > 1"
46
- :context="topicData.generic.context"
47
- />
48
-
49
- <ContentTitle
50
- :title="
51
- topicData.generic?.title ||
52
- topicData.generic.contentId.split('/').pop()!
53
- "
54
- :icon="TOPIC_PART_ICON[location!.type as TopicPart]"
55
- :hint="phrase[location!.type as TopicPart]"
56
- />
57
-
58
- <ContentDescription
59
- v-if="topicData.generic?.description"
60
- :description="topicData.generic?.description"
61
- />
62
-
63
- <ContentPopovers :generic="topicData.generic" />
64
-
65
- <TopicPartSwitch
66
- :partLinks="topicData.topicPartLinks"
67
- :active="topicPart"
68
- />
69
-
70
- <div style="clear: both"></div>
71
-
72
- <BitranContent :content :context="{ location, aliases: NO_ALIASES() }" />
73
-
74
- <ContentSection v-if="topicData.generic.references">
75
- <ContentReferences :references="topicData.generic.references" />
76
- </ContentSection>
77
-
78
- <AdsBottomBanner v-if="eruditConfig.ads?.bottomBlockId" />
79
- </template>
1
+ <script lang="ts" setup>
2
+ import type { TopicPart } from '@erudit-js/cog/schema';
3
+ import { NO_ALIASES } from '@erudit-js/bitran-elements/aliases/shared';
4
+
5
+ import eruditConfig from '#erudit/config';
6
+
7
+ import { type ContentTopicData } from '@erudit/shared/content/data/type/topic';
8
+ import { topicLocation } from '@app/scripts/aside/minor/topic';
9
+
10
+ import ContentDecoration from '../utils/ContentDecoration.vue';
11
+ import ContentTitle from '../utils/ContentTitle.vue';
12
+ import ContentDescription from '../utils/ContentDescription.vue';
13
+ import TopicPartSwitch from './TopicPartSwitch.vue';
14
+ import Breadcrumb from '../utils/Breadcrumb.vue';
15
+ import ContentPopovers from '../utils/ContentPopovers.vue';
16
+ import ContentReferences from '../utils/ContentReferences.vue';
17
+ import ContentSection from '../utils/ContentSection.vue';
18
+ import { TOPIC_PART_ICON } from '@erudit/shared/icons';
19
+
20
+ const location = useBitranLocation();
21
+ const topicPart = computed(() => location.value?.type as TopicPart);
22
+
23
+ const topicData = await useContentData<ContentTopicData>();
24
+ await useContentPage(topicData);
25
+
26
+ const phrase = await usePhrases('article', 'summary', 'practice');
27
+
28
+ const content = await useBitranContent(location);
29
+
30
+ onMounted(() => {
31
+ watchEffect(() => {
32
+ // Telling live toc that content is mounted
33
+ topicLocation.value = location.value;
34
+ });
35
+ });
36
+ </script>
37
+
38
+ <template>
39
+ <ContentDecoration
40
+ v-if="topicData.generic.decoration"
41
+ :decoration="topicData.generic.decoration"
42
+ />
43
+
44
+ <Breadcrumb
45
+ v-if="topicData.generic.context?.length > 1"
46
+ :context="topicData.generic.context"
47
+ />
48
+
49
+ <ContentTitle
50
+ :title="
51
+ topicData.generic?.title ||
52
+ topicData.generic.contentId.split('/').pop()!
53
+ "
54
+ :icon="TOPIC_PART_ICON[location!.type as TopicPart]"
55
+ :hint="phrase[location!.type as TopicPart]"
56
+ />
57
+
58
+ <ContentDescription
59
+ v-if="topicData.generic?.description"
60
+ :description="topicData.generic?.description"
61
+ />
62
+
63
+ <ContentPopovers :generic="topicData.generic" />
64
+
65
+ <TopicPartSwitch
66
+ :partLinks="topicData.topicPartLinks"
67
+ :active="topicPart"
68
+ />
69
+
70
+ <div style="clear: both"></div>
71
+
72
+ <BitranContent :content :context="{ location, aliases: NO_ALIASES() }" />
73
+
74
+ <ContentSection v-if="topicData.generic.references">
75
+ <ContentReferences :references="topicData.generic.references" />
76
+ </ContentSection>
77
+
78
+ <AdsBottomBanner v-if="eruditConfig.ads?.bottomBlockId" />
79
+ </template>