erudit 3.0.0-dev.17 → 3.0.0-dev.19

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 (250) hide show
  1. package/app/app.vue +193 -191
  2. package/app/assets/icons/graduation.svg +3 -0
  3. package/app/components/Loading.vue +23 -23
  4. package/app/components/SiteAside.vue +393 -393
  5. package/app/components/SiteMain.vue +32 -32
  6. package/app/components/aside/AsideListItem.vue +74 -74
  7. package/app/components/aside/AsideMajor.vue +56 -56
  8. package/app/components/aside/AsideMinor.vue +97 -73
  9. package/app/components/aside/major/PaneContentScroll.vue +23 -23
  10. package/app/components/aside/major/PaneSwitch.vue +54 -54
  11. package/app/components/aside/major/PaneSwitchButton.vue +63 -63
  12. package/app/components/aside/major/SiteInfo.vue +85 -85
  13. package/app/components/aside/major/panes/Language.vue +79 -79
  14. package/app/components/aside/major/panes/Pages.vue +31 -34
  15. package/app/components/aside/major/panes/Search.vue +11 -11
  16. package/app/components/aside/major/panes/nav/Nav.vue +92 -92
  17. package/app/components/aside/major/panes/nav/NavBook.vue +95 -95
  18. package/app/components/aside/major/panes/nav/NavBookLoading.vue +24 -24
  19. package/app/components/aside/major/panes/nav/NavGlobal.vue +16 -16
  20. package/app/components/aside/major/panes/nav/fnav/FNav.vue +105 -105
  21. package/app/components/aside/major/panes/nav/fnav/FNavBook.vue +32 -32
  22. package/app/components/aside/major/panes/nav/fnav/FNavFlags.vue +40 -40
  23. package/app/components/aside/major/panes/nav/fnav/FNavFolder.vue +60 -60
  24. package/app/components/aside/major/panes/nav/fnav/FNavItem.vue +34 -34
  25. package/app/components/aside/major/panes/nav/fnav/FNavSeparator.vue +80 -80
  26. package/app/components/aside/major/panes/nav/fnav/FNavTopic.vue +24 -24
  27. package/app/components/aside/major/panes/other/ItemContent.vue +29 -29
  28. package/app/components/aside/major/panes/other/ItemGenerator.vue +13 -13
  29. package/app/components/aside/major/panes/other/ItemTheme.vue +54 -54
  30. package/app/components/aside/major/panes/other/Other.vue +16 -16
  31. package/app/components/aside/minor/{Contribute.vue → AsideMinorContribute.vue} +175 -145
  32. package/app/components/aside/minor/AsideMinorNews.vue +11 -11
  33. package/app/components/aside/minor/AsideMinorPane.vue +15 -15
  34. package/app/components/aside/minor/AsideMinorTopLink.vue +67 -67
  35. package/app/components/aside/minor/content/AsideMinorContent.vue +89 -92
  36. package/app/components/aside/minor/contributor/AsideMinorContributor.vue +78 -0
  37. package/app/components/aside/minor/contributor/BookContribution.vue +64 -0
  38. package/app/components/aside/minor/topic/AsideMinorTopic.vue +29 -32
  39. package/app/components/aside/minor/topic/TopicContributors.vue +177 -177
  40. package/app/components/aside/minor/topic/TopicNav.vue +49 -49
  41. package/app/components/aside/minor/topic/TopicToc.vue +213 -214
  42. package/app/components/aside/minor/topic/TopicTocItem.vue +32 -32
  43. package/app/components/aside/utils/AsideOverlayPane.vue +40 -40
  44. package/app/components/bitran/BitranContent.vue +90 -91
  45. package/app/components/bitran/RenderWrapper.vue +10 -10
  46. package/app/components/contributor/ContributorAvatar.vue +45 -45
  47. package/app/components/contributor/ContributorListItem.vue +35 -35
  48. package/app/components/main/MainBitranContent.vue +41 -0
  49. package/app/components/main/{utils/Breadcrumb.vue → MainBreadcrumb.vue} +67 -74
  50. package/app/components/main/MainDescription.vue +24 -0
  51. package/app/components/main/{utils/ContentTitle.vue → MainTitle.vue} +72 -63
  52. package/app/components/main/content/ContentBreadcrumb.vue +28 -0
  53. package/app/components/main/{utils → content}/ContentDecoration.vue +29 -29
  54. package/app/components/main/{utils → content}/ContentPopover.vue +188 -188
  55. package/app/components/main/{utils → content}/ContentPopovers.vue +111 -111
  56. package/app/components/main/{utils → content}/ContentReferences.vue +70 -70
  57. package/app/components/main/{utils → content}/ContentSection.vue +45 -45
  58. package/app/components/main/{utils → content}/reference/ReferenceGroup.vue +38 -38
  59. package/app/components/main/{utils → content}/reference/ReferenceItem.vue +70 -70
  60. package/app/components/main/{utils → content}/reference/ReferenceSource.vue +120 -120
  61. package/app/components/main/topic/MainTopic.vue +83 -88
  62. package/app/components/main/topic/TopicPartSwitch.vue +124 -118
  63. package/app/components/preview/Preview.vue +186 -186
  64. package/app/components/preview/PreviewDisplay.vue +139 -139
  65. package/app/components/preview/PreviewFooterAction.vue +73 -73
  66. package/app/components/preview/PreviewLoading.vue +14 -14
  67. package/app/components/preview/PreviewScreen.vue +141 -141
  68. package/app/components/preview/display/Alert.vue +50 -50
  69. package/app/components/preview/display/Custom.vue +18 -18
  70. package/app/components/preview/display/GenericLink.vue +48 -48
  71. package/app/components/preview/display/PageLink.vue +22 -22
  72. package/app/components/preview/display/Unique.vue +46 -55
  73. package/app/components/transition/Fade.vue +19 -19
  74. package/app/components/tree/TreeContainer.vue +11 -11
  75. package/app/components/tree/TreeItem.vue +89 -89
  76. package/app/composables/adsAllowed.ts +11 -0
  77. package/app/composables/bitran.ts +108 -108
  78. package/app/composables/bitranLocation.ts +7 -7
  79. package/app/composables/contentData.ts +38 -38
  80. package/app/composables/contentPage.ts +168 -158
  81. package/app/composables/contentRoute.ts +45 -45
  82. package/app/composables/darkMagic.ts +24 -24
  83. package/app/composables/externalApi.ts +69 -69
  84. package/app/composables/favicon.ts +8 -8
  85. package/app/composables/formatText.ts +99 -99
  86. package/app/composables/majorPane.ts +61 -60
  87. package/app/composables/phrases.ts +77 -65
  88. package/app/composables/theme.ts +29 -29
  89. package/app/composables/url.ts +33 -33
  90. package/app/pages/_test/preview.vue +110 -110
  91. package/app/pages/article/[...articleId].vue +3 -3
  92. package/app/pages/book/[...bookId].vue +42 -47
  93. package/app/pages/contributor/[contributorId].vue +225 -0
  94. package/app/pages/contributors.vue +183 -0
  95. package/app/pages/group/[...groupId].vue +58 -66
  96. package/app/pages/index.vue +32 -32
  97. package/app/pages/practice/[...practice].vue +3 -3
  98. package/app/pages/summary/[...summaryId].vue +3 -3
  99. package/app/plugins/analytics.ts +8 -0
  100. package/app/plugins/prerender.server.ts +22 -22
  101. package/app/scripts/_immediate.js +9 -9
  102. package/app/scripts/aside/index.ts +59 -59
  103. package/app/scripts/aside/major/nav.ts +26 -26
  104. package/app/scripts/aside/minor/state.ts +37 -37
  105. package/app/scripts/aside/minor/topic.ts +3 -3
  106. package/app/scripts/flag.ts +28 -28
  107. package/app/scripts/og.ts +27 -27
  108. package/app/scripts/preview/build.ts +76 -76
  109. package/app/scripts/preview/data/alert.ts +19 -19
  110. package/app/scripts/preview/data/custom.ts +8 -8
  111. package/app/scripts/preview/data/genericLink.ts +24 -24
  112. package/app/scripts/preview/data/pageLink.ts +23 -23
  113. package/app/scripts/preview/data/unique.ts +69 -72
  114. package/app/scripts/preview/data.ts +24 -24
  115. package/app/scripts/preview/display.ts +37 -37
  116. package/app/scripts/preview/footer.ts +9 -9
  117. package/app/scripts/preview/request.ts +51 -51
  118. package/app/scripts/preview/state.ts +63 -63
  119. package/app/styles/_immediate.css +7 -7
  120. package/app/styles/_util.scss +43 -43
  121. package/app/styles/_utils.scss +44 -44
  122. package/app/styles/app.scss +91 -91
  123. package/app/styles/def/_bp.scss +27 -27
  124. package/app/styles/def/_size.scss +7 -7
  125. package/app/styles/def/_z.scss +5 -5
  126. package/app/styles/normalize.scss +49 -49
  127. package/app/styles/partials/_darkMagic.scss +5 -5
  128. package/app/styles/partials/_fnav.scss +15 -15
  129. package/app/styles/partials/_preview.scss +5 -5
  130. package/bin/erudit.mjs +2 -2
  131. package/const.ts +4 -4
  132. package/globalPath.ts +21 -21
  133. package/globals/bitran.ts +1 -1
  134. package/globals/content.ts +27 -27
  135. package/globals/contributor.ts +5 -5
  136. package/globals/erudit.ts +5 -5
  137. package/globals/register.ts +18 -18
  138. package/languages/en.ts +103 -94
  139. package/languages/ru.ts +107 -98
  140. package/module/bitran.ts +66 -66
  141. package/module/config.ts +35 -35
  142. package/module/imports.ts +67 -67
  143. package/module/index.ts +47 -47
  144. package/module/logger.ts +10 -10
  145. package/module/paths.ts +22 -22
  146. package/module/restart.ts +61 -61
  147. package/nuxt.config.ts +131 -131
  148. package/package.json +5 -5
  149. package/server/api/aside/major/nav/bookIds.ts +5 -5
  150. package/server/api/aside/major/nav/bookNav/[...bookId].ts +17 -20
  151. package/server/api/aside/major/nav/global.ts +7 -7
  152. package/server/api/aside/minor/book/[...bookId].ts +18 -0
  153. package/server/api/aside/minor/contributor/[contributorId].ts +18 -0
  154. package/server/api/aside/minor/group/[...groupId].ts +18 -0
  155. package/server/api/aside/minor/news.ts +7 -7
  156. package/server/api/aside/minor/topic.ts +36 -0
  157. package/server/api/bitran/content/[...location].ts +13 -10
  158. package/server/api/bitran/toc/[...location].ts +9 -9
  159. package/server/api/content/data.ts +75 -75
  160. package/server/api/contributor/count.ts +6 -6
  161. package/server/api/contributor/list.ts +44 -0
  162. package/server/api/contributor/page/[contributorId].ts +14 -0
  163. package/server/api/fake/content.ts +11 -11
  164. package/server/api/fake/shared/languages.ts +12 -12
  165. package/server/api/language/functions.ts +12 -12
  166. package/server/api/language/phrase/[phraseId].ts +19 -19
  167. package/server/api/language/phraseIds.ts +8 -8
  168. package/server/api/prerender.ts +19 -120
  169. package/server/api/preview/page/[...parts].ts +78 -78
  170. package/server/api/preview/unique/[...location].ts +48 -61
  171. package/server/plugin/bitran/content.ts +252 -190
  172. package/server/plugin/bitran/elements/include.ts +229 -229
  173. package/server/plugin/bitran/location.ts +43 -39
  174. package/server/plugin/bitran/toc.ts +94 -94
  175. package/server/plugin/bitran/transpiler.ts +18 -18
  176. package/server/plugin/build/close.ts +12 -12
  177. package/server/plugin/build/jobs/content/builderArgs.ts +8 -8
  178. package/server/plugin/build/jobs/content/generic.ts +191 -191
  179. package/server/plugin/build/jobs/content/parse.ts +113 -113
  180. package/server/plugin/build/jobs/content/path.ts +6 -6
  181. package/server/plugin/build/jobs/content/type/book.ts +9 -9
  182. package/server/plugin/build/jobs/content/type/group.ts +37 -37
  183. package/server/plugin/build/jobs/content/type/topic.ts +36 -36
  184. package/server/plugin/build/jobs/contributors.ts +69 -66
  185. package/server/plugin/build/jobs/language.ts +36 -36
  186. package/server/plugin/build/jobs/nav.ts +345 -345
  187. package/server/plugin/build/process.ts +32 -32
  188. package/server/plugin/build/rebuild.ts +66 -66
  189. package/server/plugin/build/setup.ts +19 -19
  190. package/server/plugin/content/context.ts +119 -119
  191. package/server/plugin/db/entities/Book.ts +7 -7
  192. package/server/plugin/db/entities/Content.ts +45 -45
  193. package/server/plugin/db/entities/Contribution.ts +10 -10
  194. package/server/plugin/db/entities/Contributor.ts +25 -16
  195. package/server/plugin/db/entities/File.ts +10 -10
  196. package/server/plugin/db/entities/Group.ts +14 -14
  197. package/server/plugin/db/entities/Hash.ts +15 -15
  198. package/server/plugin/db/entities/Topic.ts +20 -20
  199. package/server/plugin/db/entities/Unique.ts +21 -21
  200. package/server/plugin/db/reset.ts +12 -12
  201. package/server/plugin/db/setup.ts +49 -49
  202. package/server/plugin/global.ts +16 -16
  203. package/server/plugin/importer.ts +16 -16
  204. package/server/plugin/index.ts +9 -9
  205. package/server/plugin/logger.ts +23 -23
  206. package/server/plugin/nav/node.ts +27 -27
  207. package/server/plugin/nav/utils.ts +179 -175
  208. package/server/plugin/repository/asideMinor.ts +51 -0
  209. package/server/plugin/repository/book.ts +39 -21
  210. package/server/plugin/repository/content.ts +240 -240
  211. package/server/plugin/repository/contentId.ts +40 -40
  212. package/server/plugin/repository/contributor.ts +98 -8
  213. package/server/plugin/repository/file.ts +10 -10
  214. package/server/plugin/repository/frontNav.ts +145 -145
  215. package/server/plugin/repository/topic.ts +35 -35
  216. package/server/tsconfig.json +9 -9
  217. package/shared/aside/minor.ts +55 -51
  218. package/shared/asset.ts +22 -22
  219. package/shared/bitran/content.ts +9 -0
  220. package/shared/bitran/contentId.ts +56 -56
  221. package/shared/bitran/toc.ts +8 -8
  222. package/shared/breadcrumb.ts +7 -0
  223. package/shared/content/bookId.ts +12 -12
  224. package/shared/content/context.ts +9 -9
  225. package/shared/content/data/base.ts +32 -32
  226. package/shared/content/data/index.ts +5 -5
  227. package/shared/content/data/type/book.ts +5 -5
  228. package/shared/content/data/type/group.ts +6 -6
  229. package/shared/content/data/type/topic.ts +11 -11
  230. package/shared/content/previousNext.ts +9 -9
  231. package/shared/contributor.ts +33 -5
  232. package/shared/frontNav.ts +41 -41
  233. package/shared/icons.ts +38 -38
  234. package/shared/image.ts +5 -5
  235. package/shared/link.ts +28 -28
  236. package/shared/popover.ts +8 -8
  237. package/shared/types/language.ts +79 -74
  238. package/shared/utils/objectsEqual.ts +4 -4
  239. package/shared/utils/stringColor.ts +9 -9
  240. package/test/contentId.test.ts +91 -91
  241. package/tsconfig.json +8 -8
  242. package/utils/contentPath.ts +67 -67
  243. package/utils/slash.ts +11 -11
  244. package/utils/stress.ts +9 -9
  245. package/app/components/aside/minor/AsideMinorContributor.vue +0 -5
  246. package/app/components/main/utils/ContentDescription.vue +0 -19
  247. package/app/composables/bitranContent.ts +0 -92
  248. package/app/pages/members.vue +0 -6
  249. package/server/api/aside/minor/path.ts +0 -82
  250. package/shared/bitran/stringContent.ts +0 -6
