erudit 3.0.0-dev.9 → 4.0.0-dev.2

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 (605) hide show
  1. package/app/app.vue +24 -185
  2. package/app/assets/icons/array-check.svg +3 -0
  3. package/app/assets/icons/array-lines.svg +3 -0
  4. package/app/assets/icons/array-star.svg +3 -0
  5. package/app/assets/icons/arrow/from-circle.svg +3 -0
  6. package/app/assets/icons/arrow/left.svg +3 -0
  7. package/app/assets/icons/arrow/outward-box.svg +3 -0
  8. package/app/assets/icons/arrow/outward.svg +3 -0
  9. package/app/assets/icons/arrow/to-circle.svg +3 -0
  10. package/app/assets/icons/arrow/up-to-right.svg +3 -0
  11. package/app/assets/icons/aside-open.svg +2 -2
  12. package/app/assets/icons/asterisk.svg +2 -2
  13. package/app/assets/icons/bell.svg +3 -0
  14. package/app/assets/icons/book-outline.svg +3 -0
  15. package/app/assets/icons/book-question.svg +2 -2
  16. package/app/assets/icons/book.svg +2 -2
  17. package/app/assets/icons/box.svg +3 -0
  18. package/app/assets/icons/bug.svg +2 -2
  19. package/app/assets/icons/chevron-right.svg +3 -0
  20. package/app/assets/icons/cog.svg +3 -0
  21. package/app/assets/icons/construction.svg +2 -2
  22. package/app/assets/icons/diamond.svg +3 -0
  23. package/app/assets/icons/draw.svg +2 -2
  24. package/app/assets/icons/erudit.svg +3 -0
  25. package/app/assets/icons/file-lines.svg +2 -2
  26. package/app/assets/icons/files.svg +3 -0
  27. package/app/assets/icons/flame.svg +3 -0
  28. package/app/assets/icons/folder-open.svg +2 -2
  29. package/app/assets/icons/folder.svg +2 -2
  30. package/app/assets/icons/globe.svg +2 -2
  31. package/app/assets/icons/graduation.svg +3 -0
  32. package/app/assets/icons/handshake.svg +3 -0
  33. package/app/assets/icons/house.svg +2 -2
  34. package/app/assets/icons/lines.svg +3 -0
  35. package/app/assets/icons/moon.svg +2 -2
  36. package/app/assets/icons/plus-circle.svg +2 -2
  37. package/app/assets/icons/plus.svg +2 -2
  38. package/app/assets/icons/puzzle.svg +2 -2
  39. package/app/assets/icons/question-circle.svg +3 -0
  40. package/app/assets/icons/rocket.svg +3 -0
  41. package/app/assets/icons/search/check.svg +3 -0
  42. package/app/assets/icons/search/dead.svg +3 -0
  43. package/app/assets/icons/search/glass.svg +3 -0
  44. package/app/assets/icons/search/wtf.svg +3 -0
  45. package/app/assets/icons/sun-moon.svg +2 -2
  46. package/app/assets/icons/sun.svg +2 -2
  47. package/app/assets/icons/translate.svg +3 -0
  48. package/app/assets/icons/user.svg +2 -2
  49. package/app/assets/icons/users.svg +2 -2
  50. package/app/assets/icons/warning.svg +3 -0
  51. package/app/components/EruditLink.ts +9 -0
  52. package/app/components/FancyBold.vue +16 -0
  53. package/app/components/FancyCard.vue +58 -0
  54. package/app/components/FancyCardTag.vue +16 -0
  55. package/app/components/Prose.vue +51 -0
  56. package/app/components/ScrollHolder.vue +20 -0
  57. package/app/components/SmartMedia.vue +112 -0
  58. package/app/components/ads/Ads.vue +39 -0
  59. package/app/components/ads/AdsBannerAside.vue +45 -0
  60. package/app/components/ads/AdsBannerBottom.vue +17 -0
  61. package/app/components/ads/AdsReplacer.vue +28 -0
  62. package/app/components/ads/provider/Custom.vue +19 -0
  63. package/app/components/ads/provider/Yandex.vue +84 -0
  64. package/app/components/aside/AsideListItem.vue +66 -74
  65. package/app/components/aside/AsideMajor.vue +8 -56
  66. package/app/components/aside/AsideMinor.vue +76 -71
  67. package/app/components/aside/AsidePlainMessage.vue +9 -0
  68. package/app/components/aside/AsideSwitch.vue +77 -0
  69. package/app/components/aside/major/PaneHolder.vue +106 -0
  70. package/app/components/aside/major/PaneSwitcher.vue +73 -0
  71. package/app/components/aside/major/PaneSwitcherButton.vue +38 -0
  72. package/app/components/aside/major/PaneTemplate.vue +5 -0
  73. package/app/components/aside/major/SiteInfo.vue +68 -85
  74. package/app/components/aside/major/contentNav/PaneBookNav.vue +116 -0
  75. package/app/components/aside/major/contentNav/PaneGlobalNav.vue +19 -0
  76. package/app/components/aside/major/contentNav/items/ContentNavBook.vue +21 -0
  77. package/app/components/aside/major/contentNav/items/ContentNavFolder.vue +92 -0
  78. package/app/components/aside/major/contentNav/items/ContentNavItem.vue +33 -0
  79. package/app/components/aside/major/contentNav/items/ContentNavPage.vue +18 -0
  80. package/app/components/aside/major/contentNav/items/ContentNavSeparator.vue +62 -0
  81. package/app/components/aside/major/contentNav/items/ContentNavTopic.vue +18 -0
  82. package/app/components/aside/major/contentNav/items/Flags.vue +52 -0
  83. package/app/components/aside/major/contentNav/items/ItemTemplate.vue +27 -0
  84. package/app/components/aside/major/languages/PaneLanguages.vue +55 -0
  85. package/app/components/aside/major/pages/PanePages.vue +60 -0
  86. package/app/components/aside/major/search/PaneSearch.vue +145 -0
  87. package/app/components/aside/major/search/SearchInput.vue +104 -0
  88. package/app/components/aside/major/search/SearchResult.vue +103 -0
  89. package/app/components/aside/major/search/SearchStatus.vue +48 -0
  90. package/app/components/aside/major/search/search.worker.ts +164 -0
  91. package/app/components/aside/major/settings/BuildTime.vue +25 -0
  92. package/app/components/aside/major/settings/EngineVersion.vue +13 -0
  93. package/app/components/aside/major/settings/PaneSettings.vue +17 -0
  94. package/app/components/aside/major/settings/ThemeSwitcher.vue +53 -0
  95. package/app/components/aside/major/settings/repository/Repository.vue +33 -0
  96. package/app/components/aside/major/settings/repository/SecondaryGitHub.vue +71 -0
  97. package/app/components/aside/minor/AsideMinorPane.vue +1 -11
  98. package/app/components/aside/minor/AsideMinorPlainHeader.vue +20 -0
  99. package/app/components/aside/minor/content/AsideMinorContentContributions.vue +51 -0
  100. package/app/components/aside/minor/content/AsideMinorContentPage.vue +37 -0
  101. package/app/components/aside/minor/content/AsideMinorContentTopic.vue +66 -0
  102. package/app/components/aside/minor/content/ButtonPaneContributions.vue +114 -0
  103. package/app/components/aside/minor/content/ButtonPaneImprove.vue +120 -0
  104. package/app/components/aside/minor/content/Contribution.vue +36 -0
  105. package/app/components/aside/minor/content/Toc.vue +163 -0
  106. package/app/components/aside/minor/content/TocItem.vue +91 -0
  107. package/app/components/aside/minor/content/TopicPartButton.vue +35 -0
  108. package/app/components/aside/minor/contributor/AsideMinorContributor.vue +39 -0
  109. package/app/components/aside/minor/contributor/ItemBook.vue +39 -0
  110. package/app/components/aside/minor/contributor/ItemContent.vue +17 -0
  111. package/app/components/aside/minor/news/AsideMinorNews.vue +132 -0
  112. package/app/components/aside/minor/news/NewsItem.vue +69 -0
  113. package/app/components/aside/minor/news/RenderNewsElement.vue +42 -0
  114. package/app/components/aside/minor/news/elements/Mix.vue +11 -0
  115. package/app/components/aside/minor/news/elements/P.vue +14 -0
  116. package/app/components/aside/minor/news/elements/Ref.vue +58 -0
  117. package/app/components/aside/minor/news/elements/Text.vue +18 -0
  118. package/app/components/indexPage/IndexPagePersons.vue +117 -0
  119. package/app/components/main/MainAction.vue +20 -0
  120. package/app/components/main/MainBreadcrumbs.vue +28 -0
  121. package/app/components/main/MainContentChild.vue +47 -0
  122. package/app/components/main/MainContentChildren.vue +14 -0
  123. package/app/components/main/MainDecoration.vue +15 -0
  124. package/app/components/main/MainDescription.vue +13 -0
  125. package/app/components/main/MainFlag.vue +133 -0
  126. package/app/components/main/MainFlags.vue +17 -0
  127. package/app/components/main/MainGlow.vue +12 -0
  128. package/app/components/main/MainQuickLink.vue +91 -0
  129. package/app/components/main/MainQuickLinks.vue +40 -0
  130. package/app/components/main/MainQuote.vue +159 -0
  131. package/app/components/main/MainQuoteLoader.vue +86 -0
  132. package/app/components/main/MainSection.vue +44 -0
  133. package/app/components/main/MainSectionPreamble.vue +5 -0
  134. package/app/components/main/MainSubTitle.vue +12 -0
  135. package/app/components/main/MainTitle.vue +32 -0
  136. package/app/components/main/MainTopicPartPage.vue +88 -0
  137. package/app/components/main/MainTopicPartSwitch.vue +71 -0
  138. package/app/components/main/connections/Deps.vue +34 -0
  139. package/app/components/main/connections/Externals.vue +104 -0
  140. package/app/components/main/connections/MainConnections.vue +94 -0
  141. package/app/components/main/connections/MainConnectionsButton.vue +81 -0
  142. package/app/components/main/connections/ScrollPane.vue +10 -0
  143. package/app/components/main/contentStats/Item.vue +34 -0
  144. package/app/components/main/contentStats/ItemElement.vue +19 -0
  145. package/app/components/main/contentStats/ItemMaterials.vue +11 -0
  146. package/app/components/main/contentStats/MainContentStats.vue +53 -0
  147. package/app/components/preview/Preview.vue +172 -186
  148. package/app/components/preview/PreviewError.vue +10 -0
  149. package/app/components/preview/PreviewLoading.vue +5 -14
  150. package/app/components/preview/PreviewScreen.vue +64 -141
  151. package/app/components/preview/PreviewScreenButton.vue +39 -0
  152. package/app/components/preview/screen/ContentPage.vue +50 -0
  153. package/app/components/preview/screen/DirectLink.vue +23 -0
  154. package/app/components/preview/screen/Unique.vue +54 -0
  155. package/app/components/site/SiteAside.vue +68 -0
  156. package/app/components/site/SiteAsideOverlay.vue +21 -0
  157. package/app/components/site/SiteMain.vue +13 -0
  158. package/app/components/transition/Fade.vue +30 -19
  159. package/app/components/transition/Slide.vue +47 -0
  160. package/app/components/tree/TreeContainer.vue +5 -11
  161. package/app/components/tree/TreeItem.vue +40 -89
  162. package/app/composables/ads.ts +23 -0
  163. package/app/composables/analytics.ts +102 -0
  164. package/app/composables/appElements.ts +40 -0
  165. package/app/composables/aside.ts +28 -0
  166. package/app/composables/asideMajorPane.ts +135 -0
  167. package/app/composables/asideMinor.ts +109 -0
  168. package/app/composables/contentNav.ts +7 -0
  169. package/app/composables/favicon.ts +104 -4
  170. package/app/composables/file.ts +3 -0
  171. package/app/composables/formatText.ts +85 -71
  172. package/app/composables/loading.ts +2 -0
  173. package/app/composables/mainContent.ts +31 -0
  174. package/app/composables/og.ts +182 -0
  175. package/app/composables/phrases.ts +126 -81
  176. package/app/composables/preview.ts +53 -0
  177. package/app/composables/route.ts +4 -0
  178. package/app/composables/theme.ts +71 -29
  179. package/app/composables/url.ts +22 -33
  180. package/app/formatters/ru.ts +14 -0
  181. package/app/pages/article/[...articleId].vue +10 -1
  182. package/app/pages/book/[...bookId].vue +52 -43
  183. package/app/pages/contributor/[contributorId].vue +150 -0
  184. package/app/pages/contributors.vue +99 -0
  185. package/app/pages/group/[...groupId].vue +53 -59
  186. package/app/pages/index.vue +111 -26
  187. package/app/pages/page/[...pageId].vue +60 -0
  188. package/app/pages/practice/[...practiceId].vue +12 -0
  189. package/app/pages/sponsors.vue +91 -0
  190. package/app/pages/summary/[...summaryId].vue +10 -1
  191. package/app/plugins/appSetup/client/htmlBranding.ts +6 -0
  192. package/app/plugins/appSetup/client/welcome.ts +35 -0
  193. package/app/plugins/appSetup/config.ts +6 -0
  194. package/app/plugins/appSetup/global.ts +3 -0
  195. package/app/plugins/appSetup/index.ts +28 -0
  196. package/app/plugins/prerender.server.ts +40 -0
  197. package/app/router.options.ts +5 -0
  198. package/app/scripts/theme.js +33 -0
  199. package/app/styles/main.css +172 -0
  200. package/bin/erudit.mjs +2 -2
  201. package/modules/erudit/globals/content.ts +4 -0
  202. package/modules/erudit/globals/contributor.ts +1 -0
  203. package/modules/erudit/globals/eruditConfig.ts +10 -0
  204. package/modules/erudit/globals/problem.ts +1 -0
  205. package/modules/erudit/globals/prose.ts +1 -0
  206. package/modules/erudit/globals/public.ts +18 -0
  207. package/modules/erudit/index.ts +60 -0
  208. package/{module → modules/erudit}/logger.ts +2 -2
  209. package/modules/erudit/setup/aliases.ts +17 -0
  210. package/modules/erudit/setup/baseUrl.ts +19 -0
  211. package/modules/erudit/setup/elements/appTemplate.ts +45 -0
  212. package/modules/erudit/setup/elements/globalTemplate.ts +82 -0
  213. package/modules/erudit/setup/elements/globalTypes.ts +273 -0
  214. package/modules/erudit/setup/elements/setup.ts +167 -0
  215. package/modules/erudit/setup/elements/shared.ts +10 -0
  216. package/modules/erudit/setup/elements/tagsTable.ts +28 -0
  217. package/modules/erudit/setup/fullRestart.ts +71 -0
  218. package/modules/erudit/setup/globals.ts +196 -0
  219. package/modules/erudit/setup/nuxtConfig.ts +62 -0
  220. package/modules/erudit/setup/projectConfig.ts +114 -0
  221. package/modules/erudit/setup/publicAssets.ts +52 -0
  222. package/modules/erudit/setup/runtimeConfig.ts +58 -0
  223. package/modules/erudit/watcher.ts +27 -0
  224. package/nuxt.config.ts +66 -87
  225. package/package.json +38 -19
  226. package/proxy/prose.app.ts +1 -0
  227. package/proxy/prose.ts +1 -0
  228. package/public/favicons/default.svg +1 -0
  229. package/{app/public → public}/logotype.svg +1 -1
  230. package/public/og.png +0 -0
  231. package/server/api/aside/major/frontNav/book/[...shortId].ts +10 -0
  232. package/server/api/aside/major/frontNav/global.ts +5 -0
  233. package/server/api/aside/major/pages.ts +6 -0
  234. package/server/api/contributor/list.ts +61 -0
  235. package/server/api/contributor/page/[contributorId].ts +68 -0
  236. package/server/api/indexPage.ts +81 -0
  237. package/server/api/language/functions.ts +6 -7
  238. package/server/api/language/phrase/[phraseKey].ts +32 -0
  239. package/server/api/main/content/[...contentTypePath].ts +153 -0
  240. package/server/api/news/batch/[batchIndex].ts +5 -0
  241. package/server/api/pageSponsors.ts +58 -0
  242. package/server/api/prerender/content.ts +82 -0
  243. package/server/api/prerender/default.ts +35 -0
  244. package/server/api/prerender/files.ts +10 -0
  245. package/server/api/prerender/frontNav.ts +13 -0
  246. package/server/api/prerender/language.ts +7 -0
  247. package/server/api/prerender/news.ts +8 -0
  248. package/server/api/prerender/quotes.ts +15 -0
  249. package/server/api/preview/contentPage/[...contentTypePath].ts +63 -0
  250. package/server/api/preview/contentUnique/[...contentTypePathUnique].ts +81 -0
  251. package/server/api/problemScript/[...problemScriptPath].ts +92 -0
  252. package/server/api/quote/data/[quoteId].ts +87 -0
  253. package/server/api/quote/ids.ts +3 -0
  254. package/server/erudit/build.ts +137 -0
  255. package/server/erudit/cameos/build.ts +161 -0
  256. package/server/erudit/config.ts +13 -0
  257. package/server/erudit/content/global/build.ts +297 -0
  258. package/server/erudit/content/global/singleton.ts +5 -0
  259. package/server/erudit/content/nav/build.ts +463 -0
  260. package/server/erudit/content/nav/front.ts +127 -0
  261. package/server/erudit/content/nav/repository/books.ts +40 -0
  262. package/server/erudit/content/nav/repository/get.ts +33 -0
  263. package/server/erudit/content/nav/repository/hasChildren.ts +5 -0
  264. package/server/erudit/content/nav/repository/hasNav.ts +3 -0
  265. package/server/erudit/content/nav/repository/hasParent.ts +5 -0
  266. package/server/erudit/content/nav/repository/id.ts +9 -0
  267. package/server/erudit/content/nav/repository/index.ts +9 -0
  268. package/server/erudit/content/nav/repository/order.ts +14 -0
  269. package/server/erudit/content/nav/repository/previousNext.ts +35 -0
  270. package/server/erudit/content/nav/repository/walk.ts +127 -0
  271. package/server/erudit/content/nav/setup.ts +13 -0
  272. package/server/erudit/content/nav/types.ts +24 -0
  273. package/server/erudit/content/repository/breadcrumbs.ts +24 -0
  274. package/server/erudit/content/repository/children.ts +47 -0
  275. package/server/erudit/content/repository/connections.ts +35 -0
  276. package/server/erudit/content/repository/contentLink.ts +16 -0
  277. package/server/erudit/content/repository/decoration.ts +23 -0
  278. package/server/erudit/content/repository/deps.ts +84 -0
  279. package/server/erudit/content/repository/description.ts +11 -0
  280. package/server/erudit/content/repository/elementSnippets.ts +105 -0
  281. package/server/erudit/content/repository/externals.ts +50 -0
  282. package/server/erudit/content/repository/flags.ts +33 -0
  283. package/server/erudit/content/repository/seo.ts +12 -0
  284. package/server/erudit/content/repository/stats.ts +97 -0
  285. package/server/erudit/content/repository/title.ts +27 -0
  286. package/server/erudit/content/repository/topicParts.ts +39 -0
  287. package/server/erudit/content/repository/unique.ts +76 -0
  288. package/server/erudit/content/resolve/book.ts +32 -0
  289. package/server/erudit/content/resolve/group.ts +39 -0
  290. package/server/erudit/content/resolve/index.ts +290 -0
  291. package/server/erudit/content/resolve/page.ts +87 -0
  292. package/server/erudit/content/resolve/topic.ts +246 -0
  293. package/server/erudit/content/resolve/utils/contentError.ts +10 -0
  294. package/server/erudit/content/resolve/utils/insertContentItem.ts +122 -0
  295. package/server/erudit/content/resolve/utils/insertContentResolved.ts +132 -0
  296. package/server/erudit/content/search.ts +163 -0
  297. package/server/erudit/contributors/build.ts +166 -0
  298. package/server/erudit/contributors/global.ts +3 -0
  299. package/server/erudit/contributors/repository/avatarUrl.ts +10 -0
  300. package/server/erudit/contributors/repository/contributions.ts +178 -0
  301. package/server/erudit/contributors/repository/count.ts +3 -0
  302. package/server/erudit/contributors/search.ts +34 -0
  303. package/server/erudit/db/repository/pushFile.ts +26 -0
  304. package/server/erudit/db/repository/pushProblemScript.ts +19 -0
  305. package/server/erudit/db/repository/pushProseLink.ts +40 -0
  306. package/server/erudit/db/schema/cameos.ts +7 -0
  307. package/server/erudit/db/schema/content.ts +18 -0
  308. package/server/erudit/db/schema/contentContributions.ts +15 -0
  309. package/server/erudit/db/schema/contentDeps.ts +21 -0
  310. package/server/erudit/db/schema/contentElementStats.ts +20 -0
  311. package/server/erudit/db/schema/contentProseLinks.ts +23 -0
  312. package/server/erudit/db/schema/contentSnippets.ts +15 -0
  313. package/server/erudit/db/schema/contentToc.ts +16 -0
  314. package/server/erudit/db/schema/contentUniques.ts +25 -0
  315. package/server/erudit/db/schema/contributors.ts +12 -0
  316. package/server/erudit/db/schema/files.ts +11 -0
  317. package/server/erudit/db/schema/groups.ts +6 -0
  318. package/server/erudit/db/schema/index.ts +17 -0
  319. package/server/erudit/db/schema/news.ts +7 -0
  320. package/server/erudit/db/schema/pages.ts +7 -0
  321. package/server/erudit/db/schema/problemScripts.ts +14 -0
  322. package/server/erudit/db/schema/sponsors.ts +9 -0
  323. package/server/erudit/db/schema/topics.ts +9 -0
  324. package/server/erudit/db/setup.ts +62 -0
  325. package/server/erudit/db/types.ts +10 -0
  326. package/server/erudit/global.ts +33 -0
  327. package/server/erudit/importer.ts +97 -0
  328. package/server/erudit/index.ts +90 -0
  329. package/server/erudit/language/list/en.ts +211 -0
  330. package/server/erudit/language/list/ru.ts +216 -0
  331. package/server/erudit/language/list.ts +6 -0
  332. package/server/erudit/language/setup.ts +36 -0
  333. package/server/erudit/language/types.ts +16 -0
  334. package/server/erudit/logger.ts +77 -0
  335. package/server/erudit/news/build.ts +114 -0
  336. package/server/erudit/news/repository/batch.ts +61 -0
  337. package/server/erudit/prose/repository/finalize.ts +68 -0
  338. package/server/erudit/prose/repository/get.ts +54 -0
  339. package/server/erudit/prose/repository/resolve.ts +17 -0
  340. package/server/erudit/prose/storage/callout.ts +14 -0
  341. package/server/erudit/prose/storage/image.ts +20 -0
  342. package/server/erudit/prose/storage/link.ts +226 -0
  343. package/server/erudit/prose/storage/problemScript.ts +21 -0
  344. package/server/erudit/prose/storage/video.ts +14 -0
  345. package/server/erudit/prose/transform/bundleProblemScript.ts +6 -0
  346. package/server/erudit/prose/transform/extensions.ts +15 -0
  347. package/server/erudit/quote/repository/ids.ts +31 -0
  348. package/server/erudit/repository.ts +96 -0
  349. package/server/erudit/sponsors/build.ts +165 -0
  350. package/server/erudit/sponsors/repository/avatarUrl.ts +10 -0
  351. package/server/erudit/sponsors/repository/count.ts +4 -0
  352. package/server/erudit/staticFile.ts +28 -0
  353. package/server/plugins/augmentCss.ts +17 -0
  354. package/server/plugins/lang.ts +7 -0
  355. package/server/plugins/metaViewport.ts +15 -0
  356. package/server/plugins/theme.ts +13 -0
  357. package/server/routes/file/[...path].ts +18 -0
  358. package/server/routes/robots.txt.ts +9 -0
  359. package/server/routes/search.json.gz.ts +73 -0
  360. package/server/routes/sitemap.xml.ts +81 -0
  361. package/shared/search/encoders.ts +20 -0
  362. package/shared/types/asideMajorPages.ts +4 -0
  363. package/shared/types/breadcrumbs.ts +9 -0
  364. package/shared/types/contentChildren.ts +10 -0
  365. package/shared/types/contentConnections.ts +27 -0
  366. package/shared/types/contentStats.ts +6 -0
  367. package/shared/types/elementSnippet.ts +14 -0
  368. package/shared/types/frontContentNav.ts +38 -0
  369. package/shared/types/indexPage.ts +20 -0
  370. package/shared/types/language.ts +191 -75
  371. package/shared/types/mainContent.ts +69 -0
  372. package/shared/types/news.ts +13 -0
  373. package/shared/types/preview.ts +28 -0
  374. package/shared/types/runtimeConfig.ts +64 -0
  375. package/shared/types/search.ts +79 -0
  376. package/shared/utils/contentTypePath.ts +63 -0
  377. package/shared/utils/icons.ts +11 -0
  378. package/shared/utils/pages.ts +24 -0
  379. package/shared/utils/slasher.ts +64 -0
  380. package/shared/utils/stringColor.ts +13 -9
  381. package/shared/utils/toStringEqual.ts +21 -0
  382. package/shared/utils/zip.ts +64 -0
  383. package/test/shared/utils/slasher.test.ts +75 -0
  384. package/test/shared/utils/zip.test.ts +8 -0
  385. package/tsconfig.json +17 -8
  386. package/app/assets/icons/alert.svg +0 -3
  387. package/app/assets/icons/angle-right.svg +0 -3
  388. package/app/assets/icons/arrow-in-text.svg +0 -3
  389. package/app/assets/icons/arrow-left.svg +0 -3
  390. package/app/assets/icons/arrow-up-to-right.svg +0 -3
  391. package/app/assets/icons/chip.svg +0 -3
  392. package/app/assets/icons/circle-help.svg +0 -3
  393. package/app/assets/icons/cross.svg +0 -3
  394. package/app/assets/icons/ellipsis-vertical.svg +0 -3
  395. package/app/assets/icons/file-check.svg +0 -3
  396. package/app/assets/icons/file-star.svg +0 -3
  397. package/app/assets/icons/link-external.svg +0 -3
  398. package/app/assets/icons/link.svg +0 -3
  399. package/app/assets/icons/outline/book.svg +0 -3
  400. package/app/assets/icons/outline/file-lines.svg +0 -3
  401. package/app/assets/icons/pirate.svg +0 -3
  402. package/app/assets/icons/search.svg +0 -3
  403. package/app/assets/icons/shuffle.svg +0 -3
  404. package/app/assets/icons/star.svg +0 -3
  405. package/app/components/Loading.vue +0 -23
  406. package/app/components/SiteAside.vue +0 -393
  407. package/app/components/SiteMain.vue +0 -34
  408. package/app/components/ads/BannerTemplate.vue +0 -51
  409. package/app/components/ads/BottomBanner.vue +0 -45
  410. package/app/components/ads/LeftBanner.vue +0 -50
  411. package/app/components/aside/major/PaneContentScroll.vue +0 -23
  412. package/app/components/aside/major/PaneSwitch.vue +0 -54
  413. package/app/components/aside/major/PaneSwitchButton.vue +0 -63
  414. package/app/components/aside/major/panes/Language.vue +0 -79
  415. package/app/components/aside/major/panes/Pages.vue +0 -34
  416. package/app/components/aside/major/panes/Search.vue +0 -11
  417. package/app/components/aside/major/panes/nav/Nav.vue +0 -87
  418. package/app/components/aside/major/panes/nav/NavBook.vue +0 -87
  419. package/app/components/aside/major/panes/nav/NavBookLoading.vue +0 -24
  420. package/app/components/aside/major/panes/nav/NavGlobal.vue +0 -16
  421. package/app/components/aside/major/panes/nav/fnav/FNav.vue +0 -105
  422. package/app/components/aside/major/panes/nav/fnav/FNavBook.vue +0 -32
  423. package/app/components/aside/major/panes/nav/fnav/FNavFlags.vue +0 -40
  424. package/app/components/aside/major/panes/nav/fnav/FNavFolder.vue +0 -60
  425. package/app/components/aside/major/panes/nav/fnav/FNavItem.vue +0 -34
  426. package/app/components/aside/major/panes/nav/fnav/FNavSeparator.vue +0 -80
  427. package/app/components/aside/major/panes/nav/fnav/FNavTopic.vue +0 -24
  428. package/app/components/aside/major/panes/other/ItemContent.vue +0 -29
  429. package/app/components/aside/major/panes/other/ItemGenerator.vue +0 -15
  430. package/app/components/aside/major/panes/other/ItemTheme.vue +0 -54
  431. package/app/components/aside/major/panes/other/Other.vue +0 -16
  432. package/app/components/aside/minor/AsideMinorContributor.vue +0 -5
  433. package/app/components/aside/minor/AsideMinorNews.vue +0 -11
  434. package/app/components/aside/minor/AsideMinorTopLink.vue +0 -67
  435. package/app/components/aside/minor/Contribute.vue +0 -145
  436. package/app/components/aside/minor/content/AsideMinorContent.vue +0 -92
  437. package/app/components/aside/minor/topic/AsideMinorTopic.vue +0 -32
  438. package/app/components/aside/minor/topic/TopicContributors.vue +0 -177
  439. package/app/components/aside/minor/topic/TopicNav.vue +0 -49
  440. package/app/components/aside/minor/topic/TopicToc.vue +0 -219
  441. package/app/components/aside/minor/topic/TopicTocItem.vue +0 -30
  442. package/app/components/aside/utils/AsideOverlayPane.vue +0 -40
  443. package/app/components/bitran/BitranContent.vue +0 -77
  444. package/app/components/bitran/RenderWrapper.vue +0 -10
  445. package/app/components/contributor/ContributorAvatar.vue +0 -43
  446. package/app/components/contributor/ContributorListItem.vue +0 -35
  447. package/app/components/main/topic/MainTopic.vue +0 -78
  448. package/app/components/main/topic/TopicPartSwitch.vue +0 -118
  449. package/app/components/main/utils/Breadcrumb.vue +0 -70
  450. package/app/components/main/utils/ContentDecoration.vue +0 -29
  451. package/app/components/main/utils/ContentDescription.vue +0 -19
  452. package/app/components/main/utils/ContentPopover.vue +0 -188
  453. package/app/components/main/utils/ContentPopovers.vue +0 -111
  454. package/app/components/main/utils/ContentReferences.vue +0 -70
  455. package/app/components/main/utils/ContentSection.vue +0 -45
  456. package/app/components/main/utils/ContentTitle.vue +0 -63
  457. package/app/components/main/utils/reference/ReferenceGroup.vue +0 -38
  458. package/app/components/main/utils/reference/ReferenceItem.vue +0 -68
  459. package/app/components/main/utils/reference/ReferenceSource.vue +0 -116
  460. package/app/components/preview/PreviewDisplay.vue +0 -139
  461. package/app/components/preview/PreviewFooterAction.vue +0 -73
  462. package/app/components/preview/display/Alert.vue +0 -50
  463. package/app/components/preview/display/Custom.vue +0 -18
  464. package/app/components/preview/display/GenericLink.vue +0 -48
  465. package/app/components/preview/display/PageLink.vue +0 -20
  466. package/app/components/preview/display/Unique.vue +0 -55
  467. package/app/composables/bitran.ts +0 -105
  468. package/app/composables/bitranContent.ts +0 -51
  469. package/app/composables/bitranLocation.ts +0 -7
  470. package/app/composables/contentData.ts +0 -36
  471. package/app/composables/contentPage.ts +0 -157
  472. package/app/composables/contentRoute.ts +0 -45
  473. package/app/composables/darkMagic.ts +0 -24
  474. package/app/composables/externalApi.ts +0 -63
  475. package/app/composables/majorPane.ts +0 -60
  476. package/app/pages/_test/preview.vue +0 -110
  477. package/app/pages/members.vue +0 -6
  478. package/app/pages/practice/[...practice].vue +0 -3
  479. package/app/public/favicon/article.svg +0 -10
  480. package/app/public/favicon/default.svg +0 -10
  481. package/app/public/favicon/practice.svg +0 -10
  482. package/app/public/favicon/summary.svg +0 -10
  483. package/app/public/og-default.png +0 -0
  484. package/app/public/user.svg +0 -10
  485. package/app/scripts/_immediate.js +0 -9
  486. package/app/scripts/aside/index.ts +0 -59
  487. package/app/scripts/aside/major/nav.ts +0 -26
  488. package/app/scripts/aside/minor/state.ts +0 -37
  489. package/app/scripts/aside/minor/topic.ts +0 -3
  490. package/app/scripts/flag.ts +0 -28
  491. package/app/scripts/og.ts +0 -27
  492. package/app/scripts/preview/build.ts +0 -73
  493. package/app/scripts/preview/data/alert.ts +0 -19
  494. package/app/scripts/preview/data/custom.ts +0 -8
  495. package/app/scripts/preview/data/genericLink.ts +0 -24
  496. package/app/scripts/preview/data/pageLink.ts +0 -22
  497. package/app/scripts/preview/data/unique.ts +0 -72
  498. package/app/scripts/preview/data.ts +0 -24
  499. package/app/scripts/preview/display.ts +0 -37
  500. package/app/scripts/preview/footer.ts +0 -9
  501. package/app/scripts/preview/request.ts +0 -51
  502. package/app/scripts/preview/state.ts +0 -63
  503. package/app/styles/_immediate.css +0 -7
  504. package/app/styles/_util.scss +0 -43
  505. package/app/styles/_utils.scss +0 -44
  506. package/app/styles/app.scss +0 -91
  507. package/app/styles/def/_bp.scss +0 -27
  508. package/app/styles/def/_size.scss +0 -7
  509. package/app/styles/def/_z.scss +0 -5
  510. package/app/styles/normalize.scss +0 -63
  511. package/app/styles/partials/_darkMagic.scss +0 -5
  512. package/app/styles/partials/_fnav.scss +0 -15
  513. package/app/styles/partials/_preview.scss +0 -5
  514. package/globalPath.ts +0 -21
  515. package/globals/bitran.ts +0 -2
  516. package/globals/content.ts +0 -22
  517. package/globals/contributor.ts +0 -5
  518. package/globals/erudit.ts +0 -5
  519. package/globals/register.ts +0 -18
  520. package/languages/en.ts +0 -95
  521. package/languages/ru.ts +0 -99
  522. package/module/bitran.ts +0 -36
  523. package/module/config.ts +0 -35
  524. package/module/imports.ts +0 -50
  525. package/module/index.ts +0 -47
  526. package/module/paths.ts +0 -22
  527. package/module/restart.ts +0 -61
  528. package/server/api/aside/major/nav/bookIds.ts +0 -5
  529. package/server/api/aside/major/nav/bookNav/[...bookId].ts +0 -20
  530. package/server/api/aside/major/nav/global.ts +0 -7
  531. package/server/api/aside/minor/news.ts +0 -7
  532. package/server/api/aside/minor/path.ts +0 -77
  533. package/server/api/bitran/content/[location].ts +0 -8
  534. package/server/api/bitran/toc/[location].ts +0 -7
  535. package/server/api/content/data.ts +0 -72
  536. package/server/api/contributor/count.ts +0 -6
  537. package/server/api/fake/content.ts +0 -11
  538. package/server/api/fake/shared/languages.ts +0 -12
  539. package/server/api/language/phrase/[phraseId].ts +0 -19
  540. package/server/api/language/phraseIds.ts +0 -8
  541. package/server/api/preview/page/[...parts].ts +0 -52
  542. package/server/api/preview/unique/[location].ts +0 -60
  543. package/server/plugin/bitran/content.ts +0 -194
  544. package/server/plugin/bitran/location.ts +0 -25
  545. package/server/plugin/bitran/products/include.ts +0 -228
  546. package/server/plugin/bitran/products/link.ts +0 -116
  547. package/server/plugin/bitran/setup.ts +0 -11
  548. package/server/plugin/bitran/toc.ts +0 -75
  549. package/server/plugin/bitran/transpiler.ts +0 -30
  550. package/server/plugin/build/close.ts +0 -10
  551. package/server/plugin/build/jobs/content/builderArgs.ts +0 -8
  552. package/server/plugin/build/jobs/content/generic.ts +0 -176
  553. package/server/plugin/build/jobs/content/parse.ts +0 -109
  554. package/server/plugin/build/jobs/content/path.ts +0 -6
  555. package/server/plugin/build/jobs/content/type/book.ts +0 -9
  556. package/server/plugin/build/jobs/content/type/group.ts +0 -37
  557. package/server/plugin/build/jobs/content/type/topic.ts +0 -36
  558. package/server/plugin/build/jobs/contributors.ts +0 -66
  559. package/server/plugin/build/jobs/language.ts +0 -36
  560. package/server/plugin/build/jobs/nav.ts +0 -214
  561. package/server/plugin/build/process.ts +0 -25
  562. package/server/plugin/build/rebuild.ts +0 -55
  563. package/server/plugin/build/setup.ts +0 -22
  564. package/server/plugin/content/absoluteId.ts +0 -94
  565. package/server/plugin/content/context.ts +0 -116
  566. package/server/plugin/db/entities/Book.ts +0 -7
  567. package/server/plugin/db/entities/Content.ts +0 -49
  568. package/server/plugin/db/entities/Contribution.ts +0 -10
  569. package/server/plugin/db/entities/Contributor.ts +0 -16
  570. package/server/plugin/db/entities/Group.ts +0 -14
  571. package/server/plugin/db/entities/Hash.ts +0 -15
  572. package/server/plugin/db/entities/Topic.ts +0 -20
  573. package/server/plugin/db/entities/Unique.ts +0 -21
  574. package/server/plugin/db/setup.ts +0 -34
  575. package/server/plugin/global.ts +0 -17
  576. package/server/plugin/importer.ts +0 -12
  577. package/server/plugin/index.ts +0 -9
  578. package/server/plugin/logger.ts +0 -23
  579. package/server/plugin/nav/node.ts +0 -26
  580. package/server/plugin/nav/utils.ts +0 -129
  581. package/server/plugin/repository/book.ts +0 -21
  582. package/server/plugin/repository/content.ts +0 -238
  583. package/server/plugin/repository/contributor.ts +0 -8
  584. package/server/plugin/repository/frontNav.ts +0 -148
  585. package/server/plugin/repository/topic.ts +0 -32
  586. package/server/tsconfig.json +0 -9
  587. package/shared/aside/minor.ts +0 -51
  588. package/shared/asset.ts +0 -15
  589. package/shared/bitran/stringContent.ts +0 -6
  590. package/shared/bitran/toc.ts +0 -8
  591. package/shared/content/context.ts +0 -9
  592. package/shared/content/data/base.ts +0 -32
  593. package/shared/content/data/index.ts +0 -5
  594. package/shared/content/data/type/book.ts +0 -5
  595. package/shared/content/data/type/group.ts +0 -6
  596. package/shared/content/data/type/topic.ts +0 -11
  597. package/shared/content/previousNext.ts +0 -9
  598. package/shared/contributor.ts +0 -5
  599. package/shared/frontNav.ts +0 -41
  600. package/shared/icons.ts +0 -38
  601. package/shared/image.ts +0 -5
  602. package/shared/link.ts +0 -28
  603. package/shared/popover.ts +0 -8
  604. package/shared/utils/objectsEqual.ts +0 -4
  605. package/utils/stress.ts +0 -9
