spoko-design-system 0.2.40 → 0.2.42

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 (158) hide show
  1. package/.env.example +2 -0
  2. package/.github/dependabot.yml +11 -11
  3. package/.github/todo.yml +3 -3
  4. package/.github/workflows/deploy.yml +39 -39
  5. package/.stackblitzrc +5 -5
  6. package/.vscode/extensions.json +5 -5
  7. package/.vscode/launch.json +11 -11
  8. package/.vscode/settings.json +5 -5
  9. package/LICENSE +21 -21
  10. package/README.md +113 -113
  11. package/astro-i18next.config.mjs +17 -17
  12. package/astro-i18next.config.ts +10 -10
  13. package/astro.config.mjs +147 -147
  14. package/dev-dist/sw.js +91 -91
  15. package/dev-dist/workbox-c676b6d3.js +3391 -3391
  16. package/index.ts +58 -33
  17. package/package.json +1 -1
  18. package/public/fonts/lg.svg +53 -53
  19. package/public/fonts/vwhead-bold-demo.html +549 -549
  20. package/public/fonts/vwhead-regular-demo.html +549 -549
  21. package/public/fonts/vwtext-bold-demo.html +549 -549
  22. package/public/fonts/vwtext-regular-demo.html +549 -549
  23. package/public/github.svg +3 -3
  24. package/public/grid_dot.svg +4 -4
  25. package/public/linkedin.svg +44 -44
  26. package/public/locales/en/translation.json +8 -8
  27. package/public/locales/pl/translation.json +8 -8
  28. package/public/make-scrollable-code-focusable.js +3 -3
  29. package/public/pagefind.yml +3 -3
  30. package/public/polo.blue.svg +29 -29
  31. package/public/spoko.space.svg +71 -71
  32. package/public/twitter.svg +46 -46
  33. package/renovate.json +6 -6
  34. package/sandbox.config.json +11 -11
  35. package/src/MyComponent.astro +8 -8
  36. package/src/components/Badge.vue +19 -19
  37. package/src/components/Badges.vue +21 -21
  38. package/src/components/Breadcrumbs.vue +110 -110
  39. package/src/components/Button.vue +55 -55
  40. package/src/components/ButtonCopy.vue +47 -47
  41. package/src/components/Card.astro +27 -27
  42. package/src/components/Carousel.astro +26 -26
  43. package/src/components/Category/CategoriesCarousel.astro +101 -0
  44. package/src/components/Category/CategoriesSidebar.astro +187 -0
  45. package/src/components/Category/CategoryDetails.astro +82 -0
  46. package/src/components/Category/CategoryLink.vue +23 -0
  47. package/src/components/Category/CategorySection.astro +70 -0
  48. package/src/components/Category/CategorySidebarToggler.vue +10 -0
  49. package/src/components/Category/SubCategoryLink.vue +29 -0
  50. package/src/components/CategoryLink.astro +18 -18
  51. package/src/components/Copyright.astro +12 -12
  52. package/src/components/Date.astro +7 -7
  53. package/src/components/Faq.astro +33 -33
  54. package/src/components/FaqItem.astro +96 -96
  55. package/src/components/FeaturesList.vue +41 -41
  56. package/src/components/FuckRussia.vue +80 -80
  57. package/src/components/HandDrive.astro +29 -29
  58. package/src/components/Header/Header.astro +214 -214
  59. package/src/components/Header/SkipToContent.astro +1 -1
  60. package/src/components/Headline.vue +48 -48
  61. package/src/components/Image.astro +30 -30
  62. package/src/components/Jumbatron.vue +40 -40
  63. package/src/components/LeftSidebar.astro +53 -53
  64. package/src/components/MainColors.vue +23 -23
  65. package/src/components/MainInput.vue +15 -15
  66. package/src/components/Modal.astro +27 -27
  67. package/src/components/PageContent.astro +5 -5
  68. package/src/components/PartNumber.vue +27 -27
  69. package/src/components/PostHeader.astro +103 -103
  70. package/src/components/PrCode.vue +156 -156
  71. package/src/components/Product/ProductButton.vue +18 -0
  72. package/src/components/Product/ProductCodes.vue +167 -0
  73. package/src/components/Product/ProductEngineType.vue +42 -42
  74. package/src/components/Product/ProductImage.astro +41 -41
  75. package/src/components/Product/ProductLinkInfo.astro +37 -37
  76. package/src/components/Product/ProductNumber.astro +104 -104
  77. package/src/components/ProductCarousel.astro +38 -38
  78. package/src/components/ProductCodes.vue +39 -39
  79. package/src/components/ProductDetailName.vue +52 -52
  80. package/src/components/ProductDetailsList.vue +65 -65
  81. package/src/components/ProductNumber copy.astro +116 -116
  82. package/src/components/ProductNumber.astro +104 -104
  83. package/src/components/ProductTile.astro +48 -48
  84. package/src/components/Quote.vue +23 -23
  85. package/src/components/ReloadPrompt.astro +50 -50
  86. package/src/components/SlimBanner.vue +72 -72
  87. package/src/components/Table.vue +32 -32
  88. package/src/components/TableOfContents.astro +15 -15
  89. package/src/components/Translations.vue +23 -23
  90. package/src/components/flags/FlagPL.vue +3 -3
  91. package/src/components/flags/FlagUA.vue +2 -2
  92. package/src/components/layout/Container.astro +7 -7
  93. package/src/components/layout/Header.astro +80 -80
  94. package/src/config.ts +56 -56
  95. package/src/design.config.ts +81 -81
  96. package/src/env.d.ts +1 -1
  97. package/src/layouts/Layout.astro +60 -60
  98. package/src/layouts/MainLayout.astro +81 -81
  99. package/src/layouts/partials/FooterCommon.astro +4 -4
  100. package/src/layouts/partials/HeadCommon.astro +44 -44
  101. package/src/layouts/partials/HeadSEO.astro +41 -41
  102. package/src/pages/components/badges.mdx +57 -57
  103. package/src/pages/components/breadcrumbs.mdx +139 -139
  104. package/src/pages/components/buttons.mdx +236 -236
  105. package/src/pages/components/card.mdx +294 -294
  106. package/src/pages/components/carousel.mdx +62 -62
  107. package/src/pages/components/copyright.mdx +42 -42
  108. package/src/pages/components/details-list.mdx +115 -115
  109. package/src/pages/components/features-list.mdx +37 -37
  110. package/src/pages/components/flags.mdx +49 -49
  111. package/src/pages/components/fuck-russia.mdx +39 -39
  112. package/src/pages/components/hand-drive.mdx +38 -38
  113. package/src/pages/components/headline.mdx +152 -152
  114. package/src/pages/components/icons.astro +48 -48
  115. package/src/pages/components/image.mdx +513 -513
  116. package/src/pages/components/input.mdx +45 -45
  117. package/src/pages/components/jumbatron.mdx +95 -95
  118. package/src/pages/components/modal.mdx +64 -64
  119. package/src/pages/components/post-header.mdx +60 -60
  120. package/src/pages/components/pr-code.mdx +65 -65
  121. package/src/pages/components/product-number.mdx +66 -66
  122. package/src/pages/components/product-tile.mdx +51 -51
  123. package/src/pages/components/quote.mdx +33 -33
  124. package/src/pages/components/slimbanner.mdx +35 -35
  125. package/src/pages/components/table.mdx +108 -108
  126. package/src/pages/core/colors.mdx +10 -10
  127. package/src/pages/core/grid.mdx +89 -89
  128. package/src/pages/core/introduction.mdx +77 -77
  129. package/src/pages/core/shadows.astro +20 -20
  130. package/src/pages/core/typography.astro +47 -47
  131. package/src/pages/index.astro +126 -126
  132. package/src/pages/patterns/introduction.mdx +60 -60
  133. package/src/pwa.ts +12 -12
  134. package/src/styles/_variables.scss +70 -70
  135. package/src/styles/base/base.css +184 -184
  136. package/src/styles/base/grid.css +92 -92
  137. package/src/styles/base/typography.css +70 -70
  138. package/src/styles/content.css +73 -73
  139. package/src/styles/main.css +7 -7
  140. package/src/types/Product.ts +31 -31
  141. package/src/types/astro.d.ts +4 -4
  142. package/src/types/index.ts +237 -0
  143. package/src/utils/api/getCategories.ts +3 -0
  144. package/src/utils/category/getMainCategoryList.ts +31 -0
  145. package/src/utils/category/getSortedCategories.ts +11 -0
  146. package/src/utils/getData.ts +52 -0
  147. package/src/utils/product/getPriceFormatted.ts +14 -0
  148. package/src/utils/product/getProductChecklist.ts +15 -0
  149. package/src/utils/seo/getShorterDescription.ts +12 -0
  150. package/src/utils/text/formatDate.ts +6 -0
  151. package/src/utils/text/formatLocaleNumber.ts +7 -0
  152. package/src/utils/text/formatPad.ts +12 -0
  153. package/src/utils/text/getNumberFormatted.ts +33 -0
  154. package/src/utils/text/getTranslatedLink.ts +5 -0
  155. package/src/utils/text.ts +42 -42
  156. package/tailwind.config.cjs +8 -8
  157. package/tsconfig.json +28 -11
  158. package/uno.config.ts +256 -256
