@simple-reporting/base 0.1.111 → 0.1.112
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.
- package/.github/workflows/npm-publish.yml +25 -25
- package/.nvmrc +1 -1
- package/README.md +23 -23
- package/cli.js +114 -114
- package/dev/.ddev/nginx_full/custom.conf +12 -12
- package/dev/index.html +17 -17
- package/dev/ldd.html +7 -7
- package/dev/livingdocs/Media/image/app.scss +25 -25
- package/dev/livingdocs/Media/image/general.scss +11 -11
- package/dev/livingdocs/Media/image/image.html +46 -46
- package/dev/livingdocs/Media/image/ldd.scss +1 -1
- package/dev/livingdocs/Media/image/pdf.scss +1 -1
- package/dev/livingdocs/Media/image/print.scss +7 -7
- package/dev/livingdocs/Media/image/properties.json +41 -41
- package/dev/livingdocs/Media/image/word.scss +1 -1
- package/dev/livingdocs/Properties/grid/app.scss +1 -1
- package/dev/livingdocs/Properties/grid/general.scss +95 -95
- package/dev/livingdocs/Properties/grid/ldd.scss +1 -1
- package/dev/livingdocs/Properties/grid/pdf.scss +1 -1
- package/dev/livingdocs/Properties/grid/print.scss +94 -94
- package/dev/livingdocs/Properties/grid/properties.json +68 -68
- package/dev/livingdocs/Properties/grid/web.scss +98 -98
- package/dev/livingdocs/Properties/grid/word.scss +1 -1
- package/dev/livingdocs/Text/paragraph/general.scss +9 -9
- package/dev/livingdocs/Text/paragraph/paragraph.html +22 -22
- package/dev/livingdocs/Titles/title-h1/general.scss +10 -10
- package/dev/livingdocs/Titles/title-h1/title-h1.html +16 -16
- package/dev/livingdocs/Titles/title-h2/app.scss +1 -1
- package/dev/livingdocs/Titles/title-h2/general.scss +13 -13
- package/dev/livingdocs/Titles/title-h2/ldd.scss +1 -1
- package/dev/livingdocs/Titles/title-h2/pdf.scss +1 -1
- package/dev/livingdocs/Titles/title-h2/print.scss +36 -36
- package/dev/livingdocs/Titles/title-h2/title-h2.html +24 -24
- package/dev/livingdocs/Titles/title-h2/web.scss +27 -27
- package/dev/livingdocs/Titles/title-h2/word.scss +1 -1
- package/dev/livingdocs/Titles/title-h3/app.scss +1 -1
- package/dev/livingdocs/Titles/title-h3/general.scss +13 -13
- package/dev/livingdocs/Titles/title-h3/ldd.scss +1 -1
- package/dev/livingdocs/Titles/title-h3/pdf.scss +1 -1
- package/dev/livingdocs/Titles/title-h3/print.scss +34 -34
- package/dev/livingdocs/Titles/title-h3/title-h3.html +24 -24
- package/dev/livingdocs/Titles/title-h3/web.scss +27 -27
- package/dev/livingdocs/Titles/title-h3/word.scss +1 -1
- package/dev/livingdocs/Titles/title-h4/app.scss +1 -1
- package/dev/livingdocs/Titles/title-h4/general.scss +13 -13
- package/dev/livingdocs/Titles/title-h4/ldd.scss +1 -1
- package/dev/livingdocs/Titles/title-h4/pdf.scss +1 -1
- package/dev/livingdocs/Titles/title-h4/print.scss +34 -34
- package/dev/livingdocs/Titles/title-h4/title-h4.html +24 -24
- package/dev/livingdocs/Titles/title-h4/web.scss +27 -27
- package/dev/livingdocs/Titles/title-h4/word.scss +1 -1
- package/dev/livingdocs/Titles/title-h5/general.scss +10 -10
- package/dev/livingdocs/Titles/title-h5/title-h5.html +16 -16
- package/dev/livingdocs/Titles/title-h6/general.scss +10 -10
- package/dev/livingdocs/Titles/title-h6/title-h6.html +16 -16
- package/dev/livingdocs.config.json +376 -376
- package/dev/nswow/ArticleAutoloader.ts +100 -100
- package/dev/nswow/ArticleLoader.ts +91 -91
- package/dev/nswow/colors.scss +3 -3
- package/dev/nswow/config.scss +13 -13
- package/dev/nswow/core-styles.scss +2 -2
- package/dev/nswow/fonts.scss +2 -2
- package/dev/nswow/grid.scss +2 -2
- package/dev/nswow/helpers.scss +2 -2
- package/dev/nswow/index.scss +9 -9
- package/dev/nswow/meta.scss +2 -2
- package/dev/nswow/spacer.scss +2 -2
- package/dev/nswow/system.scss +2 -2
- package/dev/nswow/typography.scss +3 -3
- package/dev/nswow.config.json +293 -293
- package/dev/package.json +61 -60
- package/dev/pdf/pdf-configuration-debug.xml +5 -5
- package/dev/pdf/pdf-configuration.xml +2 -2
- package/dev/pdf.ts +1 -1
- package/dev/src/App.vue +44 -44
- package/dev/src/Autoload.ts +6 -6
- package/dev/src/assets/images/mms-logo-black.svg +91 -91
- package/dev/src/assets/images/mms-logo-white.svg +105 -105
- package/dev/src/assets/scss/app.scss +39 -39
- package/dev/src/assets/scss/general.scss +17 -17
- package/dev/src/assets/scss/ldd.scss +27 -27
- package/dev/src/assets/scss/pdf.scss +2 -2
- package/dev/src/assets/scss/print.scss +1 -1
- package/dev/src/assets/scss/web.scss +1 -1
- package/dev/src/assets/scss/word.scss +2 -2
- package/dev/src/components/LanguageSwitch.vue +100 -100
- package/dev/src/components/MainNavigation.vue +209 -209
- package/dev/src/components/MenuItem/MenuArticle.vue +15 -15
- package/dev/src/components/MenuItem/MenuEntry.vue +26 -26
- package/dev/src/components/MenuItem/MenuExternal.vue +28 -28
- package/dev/src/components/MenuItem/index.ts +5 -5
- package/dev/src/components/PageFooter.vue +86 -86
- package/dev/src/components/PageHeader.vue +149 -149
- package/dev/src/components/PageModal.vue +95 -95
- package/dev/src/components/PrevNext.vue +144 -144
- package/dev/src/components/ScrollToTop.vue +63 -63
- package/dev/src/components/SrlPage/KFCApplication/hooks/kfcData.ts +9 -9
- package/dev/src/components/SrlPage/KFCApplication/scss/_iz-keyfigure-comparison.scss +151 -151
- package/dev/src/components/SrlPage/KFCApplication/scss/_kfc-loading.scss +40 -40
- package/dev/src/components/SrlPage/KFCApplication/scss/_srl-button-kfc.scss +21 -21
- package/dev/src/composables/config.ts +48 -48
- package/dev/src/i18n/index.ts +51 -51
- package/dev/src/i18n/translation.ts +85 -85
- package/dev/src/locales/de.json +15 -15
- package/dev/src/locales/en.json +15 -15
- package/dev/src/main.ts +16 -16
- package/dev/src/router/index.ts +47 -47
- package/dev/src/types/nswow.d.ts +73 -73
- package/dev/src/views/ArticleView.vue +77 -77
- package/dev/src/views/DownloadsView.vue +88 -88
- package/dev/src/views/HomeView.vue +35 -35
- package/dev/src/views/PageNotFound.vue +73 -73
- package/dev/src/views/SearchView.vue +126 -126
- package/dev/tsconfig.app.json +16 -16
- package/dev/tsconfig.node.json +19 -19
- package/dev/vite.config.ts +27 -27
- package/dev/word.ts +1 -1
- package/livingdocs/Buttons/button/app.scss +1 -1
- package/livingdocs/Buttons/button/button.html +18 -18
- package/livingdocs/Buttons/button/general.scss +33 -33
- package/livingdocs/Buttons/button/ldd.scss +1 -1
- package/livingdocs/Buttons/button/pdf.scss +1 -1
- package/livingdocs/Buttons/button/word.scss +1 -1
- package/livingdocs/Buttons/button-container/app.scss +1 -1
- package/livingdocs/Buttons/button-container/button-container.html +31 -31
- package/livingdocs/Buttons/button-container/general.scss +12 -12
- package/livingdocs/Buttons/button-container/ldd.scss +1 -1
- package/livingdocs/Buttons/button-container/pdf.scss +3 -3
- package/livingdocs/Buttons/button-container/properties.json +19 -19
- package/livingdocs/Buttons/button-container/word.scss +3 -3
- package/livingdocs/CV/cv-timeline/app.scss +1 -1
- package/livingdocs/CV/cv-timeline/cv-timeline.html +19 -19
- package/livingdocs/CV/cv-timeline/general.scss +1 -1
- package/livingdocs/CV/cv-timeline/ldd.scss +1 -1
- package/livingdocs/CV/cv-timeline/pdf.scss +1 -1
- package/livingdocs/CV/cv-timeline/print.scss +35 -35
- package/livingdocs/CV/cv-timeline/web.scss +27 -27
- package/livingdocs/CV/cv-timeline/word.scss +1 -1
- package/livingdocs/Container/column-container/column-container.html +44 -44
- package/livingdocs/Container/column-container/general.scss +105 -105
- package/livingdocs/Container/column-container/properties.json +83 -83
- package/livingdocs/Lists/alphanumeric-list-group/alphanumeric-list-group.html +25 -25
- package/livingdocs/Lists/alphanumeric-list-group/app.scss +1 -1
- package/livingdocs/Lists/alphanumeric-list-group/general.scss +5 -5
- package/livingdocs/Lists/alphanumeric-list-group/ldd.scss +1 -1
- package/livingdocs/Lists/alphanumeric-list-group/pdf.scss +1 -1
- package/livingdocs/Lists/alphanumeric-list-group/word.scss +1 -1
- package/livingdocs/Lists/list-item/app.scss +1 -1
- package/livingdocs/Lists/list-item/general.scss +4 -4
- package/livingdocs/Lists/list-item/ldd.scss +1 -1
- package/livingdocs/Lists/list-item/list-item.html +17 -17
- package/livingdocs/Lists/list-item/pdf.scss +1 -1
- package/livingdocs/Lists/list-item/word.scss +1 -1
- package/livingdocs/Lists/ordered-list-group/app.scss +1 -1
- package/livingdocs/Lists/ordered-list-group/general.scss +5 -5
- package/livingdocs/Lists/ordered-list-group/ldd.scss +1 -1
- package/livingdocs/Lists/ordered-list-group/ordered-list-group.html +25 -25
- package/livingdocs/Lists/ordered-list-group/pdf.scss +1 -1
- package/livingdocs/Lists/ordered-list-group/word.scss +1 -1
- package/livingdocs/Lists/unordered-list-group/app.scss +1 -1
- package/livingdocs/Lists/unordered-list-group/general.scss +5 -5
- package/livingdocs/Lists/unordered-list-group/ldd.scss +1 -1
- package/livingdocs/Lists/unordered-list-group/pdf.scss +1 -1
- package/livingdocs/Lists/unordered-list-group/unordered-list-group.html +25 -25
- package/livingdocs/Lists/unordered-list-group/word.scss +1 -1
- package/livingdocs/Media/chart/app.scss +19 -19
- package/livingdocs/Media/chart/chart.html +29 -29
- package/livingdocs/Media/chart/general.scss +11 -11
- package/livingdocs/Media/chart/ldd.scss +1 -1
- package/livingdocs/Media/chart/pdf.scss +9 -9
- package/livingdocs/Media/chart/properties.json +41 -41
- package/livingdocs/Media/chart/word.scss +1 -1
- package/livingdocs/Media/graphic/app.scss +1 -1
- package/livingdocs/Media/graphic/general.scss +18 -18
- package/livingdocs/Media/graphic/graphic.html +29 -29
- package/livingdocs/Media/graphic/ldd.scss +1 -1
- package/livingdocs/Media/graphic/pdf.scss +1 -1
- package/livingdocs/Media/graphic/properties.json +36 -36
- package/livingdocs/Media/graphic/word.scss +1 -1
- package/livingdocs/Media/image/app.scss +25 -25
- package/livingdocs/Media/image/general.scss +11 -11
- package/livingdocs/Media/image/image.html +55 -55
- package/livingdocs/Media/image/ldd.scss +1 -1
- package/livingdocs/Media/image/pdf.scss +1 -1
- package/livingdocs/Media/image/print.scss +7 -7
- package/livingdocs/Media/image/properties.json +41 -41
- package/livingdocs/Media/image/word.scss +1 -1
- package/livingdocs/Media/nswow-table/app.scss +2 -2
- package/livingdocs/Media/nswow-table/app.ts +35 -35
- package/livingdocs/Media/nswow-table/general.scss +281 -281
- package/livingdocs/Media/nswow-table/ldd.scss +2 -2
- package/livingdocs/Media/nswow-table/nswow-table.html +30 -30
- package/livingdocs/Media/nswow-table/pdf.scss +8 -8
- package/livingdocs/Media/nswow-table/properties.json +66 -66
- package/livingdocs/Media/nswow-table/web.scss +23 -23
- package/livingdocs/Media/nswow-table/word.scss +2 -2
- package/livingdocs/Media/video/app.scss +1 -1
- package/livingdocs/Media/video/general.scss +7 -7
- package/livingdocs/Media/video/ldd.scss +1 -1
- package/livingdocs/Media/video/pdf.scss +1 -1
- package/livingdocs/Media/video/print.scss +5 -5
- package/livingdocs/Media/video/properties.json +41 -41
- package/livingdocs/Media/video/video.html +26 -26
- package/livingdocs/Media/video/word.scss +1 -1
- package/livingdocs/Misc/accordion/accordion.html +56 -56
- package/livingdocs/Misc/accordion/app.scss +63 -63
- package/livingdocs/Misc/accordion/app.ts +10 -10
- package/livingdocs/Misc/accordion/general.scss +44 -44
- package/livingdocs/Misc/accordion/ldd.scss +36 -36
- package/livingdocs/Misc/accordion/pdf.scss +39 -39
- package/livingdocs/Misc/accordion/word.scss +39 -39
- package/livingdocs/Misc/anchor/anchor.html +15 -15
- package/livingdocs/Misc/anchor/app.scss +10 -10
- package/livingdocs/Misc/anchor/app.ts +11 -11
- package/livingdocs/Misc/anchor/general.scss +1 -1
- package/livingdocs/Misc/anchor/pdf.scss +1 -1
- package/livingdocs/Misc/anchor/print.scss +3 -3
- package/livingdocs/Misc/anchor/word.scss +1 -1
- package/livingdocs/Misc/spacer/app.scss +1 -1
- package/livingdocs/Misc/spacer/general.scss +8 -8
- package/livingdocs/Misc/spacer/ldd.scss +1 -1
- package/livingdocs/Misc/spacer/pdf.scss +1 -1
- package/livingdocs/Misc/spacer/print.scss +18 -18
- package/livingdocs/Misc/spacer/properties.json +52 -52
- package/livingdocs/Misc/spacer/spacer.html +12 -12
- package/livingdocs/Misc/spacer/web.scss +18 -18
- package/livingdocs/Misc/spacer/word.scss +1 -1
- package/livingdocs/PDF_only/pdf-cover/ldd.scss +42 -42
- package/livingdocs/PDF_only/pdf-cover/pdf-cover.html +29 -29
- package/livingdocs/PDF_only/pdf-cover/pdf.scss +1 -1
- package/livingdocs/PDF_only/pdf-cover/word.scss +1 -1
- package/livingdocs/PDF_only/pdf-cover-chapter/ldd.scss +19 -19
- package/livingdocs/PDF_only/pdf-cover-chapter/pdf-chapter-cover.html +18 -18
- package/livingdocs/PDF_only/pdf-cover-chapter/pdf.scss +1 -1
- package/livingdocs/PDF_only/pdf-cover-chapter/print.scss +19 -19
- package/livingdocs/PDF_only/pdf-cover-chapter/word.scss +1 -1
- package/livingdocs/PDF_only/pdf-pagebreak/general.scss +4 -4
- package/livingdocs/PDF_only/pdf-pagebreak/ldd.scss +5 -5
- package/livingdocs/PDF_only/pdf-pagebreak/pdf-pagebreak.html +8 -8
- package/livingdocs/PDF_only/pdf-publication-title/general.scss +5 -5
- package/livingdocs/PDF_only/pdf-publication-title/pdf-publication-title.html +15 -15
- package/livingdocs/PDF_only/pdf-toc-item/general.scss +41 -41
- package/livingdocs/PDF_only/pdf-toc-item/pdf-toc-item.html +33 -33
- package/livingdocs/PDF_only/pdf-toc-item/properties.json +7 -7
- package/livingdocs/PDF_only/pdf-toc-item-blank/general.scss +5 -5
- package/livingdocs/PDF_only/pdf-toc-item-blank/pdf-toc-item-blank.html +11 -11
- package/livingdocs/PDF_only/pdf-toc-item-title/general.scss +5 -5
- package/livingdocs/PDF_only/pdf-toc-item-title/pdf-toc-item-title.html +11 -11
- package/livingdocs/PDF_only/pdf-toc-page/app.scss +1 -1
- package/livingdocs/PDF_only/pdf-toc-page/general.scss +1 -1
- package/livingdocs/PDF_only/pdf-toc-page/ldd.scss +1 -1
- package/livingdocs/PDF_only/pdf-toc-page/pdf-toc-page.html +33 -33
- package/livingdocs/PDF_only/pdf-toc-page/pdf.scss +1 -1
- package/livingdocs/PDF_only/pdf-toc-page/properties.json +12 -12
- package/livingdocs/PDF_only/pdf-toc-page/word.scss +1 -1
- package/livingdocs/PDF_only/pdf-video-link/ldd.scss +16 -16
- package/livingdocs/PDF_only/pdf-video-link/pdf-video-link.html +41 -41
- package/livingdocs/PDF_only/pdf-video-link/pdf.scss +1 -1
- package/livingdocs/PDF_only/pdf-video-link/print.scss +12 -12
- package/livingdocs/PDF_only/pdf-video-link/word.scss +1 -1
- package/livingdocs/Properties/grid/app.scss +1 -1
- package/livingdocs/Properties/grid/general.scss +95 -95
- package/livingdocs/Properties/grid/ldd.scss +1 -1
- package/livingdocs/Properties/grid/pdf.scss +1 -1
- package/livingdocs/Properties/grid/print.scss +94 -94
- package/livingdocs/Properties/grid/properties.json +68 -68
- package/livingdocs/Properties/grid/web.scss +98 -98
- package/livingdocs/Properties/grid/word.scss +1 -1
- package/livingdocs/Signatures/signature-container/app.scss +1 -1
- package/livingdocs/Signatures/signature-container/general.scss +7 -7
- package/livingdocs/Signatures/signature-container/ldd.scss +1 -1
- package/livingdocs/Signatures/signature-container/pdf.scss +1 -1
- package/livingdocs/Signatures/signature-container/signature-container.html +30 -30
- package/livingdocs/Signatures/signature-container/word.scss +1 -1
- package/livingdocs/Signatures/signature-item/app.scss +1 -1
- package/livingdocs/Signatures/signature-item/general.scss +53 -53
- package/livingdocs/Signatures/signature-item/ldd.scss +1 -1
- package/livingdocs/Signatures/signature-item/pdf.scss +1 -1
- package/livingdocs/Signatures/signature-item/signature-item.html +23 -23
- package/livingdocs/Signatures/signature-item/word.scss +1 -1
- package/livingdocs/Text/footnote/app.scss +1 -1
- package/livingdocs/Text/footnote/footnote.html +14 -14
- package/livingdocs/Text/footnote/general.scss +12 -12
- package/livingdocs/Text/footnote/ldd.scss +1 -1
- package/livingdocs/Text/footnote/pdf.scss +1 -1
- package/livingdocs/Text/footnote/print.scss +36 -36
- package/livingdocs/Text/footnote/web.scss +27 -27
- package/livingdocs/Text/footnote/word.scss +1 -1
- package/livingdocs/Text/lead/general.scss +9 -9
- package/livingdocs/Text/lead/lead.html +23 -23
- package/livingdocs/Text/paragraph/general.scss +9 -9
- package/livingdocs/Text/paragraph/paragraph.html +24 -24
- package/livingdocs/Text/quote/general.scss +43 -43
- package/livingdocs/Text/quote/properties.json +7 -7
- package/livingdocs/Text/quote/quote.html +29 -29
- package/livingdocs/Text/quote-with-portrait/general.scss +81 -81
- package/livingdocs/Text/quote-with-portrait/properties.json +12 -12
- package/livingdocs/Text/quote-with-portrait/quote-with-portrait.html +49 -49
- package/livingdocs/Titles/title-h1/general.scss +10 -10
- package/livingdocs/Titles/title-h1/title-h1.html +16 -16
- package/livingdocs/Titles/title-h2/app.scss +1 -1
- package/livingdocs/Titles/title-h2/general.scss +13 -13
- package/livingdocs/Titles/title-h2/ldd.scss +1 -1
- package/livingdocs/Titles/title-h2/pdf.scss +1 -1
- package/livingdocs/Titles/title-h2/print.scss +36 -36
- package/livingdocs/Titles/title-h2/title-h2.html +26 -26
- package/livingdocs/Titles/title-h2/web.scss +27 -27
- package/livingdocs/Titles/title-h2/word.scss +1 -1
- package/livingdocs/Titles/title-h3/app.scss +1 -1
- package/livingdocs/Titles/title-h3/general.scss +13 -13
- package/livingdocs/Titles/title-h3/ldd.scss +1 -1
- package/livingdocs/Titles/title-h3/pdf.scss +1 -1
- package/livingdocs/Titles/title-h3/print.scss +34 -34
- package/livingdocs/Titles/title-h3/title-h3.html +26 -26
- package/livingdocs/Titles/title-h3/web.scss +27 -27
- package/livingdocs/Titles/title-h3/word.scss +1 -1
- package/livingdocs/Titles/title-h4/app.scss +1 -1
- package/livingdocs/Titles/title-h4/general.scss +13 -13
- package/livingdocs/Titles/title-h4/ldd.scss +1 -1
- package/livingdocs/Titles/title-h4/pdf.scss +1 -1
- package/livingdocs/Titles/title-h4/print.scss +34 -34
- package/livingdocs/Titles/title-h4/title-h4.html +26 -26
- package/livingdocs/Titles/title-h4/web.scss +27 -27
- package/livingdocs/Titles/title-h4/word.scss +1 -1
- package/livingdocs/Titles/title-h5/general.scss +10 -10
- package/livingdocs/Titles/title-h5/title-h5.html +16 -16
- package/livingdocs/Titles/title-h6/general.scss +10 -10
- package/livingdocs/Titles/title-h6/title-h6.html +16 -16
- package/package.json +50 -50
- package/preparePublish.cjs +95 -95
- package/scripts/beaver.js +316 -316
- package/scripts/build.js +812 -812
- package/scripts/components.js +566 -566
- package/scripts/doPublish.js +43 -43
- package/scripts/init.js +45 -45
- package/scripts/migrate-livingdocs-build/LICENSE +21 -21
- package/scripts/migrate-livingdocs-build/bin/build.js +53 -53
- package/scripts/migrate-livingdocs-build/bin/migrate.js +43 -43
- package/scripts/migrate-livingdocs-build/dev/build/v1.js +51 -51
- package/scripts/migrate-livingdocs-build/dev/build/v2.js +44 -44
- package/scripts/migrate-livingdocs-build/dev/build/zip-archive.js +39 -39
- package/scripts/migrate-livingdocs-build/dev/build.js +7 -7
- package/scripts/migrate-livingdocs-build/dev/configuration-defaults.js +18 -18
- package/scripts/migrate-livingdocs-build/dev/configuration.js +34 -34
- package/scripts/migrate-livingdocs-build/dev/lib.d.ts +1 -1
- package/scripts/migrate-livingdocs-build/dev/lib.js +251 -251
- package/scripts/migrate-livingdocs-build/dev/livingdocs-design.d.ts +2 -2
- package/scripts/migrate-livingdocs-build/dev/livingdocs-design.js +80 -80
- package/scripts/migrate-livingdocs-build/dev/logger.js +16 -16
- package/scripts/migrate-livingdocs-build/dev/migrate.js +241 -241
- package/scripts/migrate-livingdocs-build/readme.md +62 -62
- package/scripts/preparePublish.js +88 -88
- package/scripts/renamePackage.d.ts +1 -1
- package/scripts/renamePackage.js +48 -48
- package/scripts/utils.js +106 -106
- package/scripts/vite.js +58 -58
- package/scss/colors/functions.scss +18 -18
- package/scss/colors/index.scss +3 -3
- package/scss/colors/mixins.scss +45 -45
- package/scss/colors/variables.scss +6 -6
- package/scss/config.scss +7 -7
- package/scss/core-styles.scss +22 -22
- package/scss/fonts/functions.scss +21 -21
- package/scss/fonts/index.scss +3 -3
- package/scss/fonts/mixins.scss +31 -31
- package/scss/fonts/variables.scss +8 -8
- package/scss/grid/functions.scss +29 -29
- package/scss/grid/index.scss +3 -3
- package/scss/grid/mixins.scss +388 -388
- package/scss/grid/variables.scss +10 -10
- package/scss/helpers/index.scss +3 -3
- package/scss/helpers/mixins.scss +87 -87
- package/scss/helpers/variables.scss +7 -7
- package/scss/index.scss +8 -8
- package/scss/meta/functions.scss +64 -64
- package/scss/meta/index.scss +3 -3
- package/scss/meta/mixins.scss +6 -6
- package/scss/meta/variables.scss +8 -8
- package/scss/spacer/functions.scss +9 -9
- package/scss/spacer/index.scss +3 -3
- package/scss/spacer/mixins.scss +236 -236
- package/scss/spacer/variables.scss +6 -6
- package/scss/system/functions.scss +77 -77
- package/scss/system/index.scss +3 -3
- package/scss/system/mixins.scss +27 -27
- package/scss/system/root.scss +39 -39
- package/scss/system/variables.scss +13 -13
- package/scss/typography/functions.scss +63 -63
- package/scss/typography/index.scss +3 -3
- package/scss/typography/mixins.scss +262 -262
- package/scss/typography/variables.scss +11 -11
|
@@ -1,88 +1,88 @@
|
|
|
1
|
-
<script lang="ts" setup>
|
|
2
|
-
import { computed, ref, watch } from 'vue'
|
|
3
|
-
import { useRoute } from 'vue-router'
|
|
4
|
-
import { ArrayToString } from '@/utils/variables'
|
|
5
|
-
|
|
6
|
-
const route = useRoute()
|
|
7
|
-
const locale = computed(() => {
|
|
8
|
-
return ArrayToString(route.params.locale)
|
|
9
|
-
})
|
|
10
|
-
const downloadData = ref<NsWowDownloads>({ structure: [] })
|
|
11
|
-
|
|
12
|
-
async function getDownloads() {
|
|
13
|
-
const file = `./downloads/downloads_${locale.value}.json`
|
|
14
|
-
try {
|
|
15
|
-
const response = await fetch(file)
|
|
16
|
-
downloadData.value = await response.json()
|
|
17
|
-
} catch (e) {
|
|
18
|
-
console.error(`"${file}" could not be loaded.`)
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
watch(route, () => getDownloads())
|
|
23
|
-
getDownloads()
|
|
24
|
-
</script>
|
|
25
|
-
|
|
26
|
-
<template>
|
|
27
|
-
<article class="srl-download">
|
|
28
|
-
<h1>Downloads</h1>
|
|
29
|
-
<h2>Annual Report</h2>
|
|
30
|
-
<div v-if="downloadData.annualReport">
|
|
31
|
-
<a target="_blank">{{ downloadData.annualReport?.title }}</a>
|
|
32
|
-
</div>
|
|
33
|
-
<h2>Downloads</h2>
|
|
34
|
-
<transition name="fade">
|
|
35
|
-
<ul v-if="downloadData.structure.length" class="srl-download__list">
|
|
36
|
-
<li v-for="(item, index) in downloadData?.structure" :key="index">
|
|
37
|
-
<a href="" target="_blank">
|
|
38
|
-
<svg
|
|
39
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
40
|
-
width="16"
|
|
41
|
-
height="16"
|
|
42
|
-
fill="currentColor"
|
|
43
|
-
class="bi bi-download"
|
|
44
|
-
viewBox="0 0 16 16"
|
|
45
|
-
>
|
|
46
|
-
<path
|
|
47
|
-
d="M.5 9.9a.5.5 0 0 1 .5.5v2.5a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2.5a.5.5 0 0 1 1 0v2.5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-2.5a.5.5 0 0 1 .5-.5z"
|
|
48
|
-
/>
|
|
49
|
-
<path
|
|
50
|
-
d="M7.646 11.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V1.5a.5.5 0 0 0-1 0v8.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3z"
|
|
51
|
-
/>
|
|
52
|
-
</svg>
|
|
53
|
-
<div>
|
|
54
|
-
<span class="title">{{ item.title }}</span
|
|
55
|
-
><br />
|
|
56
|
-
<span>{{ item.size }}</span>
|
|
57
|
-
</div>
|
|
58
|
-
</a>
|
|
59
|
-
</li>
|
|
60
|
-
</ul>
|
|
61
|
-
</transition>
|
|
62
|
-
</article>
|
|
63
|
-
</template>
|
|
64
|
-
|
|
65
|
-
<style scoped lang="scss">
|
|
66
|
-
@use 'nswow';
|
|
67
|
-
|
|
68
|
-
.srl-download {
|
|
69
|
-
margin: 0 auto;
|
|
70
|
-
@include nswow.grid-container();
|
|
71
|
-
|
|
72
|
-
&__list {
|
|
73
|
-
list-style-type: none;
|
|
74
|
-
padding: 0 0 0 0;
|
|
75
|
-
|
|
76
|
-
li {
|
|
77
|
-
margin-bottom: nswow.system-size-unit(20);
|
|
78
|
-
|
|
79
|
-
a {
|
|
80
|
-
text-decoration: none;
|
|
81
|
-
display: flex;
|
|
82
|
-
align-items: center;
|
|
83
|
-
gap: nswow.system-size-unit(10);
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
</style>
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import { computed, ref, watch } from 'vue'
|
|
3
|
+
import { useRoute } from 'vue-router'
|
|
4
|
+
import { ArrayToString } from '@/utils/variables'
|
|
5
|
+
|
|
6
|
+
const route = useRoute()
|
|
7
|
+
const locale = computed(() => {
|
|
8
|
+
return ArrayToString(route.params.locale)
|
|
9
|
+
})
|
|
10
|
+
const downloadData = ref<NsWowDownloads>({ structure: [] })
|
|
11
|
+
|
|
12
|
+
async function getDownloads() {
|
|
13
|
+
const file = `./downloads/downloads_${locale.value}.json`
|
|
14
|
+
try {
|
|
15
|
+
const response = await fetch(file)
|
|
16
|
+
downloadData.value = await response.json()
|
|
17
|
+
} catch (e) {
|
|
18
|
+
console.error(`"${file}" could not be loaded.`)
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
watch(route, () => getDownloads())
|
|
23
|
+
getDownloads()
|
|
24
|
+
</script>
|
|
25
|
+
|
|
26
|
+
<template>
|
|
27
|
+
<article class="srl-download">
|
|
28
|
+
<h1>Downloads</h1>
|
|
29
|
+
<h2>Annual Report</h2>
|
|
30
|
+
<div v-if="downloadData.annualReport">
|
|
31
|
+
<a target="_blank">{{ downloadData.annualReport?.title }}</a>
|
|
32
|
+
</div>
|
|
33
|
+
<h2>Downloads</h2>
|
|
34
|
+
<transition name="fade">
|
|
35
|
+
<ul v-if="downloadData.structure.length" class="srl-download__list">
|
|
36
|
+
<li v-for="(item, index) in downloadData?.structure" :key="index">
|
|
37
|
+
<a href="" target="_blank">
|
|
38
|
+
<svg
|
|
39
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
40
|
+
width="16"
|
|
41
|
+
height="16"
|
|
42
|
+
fill="currentColor"
|
|
43
|
+
class="bi bi-download"
|
|
44
|
+
viewBox="0 0 16 16"
|
|
45
|
+
>
|
|
46
|
+
<path
|
|
47
|
+
d="M.5 9.9a.5.5 0 0 1 .5.5v2.5a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2.5a.5.5 0 0 1 1 0v2.5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-2.5a.5.5 0 0 1 .5-.5z"
|
|
48
|
+
/>
|
|
49
|
+
<path
|
|
50
|
+
d="M7.646 11.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V1.5a.5.5 0 0 0-1 0v8.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3z"
|
|
51
|
+
/>
|
|
52
|
+
</svg>
|
|
53
|
+
<div>
|
|
54
|
+
<span class="title">{{ item.title }}</span
|
|
55
|
+
><br />
|
|
56
|
+
<span>{{ item.size }}</span>
|
|
57
|
+
</div>
|
|
58
|
+
</a>
|
|
59
|
+
</li>
|
|
60
|
+
</ul>
|
|
61
|
+
</transition>
|
|
62
|
+
</article>
|
|
63
|
+
</template>
|
|
64
|
+
|
|
65
|
+
<style scoped lang="scss">
|
|
66
|
+
@use 'nswow';
|
|
67
|
+
|
|
68
|
+
.srl-download {
|
|
69
|
+
margin: 0 auto;
|
|
70
|
+
@include nswow.grid-container();
|
|
71
|
+
|
|
72
|
+
&__list {
|
|
73
|
+
list-style-type: none;
|
|
74
|
+
padding: 0 0 0 0;
|
|
75
|
+
|
|
76
|
+
li {
|
|
77
|
+
margin-bottom: nswow.system-size-unit(20);
|
|
78
|
+
|
|
79
|
+
a {
|
|
80
|
+
text-decoration: none;
|
|
81
|
+
display: flex;
|
|
82
|
+
align-items: center;
|
|
83
|
+
gap: nswow.system-size-unit(10);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
</style>
|
|
@@ -1,35 +1,35 @@
|
|
|
1
|
-
<script setup lang="ts">
|
|
2
|
-
import { computed } from 'vue'
|
|
3
|
-
import { ArrayToString } from '@/utils/variables'
|
|
4
|
-
import { useRoute } from 'vue-router'
|
|
5
|
-
|
|
6
|
-
const route = useRoute()
|
|
7
|
-
|
|
8
|
-
const locale = computed<string>(() => {
|
|
9
|
-
return ArrayToString(route.params.locale)
|
|
10
|
-
})
|
|
11
|
-
</script>
|
|
12
|
-
|
|
13
|
-
<template>
|
|
14
|
-
<div class="srl-main">
|
|
15
|
-
<h1>Welcome {{ locale }}</h1>
|
|
16
|
-
<h3>Dokumentation Frontend Toolkit für Komponenten als auch APP:</h3>
|
|
17
|
-
<p>
|
|
18
|
-
<a href="https://mmssolutionsio.github.io/mms-reporting-docs/docs/intro" target="_blank"
|
|
19
|
-
>Dokumentation</a
|
|
20
|
-
>
|
|
21
|
-
</p>
|
|
22
|
-
</div>
|
|
23
|
-
</template>
|
|
24
|
-
|
|
25
|
-
<style scoped lang="scss">
|
|
26
|
-
@use 'nswow';
|
|
27
|
-
|
|
28
|
-
.srl-main {
|
|
29
|
-
padding: nswow.system-size-unit(100) 0;
|
|
30
|
-
margin-left: auto;
|
|
31
|
-
margin-right: auto;
|
|
32
|
-
min-height: 80vh;
|
|
33
|
-
@include nswow.grid-container();
|
|
34
|
-
}
|
|
35
|
-
</style>
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import { computed } from 'vue'
|
|
3
|
+
import { ArrayToString } from '@/utils/variables'
|
|
4
|
+
import { useRoute } from 'vue-router'
|
|
5
|
+
|
|
6
|
+
const route = useRoute()
|
|
7
|
+
|
|
8
|
+
const locale = computed<string>(() => {
|
|
9
|
+
return ArrayToString(route.params.locale)
|
|
10
|
+
})
|
|
11
|
+
</script>
|
|
12
|
+
|
|
13
|
+
<template>
|
|
14
|
+
<div class="srl-main">
|
|
15
|
+
<h1>Welcome {{ locale }}</h1>
|
|
16
|
+
<h3>Dokumentation Frontend Toolkit für Komponenten als auch APP:</h3>
|
|
17
|
+
<p>
|
|
18
|
+
<a href="https://mmssolutionsio.github.io/mms-reporting-docs/docs/intro" target="_blank"
|
|
19
|
+
>Dokumentation</a
|
|
20
|
+
>
|
|
21
|
+
</p>
|
|
22
|
+
</div>
|
|
23
|
+
</template>
|
|
24
|
+
|
|
25
|
+
<style scoped lang="scss">
|
|
26
|
+
@use 'nswow';
|
|
27
|
+
|
|
28
|
+
.srl-main {
|
|
29
|
+
padding: nswow.system-size-unit(100) 0;
|
|
30
|
+
margin-left: auto;
|
|
31
|
+
margin-right: auto;
|
|
32
|
+
min-height: 80vh;
|
|
33
|
+
@include nswow.grid-container();
|
|
34
|
+
}
|
|
35
|
+
</style>
|
|
@@ -1,73 +1,73 @@
|
|
|
1
|
-
<script setup lang="ts"></script>
|
|
2
|
-
|
|
3
|
-
<template>
|
|
4
|
-
<div class="srl-notfound">
|
|
5
|
-
<div class="srl-notfound__inner">
|
|
6
|
-
<h1>404</h1>
|
|
7
|
-
<h2>{{ $t('page.notFound') }}</h2>
|
|
8
|
-
<svg
|
|
9
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
10
|
-
width="16"
|
|
11
|
-
height="16"
|
|
12
|
-
fill="currentColor"
|
|
13
|
-
class="bi bi-robot"
|
|
14
|
-
viewBox="0 0 16 16"
|
|
15
|
-
>
|
|
16
|
-
<path
|
|
17
|
-
d="M6 12.5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5ZM3 8.062C3 6.76 4.235 5.765 5.53 5.886a26.58 26.58 0 0 0 4.94 0C11.765 5.765 13 6.76 13 8.062v1.157a.933.933 0 0 1-.765.935c-.845.147-2.34.346-4.235.346-1.895 0-3.39-.2-4.235-.346A.933.933 0 0 1 3 9.219V8.062Zm4.542-.827a.25.25 0 0 0-.217.068l-.92.9a24.767 24.767 0 0 1-1.871-.183.25.25 0 0 0-.068.495c.55.076 1.232.149 2.02.193a.25.25 0 0 0 .189-.071l.754-.736.847 1.71a.25.25 0 0 0 .404.062l.932-.97a25.286 25.286 0 0 0 1.922-.188.25.25 0 0 0-.068-.495c-.538.074-1.207.145-1.98.189a.25.25 0 0 0-.166.076l-.754.785-.842-1.7a.25.25 0 0 0-.182-.135Z"
|
|
18
|
-
/>
|
|
19
|
-
<path
|
|
20
|
-
d="M8.5 1.866a1 1 0 1 0-1 0V3h-2A4.5 4.5 0 0 0 1 7.5V8a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1v1a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2v-1a1 1 0 0 0 1-1V9a1 1 0 0 0-1-1v-.5A4.5 4.5 0 0 0 10.5 3h-2V1.866ZM14 7.5V13a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V7.5A3.5 3.5 0 0 1 5.5 4h5A3.5 3.5 0 0 1 14 7.5Z"
|
|
21
|
-
/>
|
|
22
|
-
</svg>
|
|
23
|
-
</div>
|
|
24
|
-
</div>
|
|
25
|
-
</template>
|
|
26
|
-
|
|
27
|
-
<style scoped lang="scss">
|
|
28
|
-
@use 'nswow';
|
|
29
|
-
|
|
30
|
-
.srl-notfound {
|
|
31
|
-
margin: 0 auto;
|
|
32
|
-
@include nswow.grid-container();
|
|
33
|
-
@include nswow.fonts-core-styles();
|
|
34
|
-
|
|
35
|
-
&__inner {
|
|
36
|
-
display: flex;
|
|
37
|
-
justify-content: center;
|
|
38
|
-
align-items: center;
|
|
39
|
-
flex-direction: column;
|
|
40
|
-
min-height: 80vh;
|
|
41
|
-
|
|
42
|
-
svg {
|
|
43
|
-
height: 100px;
|
|
44
|
-
width: 100px;
|
|
45
|
-
margin-top: 2rem;
|
|
46
|
-
animation: spin 600ms linear 2;
|
|
47
|
-
|
|
48
|
-
@keyframes spin {
|
|
49
|
-
10%,
|
|
50
|
-
90% {
|
|
51
|
-
transform: translate3d(-1px, 0, 0);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
20%,
|
|
55
|
-
80% {
|
|
56
|
-
transform: translate3d(2px, 0, 0);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
30%,
|
|
60
|
-
50%,
|
|
61
|
-
70% {
|
|
62
|
-
transform: translate3d(-4px, 0, 0);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
40%,
|
|
66
|
-
60% {
|
|
67
|
-
transform: translate3d(4px, 0, 0);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
</style>
|
|
1
|
+
<script setup lang="ts"></script>
|
|
2
|
+
|
|
3
|
+
<template>
|
|
4
|
+
<div class="srl-notfound">
|
|
5
|
+
<div class="srl-notfound__inner">
|
|
6
|
+
<h1>404</h1>
|
|
7
|
+
<h2>{{ $t('page.notFound') }}</h2>
|
|
8
|
+
<svg
|
|
9
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
10
|
+
width="16"
|
|
11
|
+
height="16"
|
|
12
|
+
fill="currentColor"
|
|
13
|
+
class="bi bi-robot"
|
|
14
|
+
viewBox="0 0 16 16"
|
|
15
|
+
>
|
|
16
|
+
<path
|
|
17
|
+
d="M6 12.5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5ZM3 8.062C3 6.76 4.235 5.765 5.53 5.886a26.58 26.58 0 0 0 4.94 0C11.765 5.765 13 6.76 13 8.062v1.157a.933.933 0 0 1-.765.935c-.845.147-2.34.346-4.235.346-1.895 0-3.39-.2-4.235-.346A.933.933 0 0 1 3 9.219V8.062Zm4.542-.827a.25.25 0 0 0-.217.068l-.92.9a24.767 24.767 0 0 1-1.871-.183.25.25 0 0 0-.068.495c.55.076 1.232.149 2.02.193a.25.25 0 0 0 .189-.071l.754-.736.847 1.71a.25.25 0 0 0 .404.062l.932-.97a25.286 25.286 0 0 0 1.922-.188.25.25 0 0 0-.068-.495c-.538.074-1.207.145-1.98.189a.25.25 0 0 0-.166.076l-.754.785-.842-1.7a.25.25 0 0 0-.182-.135Z"
|
|
18
|
+
/>
|
|
19
|
+
<path
|
|
20
|
+
d="M8.5 1.866a1 1 0 1 0-1 0V3h-2A4.5 4.5 0 0 0 1 7.5V8a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1v1a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2v-1a1 1 0 0 0 1-1V9a1 1 0 0 0-1-1v-.5A4.5 4.5 0 0 0 10.5 3h-2V1.866ZM14 7.5V13a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V7.5A3.5 3.5 0 0 1 5.5 4h5A3.5 3.5 0 0 1 14 7.5Z"
|
|
21
|
+
/>
|
|
22
|
+
</svg>
|
|
23
|
+
</div>
|
|
24
|
+
</div>
|
|
25
|
+
</template>
|
|
26
|
+
|
|
27
|
+
<style scoped lang="scss">
|
|
28
|
+
@use 'nswow';
|
|
29
|
+
|
|
30
|
+
.srl-notfound {
|
|
31
|
+
margin: 0 auto;
|
|
32
|
+
@include nswow.grid-container();
|
|
33
|
+
@include nswow.fonts-core-styles();
|
|
34
|
+
|
|
35
|
+
&__inner {
|
|
36
|
+
display: flex;
|
|
37
|
+
justify-content: center;
|
|
38
|
+
align-items: center;
|
|
39
|
+
flex-direction: column;
|
|
40
|
+
min-height: 80vh;
|
|
41
|
+
|
|
42
|
+
svg {
|
|
43
|
+
height: 100px;
|
|
44
|
+
width: 100px;
|
|
45
|
+
margin-top: 2rem;
|
|
46
|
+
animation: spin 600ms linear 2;
|
|
47
|
+
|
|
48
|
+
@keyframes spin {
|
|
49
|
+
10%,
|
|
50
|
+
90% {
|
|
51
|
+
transform: translate3d(-1px, 0, 0);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
20%,
|
|
55
|
+
80% {
|
|
56
|
+
transform: translate3d(2px, 0, 0);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
30%,
|
|
60
|
+
50%,
|
|
61
|
+
70% {
|
|
62
|
+
transform: translate3d(-4px, 0, 0);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
40%,
|
|
66
|
+
60% {
|
|
67
|
+
transform: translate3d(4px, 0, 0);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
</style>
|
|
@@ -1,126 +1,126 @@
|
|
|
1
|
-
<script lang="ts" setup>
|
|
2
|
-
import { computed, ref, watch } from 'vue'
|
|
3
|
-
import { useRoute } from 'vue-router'
|
|
4
|
-
import useConfig from '@/composables/config'
|
|
5
|
-
import { ArrayToString } from '@/utils/variables'
|
|
6
|
-
|
|
7
|
-
type searchDataType = {
|
|
8
|
-
title: string
|
|
9
|
-
content: string
|
|
10
|
-
link: string
|
|
11
|
-
translatedTitle: string
|
|
12
|
-
firstParagraph: string
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
const config = await useConfig()
|
|
16
|
-
const route = useRoute()
|
|
17
|
-
const isLoading = ref<boolean>(true)
|
|
18
|
-
const searchData = ref<searchDataType[]>([])
|
|
19
|
-
|
|
20
|
-
const locale = computed<string>(() => {
|
|
21
|
-
return ArrayToString(route.params.locale)
|
|
22
|
-
})
|
|
23
|
-
|
|
24
|
-
const searchValue = computed<string>(() => {
|
|
25
|
-
return route.query.searchValue ? ArrayToString(route.query.searchValue, ' ') : ''
|
|
26
|
-
})
|
|
27
|
-
|
|
28
|
-
const articles = computed<NsWowArticle[]>(() => {
|
|
29
|
-
return config.value.articles[locale.value] ?? []
|
|
30
|
-
})
|
|
31
|
-
|
|
32
|
-
async function getSearchResult() {
|
|
33
|
-
isLoading.value = true
|
|
34
|
-
searchData.value = []
|
|
35
|
-
const routesArray: {
|
|
36
|
-
uuid: string
|
|
37
|
-
slug: string
|
|
38
|
-
name: string
|
|
39
|
-
translatedTitle: string
|
|
40
|
-
}[] = []
|
|
41
|
-
|
|
42
|
-
articles.value
|
|
43
|
-
.filter((item) => {
|
|
44
|
-
return !item.ignoreInSearch
|
|
45
|
-
})
|
|
46
|
-
.map((value) => {
|
|
47
|
-
routesArray.push({
|
|
48
|
-
uuid: value.uuid,
|
|
49
|
-
slug: value.slug,
|
|
50
|
-
name: value.name,
|
|
51
|
-
translatedTitle: value.translatedTitle
|
|
52
|
-
})
|
|
53
|
-
})
|
|
54
|
-
|
|
55
|
-
if (routesArray.length) {
|
|
56
|
-
routesArray.map(async (value) => {
|
|
57
|
-
const file = `./html/${locale.value}/${value.name}.html`
|
|
58
|
-
try {
|
|
59
|
-
const response = await fetch(file)
|
|
60
|
-
const data = await response.text()
|
|
61
|
-
if (data.toLowerCase().includes(searchValue.value.toLowerCase())) {
|
|
62
|
-
const item: searchDataType = {
|
|
63
|
-
title: `${locale.value}/${value.slug}`,
|
|
64
|
-
content: data,
|
|
65
|
-
link: `/${locale.value}/${value.slug}`,
|
|
66
|
-
translatedTitle: value.translatedTitle,
|
|
67
|
-
firstParagraph: ''
|
|
68
|
-
}
|
|
69
|
-
const doc = new DOMParser().parseFromString(data, 'text/html')
|
|
70
|
-
const paragraph = doc.querySelector('p')
|
|
71
|
-
if (paragraph) {
|
|
72
|
-
item.firstParagraph = paragraph.textContent ?? ''
|
|
73
|
-
}
|
|
74
|
-
searchData.value.push(item)
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
searchData.value.sort((a, b) => {
|
|
78
|
-
return a.title.localeCompare(b.title)
|
|
79
|
-
})
|
|
80
|
-
|
|
81
|
-
isLoading.value = false
|
|
82
|
-
} catch (e) {
|
|
83
|
-
console.error(`"${file}" could not be loaded.`)
|
|
84
|
-
}
|
|
85
|
-
})
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
watch(route, () => getSearchResult())
|
|
90
|
-
getSearchResult()
|
|
91
|
-
</script>
|
|
92
|
-
|
|
93
|
-
<template>
|
|
94
|
-
<article class="srl-article">
|
|
95
|
-
<div class="srl-article-container">
|
|
96
|
-
<h1>{{ $t('search.title') }}</h1>
|
|
97
|
-
|
|
98
|
-
<div v-if="isLoading">Loading...</div>
|
|
99
|
-
<transition name="fade">
|
|
100
|
-
<h2 v-if="!isLoading">
|
|
101
|
-
{{ $t('search.for', { search: searchValue, count: searchData.length }) }}
|
|
102
|
-
</h2>
|
|
103
|
-
</transition>
|
|
104
|
-
|
|
105
|
-
<transition name="fade">
|
|
106
|
-
<div v-if="!isLoading && searchValue">
|
|
107
|
-
<div v-for="(dataItem, index) in searchData" :key="index">
|
|
108
|
-
<h5>{{ dataItem.translatedTitle }}</h5>
|
|
109
|
-
<p>{{ dataItem.firstParagraph }}</p>
|
|
110
|
-
<router-link :to="{ path: dataItem.link }">{{ dataItem.title }}</router-link>
|
|
111
|
-
</div>
|
|
112
|
-
</div>
|
|
113
|
-
</transition>
|
|
114
|
-
</div>
|
|
115
|
-
</article>
|
|
116
|
-
</template>
|
|
117
|
-
|
|
118
|
-
<style scoped lang="scss">
|
|
119
|
-
@use 'nswow';
|
|
120
|
-
|
|
121
|
-
.srl-article {
|
|
122
|
-
margin: 0 auto;
|
|
123
|
-
@include nswow.grid-container();
|
|
124
|
-
@include nswow.typography-core-styles();
|
|
125
|
-
}
|
|
126
|
-
</style>
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import { computed, ref, watch } from 'vue'
|
|
3
|
+
import { useRoute } from 'vue-router'
|
|
4
|
+
import useConfig from '@/composables/config'
|
|
5
|
+
import { ArrayToString } from '@/utils/variables'
|
|
6
|
+
|
|
7
|
+
type searchDataType = {
|
|
8
|
+
title: string
|
|
9
|
+
content: string
|
|
10
|
+
link: string
|
|
11
|
+
translatedTitle: string
|
|
12
|
+
firstParagraph: string
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const config = await useConfig()
|
|
16
|
+
const route = useRoute()
|
|
17
|
+
const isLoading = ref<boolean>(true)
|
|
18
|
+
const searchData = ref<searchDataType[]>([])
|
|
19
|
+
|
|
20
|
+
const locale = computed<string>(() => {
|
|
21
|
+
return ArrayToString(route.params.locale)
|
|
22
|
+
})
|
|
23
|
+
|
|
24
|
+
const searchValue = computed<string>(() => {
|
|
25
|
+
return route.query.searchValue ? ArrayToString(route.query.searchValue, ' ') : ''
|
|
26
|
+
})
|
|
27
|
+
|
|
28
|
+
const articles = computed<NsWowArticle[]>(() => {
|
|
29
|
+
return config.value.articles[locale.value] ?? []
|
|
30
|
+
})
|
|
31
|
+
|
|
32
|
+
async function getSearchResult() {
|
|
33
|
+
isLoading.value = true
|
|
34
|
+
searchData.value = []
|
|
35
|
+
const routesArray: {
|
|
36
|
+
uuid: string
|
|
37
|
+
slug: string
|
|
38
|
+
name: string
|
|
39
|
+
translatedTitle: string
|
|
40
|
+
}[] = []
|
|
41
|
+
|
|
42
|
+
articles.value
|
|
43
|
+
.filter((item) => {
|
|
44
|
+
return !item.ignoreInSearch
|
|
45
|
+
})
|
|
46
|
+
.map((value) => {
|
|
47
|
+
routesArray.push({
|
|
48
|
+
uuid: value.uuid,
|
|
49
|
+
slug: value.slug,
|
|
50
|
+
name: value.name,
|
|
51
|
+
translatedTitle: value.translatedTitle
|
|
52
|
+
})
|
|
53
|
+
})
|
|
54
|
+
|
|
55
|
+
if (routesArray.length) {
|
|
56
|
+
routesArray.map(async (value) => {
|
|
57
|
+
const file = `./html/${locale.value}/${value.name}.html`
|
|
58
|
+
try {
|
|
59
|
+
const response = await fetch(file)
|
|
60
|
+
const data = await response.text()
|
|
61
|
+
if (data.toLowerCase().includes(searchValue.value.toLowerCase())) {
|
|
62
|
+
const item: searchDataType = {
|
|
63
|
+
title: `${locale.value}/${value.slug}`,
|
|
64
|
+
content: data,
|
|
65
|
+
link: `/${locale.value}/${value.slug}`,
|
|
66
|
+
translatedTitle: value.translatedTitle,
|
|
67
|
+
firstParagraph: ''
|
|
68
|
+
}
|
|
69
|
+
const doc = new DOMParser().parseFromString(data, 'text/html')
|
|
70
|
+
const paragraph = doc.querySelector('p')
|
|
71
|
+
if (paragraph) {
|
|
72
|
+
item.firstParagraph = paragraph.textContent ?? ''
|
|
73
|
+
}
|
|
74
|
+
searchData.value.push(item)
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
searchData.value.sort((a, b) => {
|
|
78
|
+
return a.title.localeCompare(b.title)
|
|
79
|
+
})
|
|
80
|
+
|
|
81
|
+
isLoading.value = false
|
|
82
|
+
} catch (e) {
|
|
83
|
+
console.error(`"${file}" could not be loaded.`)
|
|
84
|
+
}
|
|
85
|
+
})
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
watch(route, () => getSearchResult())
|
|
90
|
+
getSearchResult()
|
|
91
|
+
</script>
|
|
92
|
+
|
|
93
|
+
<template>
|
|
94
|
+
<article class="srl-article">
|
|
95
|
+
<div class="srl-article-container">
|
|
96
|
+
<h1>{{ $t('search.title') }}</h1>
|
|
97
|
+
|
|
98
|
+
<div v-if="isLoading">Loading...</div>
|
|
99
|
+
<transition name="fade">
|
|
100
|
+
<h2 v-if="!isLoading">
|
|
101
|
+
{{ $t('search.for', { search: searchValue, count: searchData.length }) }}
|
|
102
|
+
</h2>
|
|
103
|
+
</transition>
|
|
104
|
+
|
|
105
|
+
<transition name="fade">
|
|
106
|
+
<div v-if="!isLoading && searchValue">
|
|
107
|
+
<div v-for="(dataItem, index) in searchData" :key="index">
|
|
108
|
+
<h5>{{ dataItem.translatedTitle }}</h5>
|
|
109
|
+
<p>{{ dataItem.firstParagraph }}</p>
|
|
110
|
+
<router-link :to="{ path: dataItem.link }">{{ dataItem.title }}</router-link>
|
|
111
|
+
</div>
|
|
112
|
+
</div>
|
|
113
|
+
</transition>
|
|
114
|
+
</div>
|
|
115
|
+
</article>
|
|
116
|
+
</template>
|
|
117
|
+
|
|
118
|
+
<style scoped lang="scss">
|
|
119
|
+
@use 'nswow';
|
|
120
|
+
|
|
121
|
+
.srl-article {
|
|
122
|
+
margin: 0 auto;
|
|
123
|
+
@include nswow.grid-container();
|
|
124
|
+
@include nswow.typography-core-styles();
|
|
125
|
+
}
|
|
126
|
+
</style>
|