@@ -1,45 +1,45 @@
1
- import type { ContentType, TopicPart } from '@erudit-js/cog/schema';
2
-
3
- interface ContentRouteBase {
4
- type: ContentType;
5
- contentId: string;
6
- }
7
-
8
- interface TopicRoute extends ContentRouteBase {
9
- type: 'topic';
10
- topicPart: TopicPart;
11
- }
12
-
13
- interface ContentRoute extends ContentRouteBase {
14
- type: Exclude<ContentType, 'topic'>;
15
- }
16
-
17
- export function useContentRoute(): ComputedRef<
18
- TopicRoute | ContentRoute | undefined
19
- > {
20
- const route = useRoute();
21
- return computed(() => {
22
- const match = route.path.match(/\/(.+?)\/(.+)/);
23
-
24
- if (!match || !match[1] || !match[2]) return undefined;
25
-
26
- switch (match[1]) {
27
- case 'article':
28
- case 'summary':
29
- case 'practice':
30
- return <TopicRoute>{
31
- type: 'topic',
32
- contentId: match[2],
33
- topicPart: match[1],
34
- };
35
- case 'group':
36
- case 'book':
37
- return <ContentRoute>{
38
- type: match[1],
39
- contentId: match[2],
40
- };
41
- }
42
-
43
- return undefined;
44
- });
45
- }
1
+ import type { ContentType, TopicPart } from '@erudit-js/cog/schema';
2
+
3
+ interface ContentRouteBase {
4
+ type: ContentType;
5
+ contentId: string;
6
+ }
7
+
8
+ interface TopicRoute extends ContentRouteBase {
9
+ type: 'topic';
10
+ topicPart: TopicPart;
11
+ }
12
+
13
+ interface ContentRoute extends ContentRouteBase {
14
+ type: Exclude<ContentType, 'topic'>;
15
+ }
16
+
17
+ export function useContentRoute(): ComputedRef<
18
+ TopicRoute | ContentRoute | undefined
19
+ > {
20
+ const route = useRoute();
21
+ return computed(() => {
22
+ const match = route.path.match(/\/(.+?)\/(.+)/);
23
+
24
+ if (!match || !match[1] || !match[2]) return undefined;
25
+
26
+ switch (match[1]) {
27
+ case 'article':
28
+ case 'summary':
29
+ case 'practice':
30
+ return <TopicRoute>{
31
+ type: 'topic',
32
+ contentId: match[2],
33
+ topicPart: match[1],
34
+ };
35
+ case 'group':
36
+ case 'book':
37
+ return <ContentRoute>{
38
+ type: match[1],
39
+ contentId: match[2],
40
+ };
41
+ }
42
+
43
+ return undefined;
44
+ });
45
+ }
@@ -1,24 +1,24 @@
1
- declare let Ya: any;
2
-
3
- const getElementId = (bannerId: string) => {
4
- return `DarkMagic_${bannerId}`;
5
- };
6
-
7
- const registerBanner = (bannerId: string) => {
8
- const { binaryTheme } = useTheme();
9
-
10
- (window['yaContextCb'] ||= []).push(() => {
11
- Ya.Context.AdvManager.render({
12
- renderTo: getElementId(bannerId),
13
- blockId: bannerId,
14
- darkTheme: binaryTheme.value === 'dark',
15
- });
16
- });
17
- };
18
-
19
- export function useDarkMagic() {
20
- return {
21
- getElementId,
22
- registerBanner,
23
- };
24
- }
1
+ declare let Ya: any;
2
+
3
+ const getElementId = (bannerId: string) => {
4
+ return `DarkMagic_${bannerId}`;
5
+ };
6
+
7
+ const registerBanner = (bannerId: string) => {
8
+ const { binaryTheme } = useTheme();
9
+
10
+ (window['yaContextCb'] ||= []).push(() => {
11
+ Ya.Context.AdvManager.render({
12
+ renderTo: getElementId(bannerId),
13
+ blockId: bannerId,
14
+ darkTheme: binaryTheme.value === 'dark',
15
+ });
16
+ });
17
+ };
18
+
19
+ export function useDarkMagic() {
20
+ return {
21
+ getElementId,
22
+ registerBanner,
23
+ };
24
+ }
@@ -1,69 +1,69 @@
1
- import type { EruditConfigDebug } from '@erudit-js/cog/schema';
2
-
3
- import eruditConfig from '#erudit/config';
4
-
5
- let languagesCache: any;
6
- let repositoryCache: any;
7
-
8
- function useFakeUrl(
9
- fakeApiTarget: keyof EruditConfigDebug['fakeApi'],
10
- ): boolean {
11
- return eruditConfig.debug?.fakeApi?.[fakeApiTarget] ?? import.meta.dev;
12
- }
13
-
14
- function getPayload() {
15
- const nuxt = useNuxtApp();
16
- const payloadKey = 'external-api';
17
- const payload =
18
- (nuxt.static.data[payloadKey] ||=
19
- nuxt.payload.data[payloadKey] ||=
20
- {});
21
-
22
- return payload;
23
- }
24
-
25
- export async function useExternalApiLanguages() {
26
- const sharedUrl = eruditConfig.repository?.sharedUrl;
27
- if (!sharedUrl) return {};
28
-
29
- const payload = getPayload();
30
- const fake = useFakeUrl('languages');
31
-
32
- if (fake) {
33
- payload.languages ||= languagesCache ||= await $fetch(
34
- '/api/fake/shared/languages',
35
- );
36
- } else {
37
- payload.languages ||= languagesCache ||= await $fetch(
38
- `https://api.github.com/repos/${sharedUrl}/contents/languages.json`,
39
- {
40
- headers: { Accept: 'application/vnd.github.v3.raw' },
41
- responseType: 'json',
42
- //transform: (response: string) => JSON.parse(response),
43
- },
44
- );
45
- }
46
-
47
- return payload.languages;
48
- }
49
-
50
- export async function useExternalApiRepository() {
51
- const repositoryName = eruditConfig.repository?.name;
52
- const repositoryBranch = eruditConfig.repository?.branch;
53
-
54
- if (!repositoryName || !repositoryBranch) return undefined;
55
-
56
- const payload = getPayload();
57
- const fake = useFakeUrl('repository');
58
-
59
- if (fake) {
60
- payload.repository ||= repositoryCache ||=
61
- await $fetch('/api/fake/content');
62
- } else {
63
- payload.repository ||= repositoryCache ||= await $fetch(
64
- `https://api.github.com/repos/${repositoryName}/branches/${repositoryBranch}`,
65
- );
66
- }
67
-
68
- return payload.repository;
69
- }
1
+ import type { EruditConfigDebug } from '@erudit-js/cog/schema';
2
+
3
+ import eruditConfig from '#erudit/config';
4
+
5
+ let languagesCache: any;
6
+ let repositoryCache: any;
7
+
8
+ function useFakeUrl(
9
+ fakeApiTarget: keyof EruditConfigDebug['fakeApi'],
10
+ ): boolean {
11
+ return eruditConfig.debug?.fakeApi?.[fakeApiTarget] ?? import.meta.dev;
12
+ }
13
+
14
+ function getPayload() {
15
+ const nuxt = useNuxtApp();
16
+ const payloadKey = 'external-api';
17
+ const payload =
18
+ (nuxt.static.data[payloadKey] ||=
19
+ nuxt.payload.data[payloadKey] ||=
20
+ {});
21
+
22
+ return payload;
23
+ }
24
+
25
+ export async function useExternalApiLanguages() {
26
+ const sharedUrl = eruditConfig.repository?.sharedUrl;
27
+ if (!sharedUrl) return {};
28
+
29
+ const payload = getPayload();
30
+ const fake = useFakeUrl('languages');
31
+
32
+ if (fake) {
33
+ payload.languages ||= languagesCache ||= await $fetch(
34
+ '/api/fake/shared/languages',
35
+ );
36
+ } else {
37
+ payload.languages ||= languagesCache ||= await $fetch(
38
+ `https://api.github.com/repos/${sharedUrl}/contents/languages.json`,
39
+ {
40
+ headers: { Accept: 'application/vnd.github.v3.raw' },
41
+ responseType: 'json',
42
+ //transform: (response: string) => JSON.parse(response),
43
+ },
44
+ );
45
+ }
46
+
47
+ return payload.languages;
48
+ }
49
+
50
+ export async function useExternalApiRepository() {
51
+ const repositoryName = eruditConfig.repository?.name;
52
+ const repositoryBranch = eruditConfig.repository?.branch;
53
+
54
+ if (!repositoryName || !repositoryBranch) return undefined;
55
+
56
+ const payload = getPayload();
57
+ const fake = useFakeUrl('repository');
58
+
59
+ if (fake) {
60
+ payload.repository ||= repositoryCache ||=
61
+ await $fetch('/api/fake/content');
62
+ } else {
63
+ payload.repository ||= repositoryCache ||= await $fetch(
64
+ `https://api.github.com/repos/${repositoryName}/branches/${repositoryBranch}`,
65
+ );
66
+ }
67
+
68
+ return payload.repository;
69
+ }
@@ -1,8 +1,8 @@
1
- import eruditConfig from '#erudit/config';
2
-
3
- export const defaultFavicon =
4
- eruditConfig.site?.favicon?.default || eruditAsset('favicon/default.svg');
5
-
6
- export function useFavicon() {
7
- return useState('favicon', () => defaultFavicon);
8
- }
1
+ import eruditConfig from '#erudit/config';
2
+
3
+ export const defaultFavicon =
4
+ eruditConfig.site?.favicon?.default || eruditAsset('favicon/default.svg');
5
+
6
+ export function useFavicon() {
7
+ return useState('favicon', () => defaultFavicon);
8
+ }
@@ -1,99 +1,99 @@
1
- import eruditConfig from '#erudit/config';
2
-
3
- export interface FormatState {
4
- quoteOpen: boolean;
5
- }
6
-
7
- const defaultFormatState: FormatState = {
8
- quoteOpen: false,
9
- };
10
-
11
- export type FormatFunction = (text: string, state?: FormatState) => string;
12
- export type FormatterFunction = (text: string, state: FormatState) => string;
13
-
14
- let formatFunction: FormatFunction;
15
-
16
- export function useFormatText() {
17
- if (!formatFunction) {
18
- const language = eruditConfig?.language;
19
- formatFunction = createFormatFunction(language);
20
- }
21
-
22
- return formatFunction;
23
- }
24
-
25
- function createFormatFunction(language?: string): FormatFunction {
26
- const formatters: FormatterFunction[] = [];
27
-
28
- //
29
- // Em Dashes
30
- //
31
-
32
- formatters.push((text) => text.replace(/(^| )--($| )/gm, '$1—$2'));
33
-
34
- //
35
- // Quotes
36
- //
37
-
38
- {
39
- const quoteSymbols: [string, string] = (() => {
40
- switch (language) {
41
- case 'ru':
42
- return ['«', '»'];
43
- default:
44
- return ['“', '”'];
45
- }
46
- })();
47
-
48
- formatters.push((text, state) => {
49
- return text.replaceAll(/"/gm, () => {
50
- return (state.quoteOpen = !state.quoteOpen)
51
- ? quoteSymbols[0]
52
- : quoteSymbols[1];
53
- });
54
- });
55
- }
56
-
57
- //
58
- // Ellipsis
59
- //
60
-
61
- formatters.push((text) => text.replace(/\.\.\./gm, '…'));
62
-
63
- //
64
- // Language specific formatters
65
- //
66
-
67
- if (language === 'ru') formatters.push(ruStickyPrepositions);
68
-
69
- //
70
- //
71
- //
72
-
73
- function formatText(
74
- text: string,
75
- state: FormatState = defaultFormatState,
76
- ): string {
77
- if (!text) return text;
78
-
79
- for (const formatter of formatters) text = formatter(text, state);
80
-
81
- return text;
82
- }
83
-
84
- return formatText;
85
- }
86
-
87
- //
88
- //
89
- //
90
-
91
- /**
92
- * Formats prepositions in Russian text so that they are always adjacent to the next word and are not left hanging “in the air” when the line breaks.
93
- */
94
- function ruStickyPrepositions(text: string): string {
95
- return text.replace(
96
- / (в|не|без|для|до|за|из|к|на|над|о|об|от|по|под|при|про|с|у|через|вокруг|около|после|перед|между|внутри|вне|из-за|из-под|ради|сквозь|среди|насчёт|вследствие|благодаря|несмотря|наперекор|вопреки|подле|возле|рядом|навстречу) /gimu,
97
- ' $1\xa0',
98
- );
99
- }
1
+ import eruditConfig from '#erudit/config';
2
+
3
+ export interface FormatState {
4
+ quoteOpen: boolean;
5
+ }
6
+
7
+ const defaultFormatState: FormatState = {
8
+ quoteOpen: false,
9
+ };
10
+
11
+ export type FormatFunction = (text: string, state?: FormatState) => string;
12
+ export type FormatterFunction = (text: string, state: FormatState) => string;
13
+
14
+ let formatFunction: FormatFunction;
15
+
16
+ export function useFormatText() {
17
+ if (!formatFunction) {
18
+ const language = eruditConfig?.language;
19
+ formatFunction = createFormatFunction(language);
20
+ }
21
+
22
+ return formatFunction;
23
+ }
24
+
25
+ function createFormatFunction(language?: string): FormatFunction {
26
+ const formatters: FormatterFunction[] = [];
27
+
28
+ //
29
+ // Em Dashes
30
+ //
31
+
32
+ formatters.push((text) => text.replace(/(^| )--($| )/gm, '$1—$2'));
33
+
34
+ //
35
+ // Quotes
36
+ //
37
+
38
+ {
39
+ const quoteSymbols: [string, string] = (() => {
40
+ switch (language) {
41
+ case 'ru':
42
+ return ['«', '»'];
43
+ default:
44
+ return ['“', '”'];
45
+ }
46
+ })();
47
+
48
+ formatters.push((text, state) => {
49
+ return text.replaceAll(/"/gm, () => {
50
+ return (state.quoteOpen = !state.quoteOpen)
51
+ ? quoteSymbols[0]
52
+ : quoteSymbols[1];
53
+ });
54
+ });
55
+ }
56
+
57
+ //
58
+ // Ellipsis
59
+ //
60
+
61
+ formatters.push((text) => text.replace(/\.\.\./gm, '…'));
62
+
63
+ //
64
+ // Language specific formatters
65
+ //
66
+
67
+ if (language === 'ru') formatters.push(ruStickyPrepositions);
68
+
69
+ //
70
+ //
71
+ //
72
+
73
+ function formatText(
74
+ text: string,
75
+ state: FormatState = defaultFormatState,
76
+ ): string {
77
+ if (!text) return text;
78
+
79
+ for (const formatter of formatters) text = formatter(text, state);
80
+
81
+ return text;
82
+ }
83
+
84
+ return formatText;
85
+ }
86
+
87
+ //
88
+ //
89
+ //
90
+
91
+ /**
92
+ * Formats prepositions in Russian text so that they are always adjacent to the next word and are not left hanging “in the air” when the line breaks.
93
+ */
94
+ function ruStickyPrepositions(text: string): string {
95
+ return text.replace(
96
+ / (в|не|без|для|до|за|из|к|на|над|о|об|от|по|под|при|про|с|у|через|вокруг|около|после|перед|между|внутри|вне|из-за|из-под|ради|сквозь|среди|насчёт|вследствие|благодаря|несмотря|наперекор|вопреки|подле|возле|рядом|навстречу) /gimu,
97
+ ' $1\xa0',
98
+ );
99
+ }
@@ -1,60 +1,61 @@
1
- import type { Component } from 'vue';
2
-
3
- import type { MyIconName } from '#my-icons';
4
-
5
- import Nav from '@app/components/aside/major/panes/nav/Nav.vue';
6
- import Pages from '@app/components/aside/major/panes/Pages.vue';
7
- import Search from '@app/components/aside/major/panes/Search.vue';
8
- import Language from '@app/components/aside/major/panes/Language.vue';
9
- import Other from '@app/components/aside/major/panes/other/Other.vue';
10
-
11
- interface MajorPane {
12
- icon: MyIconName;
13
- phrase: EruditPhraseId;
14
- content: Component;
15
- }
16
-
17
- function definePane<TPane extends MajorPane>(pane: TPane) {
18
- return pane;
19
- }
20
-
21
- export const majorPanes = {
22
- index: definePane({ icon: 'book', phrase: 'index', content: Nav }),
23
- pages: definePane({ icon: 'file-lines', phrase: 'pages', content: Pages }),
24
- search: definePane({ icon: 'search', phrase: 'search', content: Search }),
25
- language: definePane({
26
- icon: 'globe',
27
- phrase: 'language',
28
- content: Language,
29
- }),
30
- other: definePane({
31
- icon: 'ellipsis-vertical',
32
- phrase: 'other',
33
- content: Other,
34
- }),
35
- };
36
-
37
- function getPaneOrder(paneKey: MajorPaneKey) {
38
- return Object.keys(majorPanes).indexOf(paneKey);
39
- }
40
-
41
- export type MajorPaneKey = keyof typeof majorPanes;
42
-
43
- export function useMajorPane() {
44
- const route = useRoute();
45
-
46
- const activePane = useState<MajorPaneKey>('major-pane', () => {
47
- switch (route.path) {
48
- case '/members':
49
- return 'pages';
50
- default:
51
- return 'index';
52
- }
53
- });
54
-
55
- return {
56
- panes: majorPanes,
57
- activePane,
58
- getPaneOrder,
59
- };
60
- }
1
+ import type { Component } from 'vue';
2
+
3
+ import type { MyIconName } from '#my-icons';
4
+
5
+ import Nav from '@app/components/aside/major/panes/nav/Nav.vue';
6
+ import Pages from '@app/components/aside/major/panes/Pages.vue';
7
+ import Search from '@app/components/aside/major/panes/Search.vue';
8
+ import Language from '@app/components/aside/major/panes/Language.vue';
9
+ import Other from '@app/components/aside/major/panes/other/Other.vue';
10
+
11
+ interface MajorPane {
12
+ icon: MyIconName;
13
+ phrase: EruditPhraseId;
14
+ content: Component;
15
+ }
16
+
17
+ function definePane<TPane extends MajorPane>(pane: TPane) {
18
+ return pane;
19
+ }
20
+
21
+ export const majorPanes = {
22
+ index: definePane({ icon: 'book', phrase: 'index', content: Nav }),
23
+ pages: definePane({ icon: 'file-lines', phrase: 'pages', content: Pages }),
24
+ search: definePane({ icon: 'search', phrase: 'search', content: Search }),
25
+ language: definePane({
26
+ icon: 'globe',
27
+ phrase: 'language',
28
+ content: Language,
29
+ }),
30
+ other: definePane({
31
+ icon: 'ellipsis-vertical',
32
+ phrase: 'other',
33
+ content: Other,
34
+ }),
35
+ };
36
+
37
+ function getPaneOrder(paneKey: MajorPaneKey) {
38
+ return Object.keys(majorPanes).indexOf(paneKey);
39
+ }
40
+
41
+ export type MajorPaneKey = keyof typeof majorPanes;
42
+
43
+ export function useMajorPane() {
44
+ const route = useRoute();
45
+
46
+ const activePane = useState<MajorPaneKey>('major-pane', () => {
47
+ switch (true) {
48
+ case route.path.startsWith('/contributors'):
49
+ case route.path.startsWith('/contributor/'):
50
+ return 'pages';
51
+ default:
52
+ return 'index';
53
+ }
54
+ });
55
+
56
+ return {
57
+ panes: majorPanes,
58
+ activePane,
59
+ getPaneOrder,
60
+ };
61
+ }