package/src/config.ts CHANGED
@@ -1,56 +1,56 @@
1
- export const SITE = {
2
- title: "Spoko Design System",
3
- description: "The Astro design system which facilitates the development of websites.",
4
- defaultLanguage: "en_US",
5
- twitter: "@spokospace",
6
- github: "spokospace",
7
- linkedin: "szymonberski",
8
- };
9
-
10
- export const OPEN_GRAPH = {
11
- image: {
12
- src: "",
13
- alt: "",
14
- },
15
- twitter: "",
16
- };
17
-
18
- export const SIDEBAR = [
19
- { text: "Core", header: true },
20
- { text: "Introduction", link: "/core/introduction/" },
21
- { text: "Colors", link: "/core/colors/" },
22
- { text: "Typography", link: "/core/typography/" },
23
- { text: "Shadows", link: "/core/shadows/" },
24
- { text: "Grid", link: "/core/grid/" },
25
-
26
- { text: "Components", header: true },
27
- { text: "Badges", link: "/components/badges/" },
28
- { text: "Breadcrumbs", link: "/components/breadcrumbs/" },
29
- { text: "Buttons", link: "/components/buttons/" },
30
- { text: "Card", link: "/components/card/" },
31
- { text: "Carousel", link: "/components/carousel/" },
32
- { text: "Copyright", link: "/components/copyright/" },
33
- { text: "Details List", link: "/components/details-list/" },
34
- { text: "Features List", link: "/components/features-list/"},
35
- { text: "HandDrive", link: "/components/hand-drive/" },
36
- { text: "Headline", link: "/components/headline/" },
37
- { text: "Icons", link: "/components/icons/" },
38
- { text: "Image", link: "/components/image/" },
39
- { text: "Input", link: "/components/input/" },
40
- { text: "Jumbatron", link: "/components/jumbatron/" },
41
- { text: "Modal", link: "/components/modal/" },
42
- { text: "PostHeader", link: "/components/post-header/" },
43
- { text: "PR-Code", link: "/components/pr-code/" },
44
- { text: "Product Number", link: "/components/product-number/" },
45
- { text: "Product Tile", link: "/components/product-tile/" },
46
- { text: "Quote", link: "/components/quote/" },
47
- { text: "Table", link: "/components/table/" },
48
-
49
- { text: "Extras", header: true },
50
- { text: "Flags", link: "/components/flags/" },
51
- { text: "SlimBanner", link: "/components/slimbanner/" },
52
- { text: "FuckRussia", link: "/components/fuck-russia/" },
53
-
54
- { text: "Patterns", header: true },
55
- { text: "Introduction", link: "/patterns/introduction/" },
56
- ];
1
+ export const SITE = {
2
+ title: "Spoko Design System",
3
+ description: "The Astro design system which facilitates the development of websites.",
4
+ defaultLanguage: "en_US",
5
+ twitter: "@spokospace",
6
+ github: "spokospace",
7
+ linkedin: "szymonberski",
8
+ };
9
+
10
+ export const OPEN_GRAPH = {
11
+ image: {
12
+ src: "",
13
+ alt: "",
14
+ },
15
+ twitter: "",
16
+ };
17
+
18
+ export const SIDEBAR = [
19
+ { text: "Core", header: true },
20
+ { text: "Introduction", link: "/core/introduction/" },
21
+ { text: "Colors", link: "/core/colors/" },
22
+ { text: "Typography", link: "/core/typography/" },
23
+ { text: "Shadows", link: "/core/shadows/" },
24
+ { text: "Grid", link: "/core/grid/" },
25
+
26
+ { text: "Components", header: true },
27
+ { text: "Badges", link: "/components/badges/" },
28
+ { text: "Breadcrumbs", link: "/components/breadcrumbs/" },
29
+ { text: "Buttons", link: "/components/buttons/" },
30
+ { text: "Card", link: "/components/card/" },
31
+ { text: "Carousel", link: "/components/carousel/" },
32
+ { text: "Copyright", link: "/components/copyright/" },
33
+ { text: "Details List", link: "/components/details-list/" },
34
+ { text: "Features List", link: "/components/features-list/"},
35
+ { text: "HandDrive", link: "/components/hand-drive/" },
36
+ { text: "Headline", link: "/components/headline/" },
37
+ { text: "Icons", link: "/components/icons/" },
38
+ { text: "Image", link: "/components/image/" },
39
+ { text: "Input", link: "/components/input/" },
40
+ { text: "Jumbatron", link: "/components/jumbatron/" },
41
+ { text: "Modal", link: "/components/modal/" },
42
+ { text: "PostHeader", link: "/components/post-header/" },
43
+ { text: "PR-Code", link: "/components/pr-code/" },
44
+ { text: "Product Number", link: "/components/product-number/" },
45
+ { text: "Product Tile", link: "/components/product-tile/" },
46
+ { text: "Quote", link: "/components/quote/" },
47
+ { text: "Table", link: "/components/table/" },
48
+
49
+ { text: "Extras", header: true },
50
+ { text: "Flags", link: "/components/flags/" },
51
+ { text: "SlimBanner", link: "/components/slimbanner/" },
52
+ { text: "FuckRussia", link: "/components/fuck-russia/" },
53
+
54
+ { text: "Patterns", header: true },
55
+ { text: "Introduction", link: "/patterns/introduction/" },
56
+ ];
@@ -1,81 +1,81 @@
1
- export const COLORS = {
2
- gray: [
3
- { name: "100", value: "#f3f4f6" },
4
- { name: "200", value: "#e5e7eb" },
5
- { name: "300", value: "#b5bbc5" },
6
- { name: "400", value: "#9ca3af" },
7
- { name: "500", value: "#64748B" },
8
- { name: "600", value: "#475569" },
9
- { name: "700", value: "#334155" },
10
- { name: "800", value: "#1e293b" },
11
- { name: "900", value: "#0f172a" },
12
- ],
13
- blue: [
14
- { name: "50", value: "#eff6ff" },
15
- { name: "100", value: "#dbeafe" },
16
- { name: "200", value: "#bfdbfe" },
17
- { name: "300", value: "#93c5fd" },
18
- { name: "400", value: "#60a5fa" },
19
- { name: "500", value: "#3b82f6" },
20
- { name: "540", value: '#0069ff'},
21
- { name: "545", value: '#005ad7'},
22
- { name: "550", value: '#0040c5'},
23
- { name: "600", value: "#02307d" },
24
- { name: "601", value: '#002059'},
25
- { name: "700", value: "#001e50" },
26
- { name: "800", value: "#00437a" },
27
- { name: "900", value: "#000f28" },
28
- { name: "901", value: "#0c1a32" },
29
- { name: "wrc", value: "#0000c8" },
30
- ],
31
- lightBlue: [
32
- { name: "400", value: "#00b0f0" },
33
- { name: "500", value: "#0099da" },
34
- { name: "600", value: "#0087c1" },
35
- { name: "700", value: "#006ea6" },
36
- ],
37
- red: [
38
- { name: "400", value: "#f8b5b5" },
39
- { name: "500", value: "#f49f9f" },
40
- { name: "600", value: "#e57373" },
41
- ],
42
- };
43
-
44
- export const TYPOGRAPHY = {
45
- fontFamily: "Inter, system",
46
- scale: [
47
- { name: "h1", size: "22pt", weight: "400" },
48
- { name: "h2", size: "17pt", weight: "500" },
49
- { name: "h3", size: "13pt", weight: "600" },
50
- { name: "h4", size: "13pt", weight: "500" },
51
- { name: "body", size: "13pt", weight: "400" },
52
- { name: "button", size: "13pt", weight: "400" },
53
- { name: "caption", size: "10pt", weight: "400" },
54
- ],
55
- };
56
-
57
- export const SHADOWS = {
58
- types: [
59
- { name: "xs", value: "0px 2px 4px rgba(0, 0, 0, 0.08)" },
60
- { name: "sm", value: "0px 4px 8px rgba(0, 0, 0, 0.125)" },
61
- { name: "md", value: "0px 8px 16px rgba(0, 0, 0, 0.125)" },
62
- { name: "lg", value: "0px 16px 32px rgba(0, 0, 0, 0.125)" },
63
- { name: "xl", value: "0px 32px 64px rgba(0, 0, 0, 0.125)" },
64
- { name: "2xl", value: "0px 64px 128px rgba(0, 0, 0, 0.125)" },
65
- ],
66
- };
67
-
68
-
69
- export const FONTS = {
70
- types: [
71
- { name: "vw_textregular", value: "font-textregular" },
72
- { name: "vw_textregular", value: "font-sans" },
73
- { name: "vw_textbold", value: "font-textbold" },
74
- { name: "vw_headbold", value: "font-headbold" },
75
- { name: "vw_headregular", value: "font-headregular" },
76
- { name: "vw_headlight", value: "font-headlight" },
77
- { name: "vw_textlight", value: "font-textlight" },
78
- { name: "Nova Mono", value: "font-novamono" },
79
- { name: "Nova Mono", value: "font-mono" }
80
- ],
81
- };
1
+ export const COLORS = {
2
+ gray: [
3
+ { name: "100", value: "#f3f4f6" },
4
+ { name: "200", value: "#e5e7eb" },
5
+ { name: "300", value: "#b5bbc5" },
6
+ { name: "400", value: "#9ca3af" },
7
+ { name: "500", value: "#64748B" },
8
+ { name: "600", value: "#475569" },
9
+ { name: "700", value: "#334155" },
10
+ { name: "800", value: "#1e293b" },
11
+ { name: "900", value: "#0f172a" },
12
+ ],
13
+ blue: [
14
+ { name: "50", value: "#eff6ff" },
15
+ { name: "100", value: "#dbeafe" },
16
+ { name: "200", value: "#bfdbfe" },
17
+ { name: "300", value: "#93c5fd" },
18
+ { name: "400", value: "#60a5fa" },
19
+ { name: "500", value: "#3b82f6" },
20
+ { name: "540", value: '#0069ff'},
21
+ { name: "545", value: '#005ad7'},
22
+ { name: "550", value: '#0040c5'},
23
+ { name: "600", value: "#02307d" },
24
+ { name: "601", value: '#002059'},
25
+ { name: "700", value: "#001e50" },
26
+ { name: "800", value: "#00437a" },
27
+ { name: "900", value: "#000f28" },
28
+ { name: "901", value: "#0c1a32" },
29
+ { name: "wrc", value: "#0000c8" },
30
+ ],
31
+ lightBlue: [
32
+ { name: "400", value: "#00b0f0" },
33
+ { name: "500", value: "#0099da" },
34
+ { name: "600", value: "#0087c1" },
35
+ { name: "700", value: "#006ea6" },
36
+ ],
37
+ red: [
38
+ { name: "400", value: "#f8b5b5" },
39
+ { name: "500", value: "#f49f9f" },
40
+ { name: "600", value: "#e57373" },
41
+ ],
42
+ };
43
+
44
+ export const TYPOGRAPHY = {
45
+ fontFamily: "Inter, system",
46
+ scale: [
47
+ { name: "h1", size: "22pt", weight: "400" },
48
+ { name: "h2", size: "17pt", weight: "500" },
49
+ { name: "h3", size: "13pt", weight: "600" },
50
+ { name: "h4", size: "13pt", weight: "500" },
51
+ { name: "body", size: "13pt", weight: "400" },
52
+ { name: "button", size: "13pt", weight: "400" },
53
+ { name: "caption", size: "10pt", weight: "400" },
54
+ ],
55
+ };
56
+
57
+ export const SHADOWS = {
58
+ types: [
59
+ { name: "xs", value: "0px 2px 4px rgba(0, 0, 0, 0.08)" },
60
+ { name: "sm", value: "0px 4px 8px rgba(0, 0, 0, 0.125)" },
61
+ { name: "md", value: "0px 8px 16px rgba(0, 0, 0, 0.125)" },
62
+ { name: "lg", value: "0px 16px 32px rgba(0, 0, 0, 0.125)" },
63
+ { name: "xl", value: "0px 32px 64px rgba(0, 0, 0, 0.125)" },
64
+ { name: "2xl", value: "0px 64px 128px rgba(0, 0, 0, 0.125)" },
65
+ ],
66
+ };
67
+
68
+
69
+ export const FONTS = {
70
+ types: [
71
+ { name: "vw_textregular", value: "font-textregular" },
72
+ { name: "vw_textregular", value: "font-sans" },
73
+ { name: "vw_textbold", value: "font-textbold" },
74
+ { name: "vw_headbold", value: "font-headbold" },
75
+ { name: "vw_headregular", value: "font-headregular" },
76
+ { name: "vw_headlight", value: "font-headlight" },
77
+ { name: "vw_textlight", value: "font-textlight" },
78
+ { name: "Nova Mono", value: "font-novamono" },
79
+ { name: "Nova Mono", value: "font-mono" }
80
+ ],
81
+ };
package/src/env.d.ts CHANGED
@@ -1,2 +1,2 @@
1
- /// <reference path="../.astro/types.d.ts" />
1
+ /// <reference path="../.astro/types.d.ts" />
2
2
  /// <reference types="astro/client" />