@@ -0,0 +1,94 @@
1
+ <script lang="ts" setup>
2
+ import Deps from './Deps.vue';
3
+ import Externals from './Externals.vue';
4
+
5
+ const { connections } = defineProps<{ connections?: ContentConnections }>();
6
+
7
+ const phrase = await usePhrases('connections');
8
+
9
+ const currentType = ref<keyof ContentConnections | undefined>(
10
+ 'hardDependencies',
11
+ );
12
+
13
+ const ownExternalsCount = computed(() => {
14
+ return connections?.externals?.find((ext) => ext.type === 'own')?.items
15
+ .length;
16
+ });
17
+
18
+ const parentExternalsCount = computed(() => {
19
+ return connections?.externals
20
+ ?.filter((ext) => ext.type === 'parent')
21
+ .reduce((sum, ext) => sum + ext.items.length, 0);
22
+ });
23
+ </script>
24
+
25
+ <template>
26
+ <section v-if="connections" class="px-main py-main-half">
27
+ <MainSubTitle :title="phrase.connections + ':'" />
28
+ <div
29
+ class="gap-small micro:gap-normal micro:justify-start flex flex-wrap
30
+ justify-center"
31
+ >
32
+ <template
33
+ v-for="(items, type) of {
34
+ hardDependencies: connections.hardDependencies,
35
+ autoDependencies: connections.autoDependencies,
36
+ dependents: connections.dependents,
37
+ }"
38
+ >
39
+ <MainConnectionsButton
40
+ v-if="items && items.length > 0"
41
+ :type="type"
42
+ :count="items.length"
43
+ :active="currentType === type"
44
+ @click="
45
+ currentType === type
46
+ ? (currentType = undefined)
47
+ : (currentType = type)
48
+ "
49
+ />
50
+ </template>
51
+ <MainConnectionsButton
52
+ v-if="connections.externals"
53
+ type="externals"
54
+ :active="currentType === 'externals'"
55
+ @click="
56
+ currentType === 'externals'
57
+ ? (currentType = undefined)
58
+ : (currentType = 'externals')
59
+ "
60
+ >
61
+ <template #after>
62
+ <div
63
+ v-if="connections.externals"
64
+ class="gap-small *:border-border *:pl-small flex
65
+ items-center font-bold *:border-l"
66
+ >
67
+ <div
68
+ v-if="ownExternalsCount"
69
+ class="flex items-center gap-1 text-amber-600
70
+ dark:text-amber-400"
71
+ >
72
+ <MyIcon name="arrow/left" class="-scale-x-100" />
73
+ <span>{{ ownExternalsCount }}</span>
74
+ </div>
75
+ <div
76
+ v-if="parentExternalsCount"
77
+ class="flex items-center gap-1"
78
+ >
79
+ <MyIcon name="arrow/up-to-right" />
80
+ <span>{{ parentExternalsCount }}</span>
81
+ </div>
82
+ </div>
83
+ </template>
84
+ </MainConnectionsButton>
85
+ </div>
86
+ <template v-if="currentType && connections[currentType]">
87
+ <Deps
88
+ v-if="currentType !== 'externals'"
89
+ :deps="connections[currentType]!"
90
+ />
91
+ <Externals v-else :externals="connections[currentType]!" />
92
+ </template>
93
+ </section>
94
+ </template>
@@ -0,0 +1,81 @@
1
+ <script lang="ts" setup>
2
+ import type { MyIconName } from '#my-icons';
3
+
4
+ const { type, active } = defineProps<{
5
+ type: 'hardDependencies' | 'autoDependencies' | 'dependents' | 'externals';
6
+ active?: boolean;
7
+ count?: number;
8
+ }>();
9
+
10
+ const isHard = type === 'hardDependencies';
11
+
12
+ const phrase = await usePhrases(
13
+ 'need_to_know',
14
+ 'depends_on',
15
+ 'used_by',
16
+ 'externals',
17
+ );
18
+
19
+ const title = (() => {
20
+ switch (type) {
21
+ case 'hardDependencies':
22
+ return phrase.need_to_know;
23
+ case 'autoDependencies':
24
+ return phrase.depends_on;
25
+ case 'dependents':
26
+ return phrase.used_by;
27
+ case 'externals':
28
+ return phrase.externals;
29
+ }
30
+ })();
31
+
32
+ const icon: MyIconName = (() => {
33
+ switch (type) {
34
+ case 'hardDependencies':
35
+ return 'warning';
36
+ case 'autoDependencies':
37
+ return 'arrow/to-circle';
38
+ case 'dependents':
39
+ return 'arrow/from-circle';
40
+ case 'externals':
41
+ return 'arrow/outward-box';
42
+ }
43
+ })();
44
+
45
+ const dynamicClasses = computed(() => {
46
+ if (isHard) {
47
+ if (active) {
48
+ return 'border-(--activeColor) text-(--activeColor) bg-(--activeColor)/10 hocus:ring-(--activeColor)/25';
49
+ } else {
50
+ return 'border-border bg-bg-aside text-text-muted hocus:ring-(--activeColor)/25 hocus:text-(--activeColor) hocus:border-(--activeColor)';
51
+ }
52
+ }
53
+
54
+ if (active) {
55
+ return 'border-(--activeColor) text-(--activeColor) bg-(--activeColor)/10 hocus:ring-(--activeColor)/25';
56
+ } else {
57
+ return 'border-border bg-bg-aside text-text-muted hocus:ring-(--activeColor)/25 hocus:text-(--activeColor) hocus:border-(--activeColor)';
58
+ }
59
+ });
60
+ </script>
61
+
62
+ <template>
63
+ <button
64
+ :style="{
65
+ '--activeColor': isHard
66
+ ? 'light-dark(var(--color-red-700),var(--color-red-400))'
67
+ : 'var(--color-brand)',
68
+ }"
69
+ :class="[
70
+ `gap-small text-main-sm px-small flex cursor-pointer items-center
71
+ rounded border py-1 ring-2 ring-transparent
72
+ transition-[border,color,box-shadow,background]`,
73
+ dynamicClasses,
74
+ ]"
75
+ >
76
+ <MyIcon :name="icon" class="text-[1.2em]" />
77
+ <span>{{ formatText(title) }}</span>
78
+ <span v-if="count" class="font-bold">{{ count }}</span>
79
+ <slot name="after"></slot>
80
+ </button>
81
+ </template>
@@ -0,0 +1,10 @@
1
+ <script lang="ts" setup></script>
2
+
3
+ <template>
4
+ <div
5
+ class="nice-scrollbars border-border mt-normal relative overflow-auto
6
+ border-t border-b"
7
+ >
8
+ <slot></slot>
9
+ </div>
10
+ </template>
@@ -0,0 +1,34 @@
1
+ <script lang="ts" setup>
2
+ const { mode = 'detailed' } = defineProps<{
3
+ mode?: 'compact' | 'detailed';
4
+ icon: string;
5
+ label: string;
6
+ count: number;
7
+ }>();
8
+ </script>
9
+
10
+ <template>
11
+ <div
12
+ v-if="mode === 'compact'"
13
+ :title="label"
14
+ class="gap-small flex cursor-help items-center"
15
+ >
16
+ <MaybeMyIcon
17
+ :name="icon"
18
+ class="text-text-dimmed -mr-0.5 text-[1.2em]"
19
+ />
20
+ <span class="text-text-muted font-bold">{{ count }}</span>
21
+ </div>
22
+ <div
23
+ v-else
24
+ class="gap-small px-small text-main-sm border-border bg-bg-aside flex
25
+ items-center rounded-xl border py-1"
26
+ >
27
+ <MaybeMyIcon
28
+ :name="icon"
29
+ class="text-text-dimmed -mr-0.5 text-[1.2em]"
30
+ />
31
+ <span class="text-text-muted">{{ label }}</span>
32
+ <span class="text-text-muted font-bold">{{ count }}</span>
33
+ </div>
34
+ </template>
@@ -0,0 +1,19 @@
1
+ <script lang="ts" setup>
2
+ import Item from './Item.vue';
3
+
4
+ const { schemaName } = defineProps<{
5
+ schemaName: string;
6
+ count: number;
7
+ }>();
8
+
9
+ const elementIcon = await getElementIcon(schemaName);
10
+ const elementPhrase = await getElementPhrase(schemaName);
11
+ </script>
12
+
13
+ <template>
14
+ <Item
15
+ :icon="elementIcon"
16
+ :label="elementPhrase.element_name"
17
+ :count="count"
18
+ />
19
+ </template>
@@ -0,0 +1,11 @@
1
+ <script lang="ts" setup>
2
+ import Item from './Item.vue';
3
+
4
+ defineProps<{ count: number }>();
5
+
6
+ const phrase = await usePhrases('materials');
7
+ </script>
8
+
9
+ <template>
10
+ <Item icon="files" :label="phrase.materials" :count="count" />
11
+ </template>
@@ -0,0 +1,53 @@
1
+ <script lang="ts" setup>
2
+ import ItemElement from './ItemElement.vue';
3
+ import ItemMaterials from './ItemMaterials.vue';
4
+
5
+ defineProps<{
6
+ mode: 'single' | 'children';
7
+ stats?: ContentStats;
8
+ }>();
9
+
10
+ const phrase = await usePhrases('stats');
11
+ </script>
12
+
13
+ <template>
14
+ <template v-if="stats">
15
+ <section v-if="mode === 'single'" class="px-main py-main-half">
16
+ <MainSubTitle :title="phrase.stats + ':'" />
17
+ <div
18
+ class="micro:justify-start gap-small micro:gap-normal flex
19
+ flex-wrap justify-center"
20
+ >
21
+ <ItemMaterials
22
+ v-if="stats.materials"
23
+ :count="stats.materials"
24
+ mode="detailed"
25
+ />
26
+ <ItemElement
27
+ v-if="stats.elements"
28
+ v-for="(count, schemaName) of stats.elements"
29
+ :schemaName
30
+ :count
31
+ mode="detailed"
32
+ />
33
+ </div>
34
+ </section>
35
+ <div
36
+ v-else
37
+ class="gap-small micro:gap-normal text-main-sm flex flex-wrap"
38
+ >
39
+ <ItemMaterials
40
+ v-if="stats.materials"
41
+ :count="stats.materials"
42
+ mode="compact"
43
+ />
44
+ <ItemElement
45
+ v-if="stats.elements"
46
+ v-for="(count, schemaName) of stats.elements"
47
+ :schemaName
48
+ :count
49
+ mode="compact"
50
+ />
51
+ </div>
52
+ </template>
53
+ </template>
@@ -1,186 +1,172 @@
1
- <script lang="ts" setup>
2
- import type { PreviewRequest } from '@app/scripts/preview/request';
3
- import {
4
- closePreview,
5
- previewBlinkTrigger,
6
- previewRequest,
7
- previewTheme,
8
- previewVisible,
9
- unsetPreviewTheme,
10
- } from '@app/scripts/preview/state';
11
-
12
- import PreviewScreen from './PreviewScreen.vue';
13
-
14
- const height = ref<number>(0);
15
- const request = shallowRef<PreviewRequest>();
16
- const screenKey = ref(0); // Need to change this every time for Vue transition to work
17
- const route = useRoute();
18
-
19
- watch(previewRequest, () => {
20
- if (previewRequest.value) {
21
- request.value = structuredClone(toRaw(previewRequest.value));
22
- unsetPreviewTheme();
23
- screenKey.value++;
24
- }
25
- });
26
-
27
- watch(
28
- () => route.path,
29
- () => {
30
- closePreview();
31
- },
32
- );
33
- </script>
34
-
35
- <template>
36
- <div :class="$style.previewSticky">
37
- <div :class="$style.previewOverlay">
38
- <section
39
- :class="[$style.preview, previewVisible && $style.visible]"
40
- :style="{
41
- '--_previewHeightInner': `min(${height}px, var(--_previewMaxHeight))`,
42
- }"
43
- :data-erudit-preview-theme="previewTheme"
44
- >
45
- <TransitionFade>
46
- <PreviewScreen
47
- v-if="request"
48
- :request
49
- :key="screenKey"
50
- v-model:height="height"
51
- />
52
- </TransitionFade>
53
- <div
54
- :key="previewBlinkTrigger"
55
- :class="$style.blinkOverlay"
56
- ></div>
57
- </section>
58
- </div>
59
- </div>
60
- </template>
61
-
62
- <style lang="scss" module>
63
- @use '$/def/z';
64
- @use '$/def/bp';
65
-
66
- .previewSticky {
67
- position: sticky;
68
- top: 0;
69
- z-index: z.$preview;
70
- }
71
-
72
- .previewOverlay {
73
- position: absolute;
74
- top: 0;
75
- width: 100%;
76
- height: 100dvh;
77
- //background: rgba(255, 0, 0, 0.121);
78
- overflow: hidden;
79
- pointer-events: none;
80
- touch-action: none;
81
- }
82
-
83
- .preview {
84
- --previewBorderRadius: 15px;
85
-
86
- --_previewMaxHeight: 70dvh;
87
- --_previewHeightInner: 0px;
88
- --_previewHeight: calc(var(--_previewHeightInner) + 1px /* Top border */);
89
-
90
- pointer-events: initial;
91
- touch-action: initial;
92
-
93
- overflow: hidden;
94
-
95
- position: absolute;
96
- bottom: 0;
97
- height: var(--_previewHeight);
98
- max-height: var(--_previewMaxHeight);
99
- width: 100%;
100
- background: var(--_previewThemeBg, var(--bgAside));
101
-
102
- border: 1px solid var(--_previewThemeBorder, var(--border));
103
- border-bottom: none;
104
- border-top-left-radius: var(--previewBorderRadius);
105
- border-top-right-radius: var(--previewBorderRadius);
106
-
107
- box-shadow: 0px -10px 12px 0px
108
- light-dark(rgba(black, 0.11), rgba(white, 0.03));
109
-
110
- @include transition(bottom, height, box-shadow, background);
111
-
112
- @media (max-height: 500px) {
113
- --_previewMaxHeight: 85dvh;
114
- }
115
-
116
- @include bp.below('aside2') {
117
- border-right: transparent;
118
- }
119
- @include bp.below('aside1') {
120
- border-left: transparent;
121
- }
122
-
123
- &:not(.visible) {
124
- bottom: calc(-1 * var(--_previewHeight));
125
- box-shadow: none;
126
- overflow: hidden;
127
- }
128
- }
129
-
130
- .blinkOverlay {
131
- position: absolute;
132
- z-index: 1000;
133
- top: 0;
134
- left: 0;
135
- width: 100%;
136
- height: 100%;
137
- pointer-events: none;
138
- touch-action: none;
139
- background: var(--brand);
140
- opacity: 0;
141
- animation: blink 0.5s ease-out;
142
- }
143
-
144
- @keyframes blink {
145
- 0% {
146
- opacity: 0;
147
- }
148
- 50% {
149
- opacity: 0.6;
150
- }
151
- 100% {
152
- opacity: 0;
153
- }
154
- }
155
-
156
- //
157
- // Themes
158
- //
159
-
160
- .preview {
161
- --_previewThemeBg: var(--bgAside);
162
- --_previewThemeBorder: var(--border);
163
- --_previewThemeText: var(--text);
164
-
165
- @mixin previewTheme($themeName, $baseColor) {
166
- &[data-erudit-preview-theme='#{$themeName}'] {
167
- --_previewThemeBg: color-mix(
168
- in srgb,
169
- #{$baseColor},
170
- var(--bgAside) 92%
171
- );
172
- --_previewThemeBorder: color-mix(
173
- in srgb,
174
- #{$baseColor},
175
- var(--border) 80%
176
- );
177
- --_previewThemeText: #{$baseColor};
178
- }
179
- }
180
-
181
- @include previewTheme(error, var(--error));
182
- @include previewTheme(warn, var(--warn));
183
- @include previewTheme(success, var(--success));
184
- @include previewTheme(brand, var(--brand));
185
- }
186
- </style>
1
+ <script lang="ts" setup>
2
+ import type { PreviewType } from '@erudit-js/core/preview/type';
3
+ import type { PreviewRequest } from '@erudit-js/core/preview/request';
4
+
5
+ import {
6
+ LazyPreviewScreenContentPage,
7
+ LazyPreviewScreenDirectLink,
8
+ LazyPreviewScreenUnique,
9
+ } from '#components';
10
+
11
+ const previewElement = useTemplateRef('preview');
12
+ const previewScreenElement = useTemplateRef('previewScreen');
13
+ const { previewState, closePreview } = usePreview();
14
+ const route = useRoute();
15
+
16
+ const screenKey = ref(0);
17
+ const loading = ref(true);
18
+
19
+ const screenComponents: Record<PreviewType, Component> = {
20
+ ['direct-link']: LazyPreviewScreenDirectLink,
21
+ ['content-page']: LazyPreviewScreenContentPage,
22
+ ['unique']: LazyPreviewScreenUnique,
23
+ };
24
+
25
+ const currentRequest = shallowRef<PreviewRequest>();
26
+ const CurrentScreen = shallowRef<Component>();
27
+
28
+ const LOADING_FALLBACK_HEIGHT = 200;
29
+ const lastHeight = ref(LOADING_FALLBACK_HEIGHT);
30
+ let resizeObserver: ResizeObserver;
31
+
32
+ watch(() => route.path, closePreview);
33
+
34
+ watch(
35
+ () => previewState.value.request,
36
+ (newRequest) => {
37
+ if (newRequest === undefined) {
38
+ // Still render last request for nice closing animation
39
+ return;
40
+ }
41
+
42
+ lastHeight.value =
43
+ previewElement.value?.offsetHeight || lastHeight.value;
44
+
45
+ currentRequest.value = newRequest;
46
+ CurrentScreen.value = screenComponents[newRequest.type];
47
+
48
+ screenKey.value++;
49
+ loading.value = true;
50
+
51
+ // Lock height during loading so it does not collapse
52
+ if (previewElement.value) {
53
+ previewElement.value.style.height = `${Math.max(lastHeight.value, LOADING_FALLBACK_HEIGHT)}px`;
54
+ }
55
+ },
56
+ );
57
+
58
+ function updatePreviewHeight() {
59
+ if (!previewElement.value) return;
60
+
61
+ // While loading, keep previous (or fallback) height
62
+ if (loading.value) {
63
+ previewElement.value.style.height = `${Math.max(lastHeight.value, LOADING_FALLBACK_HEIGHT)}px`;
64
+ return;
65
+ }
66
+
67
+ if (previewScreenElement.value) {
68
+ const h = previewScreenElement.value.offsetHeight;
69
+ previewElement.value.style.height = `${h}px`;
70
+ if (h > 0) {
71
+ lastHeight.value = h;
72
+ }
73
+ }
74
+ }
75
+
76
+ async function nextPaint() {
77
+ await nextTick();
78
+ await new Promise(requestAnimationFrame);
79
+ }
80
+
81
+ async function suspenseResolved() {
82
+ await nextPaint();
83
+ updatePreviewHeight();
84
+ resizeObserver ||= new ResizeObserver(updatePreviewHeight);
85
+ resizeObserver.disconnect();
86
+ resizeObserver.observe(previewScreenElement.value!);
87
+
88
+ await nextPaint();
89
+ loading.value = false;
90
+
91
+ await nextPaint();
92
+ updatePreviewHeight();
93
+ }
94
+
95
+ // Prefetch phrases
96
+ await usePhrases(
97
+ 'book',
98
+ 'page',
99
+ 'group',
100
+ 'topic',
101
+ 'article',
102
+ 'summary',
103
+ 'practice',
104
+ 'preview_content_page_description',
105
+ );
106
+ </script>
107
+
108
+ <template>
109
+ <div class="sticky top-0 z-100">
110
+ <div
111
+ class="pointer-events-none absolute top-0 right-0 left-0 h-dvh
112
+ touch-none"
113
+ >
114
+ <div
115
+ ref="preview"
116
+ :class="[
117
+ `border-border bg-bg-main micro:max-h-[70dvh]
118
+ pointer-events-auto absolute bottom-0 max-h-[90dvh] w-full
119
+ touch-auto overflow-hidden rounded-[25px] rounded-b-none
120
+ border-t transition-[max-height,height,translate]`,
121
+ previewState.opened
122
+ ? `translate-y-0
123
+ shadow-[0px_-10px_15px_5px_light-dark(rgba(0,0,0,0.1),rgba(255,255,255,0.05))]`
124
+ : 'translate-y-full shadow-none',
125
+ ]"
126
+ >
127
+ <!-- Screen -->
128
+ <TransitionFade>
129
+ <div
130
+ v-if="CurrentScreen"
131
+ :key="screenKey"
132
+ ref="previewScreen"
133
+ class="absolute bottom-0 max-h-[inherit] w-full"
134
+ >
135
+ <Suspense @resolve="suspenseResolved">
136
+ <CurrentScreen :request="currentRequest" />
137
+ </Suspense>
138
+ </div>
139
+ </TransitionFade>
140
+
141
+ <!-- Loading overlay -->
142
+ <TransitionFade>
143
+ <div
144
+ v-if="loading"
145
+ class="bg-bg-main absolute bottom-0 flex h-full w-full
146
+ items-center justify-center"
147
+ >
148
+ <MyRuntimeIcon
149
+ :svg="loadingSvg"
150
+ class="text-text-dimmed text-[50px]"
151
+ />
152
+ </div>
153
+ </TransitionFade>
154
+
155
+ <!-- Blink overlay -->
156
+ <TransitionFade>
157
+ <div
158
+ v-if="previewState.blink"
159
+ :key="previewState.blink"
160
+ class="pointer-events-none absolute top-0 left-0 h-full
161
+ w-full touch-none"
162
+ >
163
+ <div
164
+ class="bg-brand animate-opacity-blink absolute top-0
165
+ left-0 h-full w-full opacity-0"
166
+ ></div>
167
+ </div>
168
+ </TransitionFade>
169
+ </div>
170
+ </div>
171
+ </div>
172
+ </template>