@@ -1,60 +1,60 @@
1
- ---
2
- import HeadCommon from "./partials/HeadCommon.astro";
3
- import FooterCommon from "./partials/FooterCommon.astro";
4
- import HeadSEO from "../layouts/partials/HeadSEO.astro";
5
- import * as CONFIG from "../config";
6
- import { t, changeLanguage } from "i18next";
7
- import "../styles/main.css";
8
- import Copyright from "../components/Copyright.astro";
9
- const locale = "en";
10
- changeLanguage(locale);
11
- const { content = {} } = Astro.props;
12
- const canonicalURL = new URL(Astro.url.pathname, Astro.site).toString();
13
- ---
14
-
15
- <html dir={content.dir ?? "ltr"} lang={content.lang ?? "en-us"} class="initial">
16
- <head>
17
- <HeadCommon />
18
- <HeadSEO {content} canonicalURL={canonicalURL} />
19
- <title>
20
- {
21
- content.title
22
- ? `${content.title} 🚀 ${CONFIG.SITE.title}`
23
- : CONFIG.SITE.title
24
- }
25
- </title>
26
- </head>
27
-
28
- <body class="bg-blue-50">
29
- <div class="bg-white z-10 mb-11 relative">
30
- <slot />
31
- </div>
32
- <footer>
33
- <Copyright class="fixed bottom-0 z-0 w-full">
34
- <a
35
- slot="middle-item"
36
- href={`https://spoko.space`}
37
- target="_blank"
38
- rel="follow noopener"
39
- class="flex my-auto items-center mx-auto"
40
- title={`Proudly made in Poland by ${
41
- import.meta.env.COPYRIGHT_DOMAIN
42
- }`}
43
- >
44
- <div class="text-xxs md:text-xs mr-1 mt-0.5 whitespace-nowrap">
45
- createdy by
46
- </div>
47
- <img
48
- class="h-4 w-min md:h-5 "
49
- src="spoko.space.svg"
50
- alt="Modern Websites"
51
- width="126"
52
- height="23"
53
- loading="lazy"
54
- />
55
- </a>
56
- </Copyright>
57
- <FooterCommon />
58
- </footer>
59
- </body>
60
- </html>
1
+ ---
2
+ import HeadCommon from "./partials/HeadCommon.astro";
3
+ import FooterCommon from "./partials/FooterCommon.astro";
4
+ import HeadSEO from "../layouts/partials/HeadSEO.astro";
5
+ import * as CONFIG from "../config";
6
+ import { t, changeLanguage } from "i18next";
7
+ import "../styles/main.css";
8
+ import Copyright from "../components/Copyright.astro";
9
+ const locale = "en";
10
+ changeLanguage(locale);
11
+ const { content = {} } = Astro.props;
12
+ const canonicalURL = new URL(Astro.url.pathname, Astro.site).toString();
13
+ ---
14
+
15
+ <html dir={content.dir ?? "ltr"} lang={content.lang ?? "en-us"} class="initial">
16
+ <head>
17
+ <HeadCommon />
18
+ <HeadSEO {content} canonicalURL={canonicalURL} />
19
+ <title>
20
+ {
21
+ content.title
22
+ ? `${content.title} 🚀 ${CONFIG.SITE.title}`
23
+ : CONFIG.SITE.title
24
+ }
25
+ </title>
26
+ </head>
27
+
28
+ <body class="bg-blue-50">
29
+ <div class="bg-white z-10 mb-11 relative">
30
+ <slot />
31
+ </div>
32
+ <footer>
33
+ <Copyright class="fixed bottom-0 z-0 w-full">
34
+ <a
35
+ slot="middle-item"
36
+ href={`https://spoko.space`}
37
+ target="_blank"
38
+ rel="follow noopener"
39
+ class="flex my-auto items-center mx-auto"
40
+ title={`Proudly made in Poland by ${
41
+ import.meta.env.COPYRIGHT_DOMAIN
42
+ }`}
43
+ >
44
+ <div class="text-xxs md:text-xs mr-1 mt-0.5 whitespace-nowrap">
45
+ createdy by
46
+ </div>
47
+ <img
48
+ class="h-4 w-min md:h-5 "
49
+ src="spoko.space.svg"
50
+ alt="Modern Websites"
51
+ width="126"
52
+ height="23"
53
+ loading="lazy"
54
+ />
55
+ </a>
56
+ </Copyright>
57
+ <FooterCommon />
58
+ </footer>
59
+ </body>
60
+ </html>
@@ -1,81 +1,81 @@
1
- ---
2
- import HeadCommon from "./partials/HeadCommon.astro";
3
- import HeadSEO from "../layouts/partials/HeadSEO.astro";
4
- import Header from "../components/Header/Header.astro";
5
- import PageContent from "../components/PageContent.astro";
6
- import LeftSidebar from "../components/LeftSidebar.astro";
7
- import * as CONFIG from "../config";
8
- import { t, changeLanguage } from "i18next";
9
- import "../styles/main.css";
10
- import Copyright from "../components/Copyright.astro";
11
- const locale = "en";
12
- changeLanguage(locale);
13
- const { content = {} } = Astro.props;
14
- const currentPage = Astro.url.pathname;
15
- const canonicalURL = new URL(Astro.url.pathname, Astro.site).toString();
16
- ---
17
-
18
- <script>
19
- // Swiper Element
20
- import { register } from "swiper/element/bundle";
21
- document.addEventListener("astro:page-load", () => {
22
- register();
23
- });
24
- </script>
25
-
26
- <html dir={content.dir ?? "ltr"} lang={content.lang ?? "en-us"} class="initial">
27
- <head>
28
- <HeadCommon />
29
- <HeadSEO content={content} canonicalURL={canonicalURL} />
30
- <title>
31
- {
32
- content.title
33
- ? `${content.title} 🚀 ${CONFIG.SITE.title}`
34
- : CONFIG.SITE.title
35
- }
36
- </title>
37
- </head>
38
-
39
- <body class="bg-blue-50">
40
- <div class="sticky top-0 z-20 w-full bg-white/70">
41
- <Header currentPage={currentPage} />
42
- </div>
43
-
44
- <div class="flex bg-white z-10 mb-11 relative">
45
- <div class="sticky top-0 flex lg:(h-screen w-64) z-50">
46
- <div class="mr-auto" transition:name="sidebar">
47
- <LeftSidebar currentPage={currentPage} />
48
- </div>
49
- </div>
50
- <main class="pb-4 px-4 sm:px-8 col-auto sm:(pb-32) overflow-auto w-full">
51
- <PageContent content={content} transition:name="content">
52
- <slot />
53
- </PageContent>
54
- </main>
55
- </div>
56
- <footer>
57
- <Copyright class="fixed bottom-0 z-0 w-full">
58
- <a
59
- slot="middle-item"
60
- href="https://spoko.space"
61
- target="_blank"
62
- rel="follow noopener"
63
- class="flex my-auto items-center mx-auto"
64
- title={`Proudly made in Poland by spoko.space`}
65
- >
66
- <div class="text-xxs md:text-xs mr-1 mt-0.5 whitespace-nowrap">
67
- createdy by
68
- </div>
69
- <img
70
- class="h-4 md:h-5 w-min"
71
- src="/spoko.space.svg"
72
- alt="Modern Websites"
73
- width="126"
74
- height="23"
75
- loading="lazy"
76
- />
77
- </a>
78
- </Copyright>
79
- </footer>
80
- </body>
81
- </html>
1
+ ---
2
+ import HeadCommon from "./partials/HeadCommon.astro";
3
+ import HeadSEO from "../layouts/partials/HeadSEO.astro";
4
+ import Header from "../components/Header/Header.astro";
5
+ import PageContent from "../components/PageContent.astro";
6
+ import LeftSidebar from "../components/LeftSidebar.astro";
7
+ import * as CONFIG from "../config";
8
+ import { t, changeLanguage } from "i18next";
9
+ import "../styles/main.css";
10
+ import Copyright from "../components/Copyright.astro";
11
+ const locale = "en";
12
+ changeLanguage(locale);
13
+ const { content = {} } = Astro.props;
14
+ const currentPage = Astro.url.pathname;
15
+ const canonicalURL = new URL(Astro.url.pathname, Astro.site).toString();
16
+ ---
17
+
18
+ <script>
19
+ // Swiper Element
20
+ import { register } from "swiper/element/bundle";
21
+ document.addEventListener("astro:page-load", () => {
22
+ register();
23
+ });
24
+ </script>
25
+
26
+ <html dir={content.dir ?? "ltr"} lang={content.lang ?? "en-us"} class="initial">
27
+ <head>
28
+ <HeadCommon />
29
+ <HeadSEO content={content} canonicalURL={canonicalURL} />
30
+ <title>
31
+ {
32
+ content.title
33
+ ? `${content.title} 🚀 ${CONFIG.SITE.title}`
34
+ : CONFIG.SITE.title
35
+ }
36
+ </title>
37
+ </head>
38
+
39
+ <body class="bg-blue-50">
40
+ <div class="sticky top-0 z-20 w-full bg-white/70">
41
+ <Header currentPage={currentPage} />
42
+ </div>
43
+
44
+ <div class="flex bg-white z-10 mb-11 relative">
45
+ <div class="sticky top-0 flex lg:(h-screen w-64) z-50">
46
+ <div class="mr-auto" transition:name="sidebar">
47
+ <LeftSidebar currentPage={currentPage} />
48
+ </div>
49
+ </div>
50
+ <main class="pb-4 px-4 sm:px-8 col-auto sm:(pb-32) overflow-auto w-full">
51
+ <PageContent content={content} transition:name="content">
52
+ <slot />
53
+ </PageContent>
54
+ </main>
55
+ </div>
56
+ <footer>
57
+ <Copyright class="fixed bottom-0 z-0 w-full">
58
+ <a
59
+ slot="middle-item"
60
+ href="https://spoko.space"
61
+ target="_blank"
62
+ rel="follow noopener"
63
+ class="flex my-auto items-center mx-auto"
64
+ title={`Proudly made in Poland by spoko.space`}
65
+ >
66
+ <div class="text-xxs md:text-xs mr-1 mt-0.5 whitespace-nowrap">
67
+ createdy by
68
+ </div>
69
+ <img
70
+ class="h-4 md:h-5 w-min"
71
+ src="/spoko.space.svg"
72
+ alt="Modern Websites"
73
+ width="126"
74
+ height="23"
75
+ loading="lazy"
76
+ />
77
+ </a>
78
+ </Copyright>
79
+ </footer>
80
+ </body>
81
+ </html>
@@ -1,5 +1,5 @@
1
- ---
2
- import ReloadPrompt from "../../components/ReloadPrompt.astro";
3
- ---
4
-
1
+ ---
2
+ import ReloadPrompt from "../../components/ReloadPrompt.astro";
3
+ ---
4
+
5
5
  <ReloadPrompt />