spoko-design-system 0.2.48 → 0.2.50

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 (154) hide show
  1. package/.github/dependabot.yml +11 -11
  2. package/.github/todo.yml +3 -3
  3. package/.github/workflows/deploy.yml +39 -39
  4. package/.stackblitzrc +5 -5
  5. package/.vscode/extensions.json +5 -5
  6. package/.vscode/launch.json +11 -11
  7. package/.vscode/settings.json +5 -5
  8. package/LICENSE +21 -21
  9. package/README.md +113 -113
  10. package/astro-i18next.config.mjs +17 -17
  11. package/astro-i18next.config.ts +10 -10
  12. package/astro.config.mjs +147 -147
  13. package/dev-dist/sw.js +91 -91
  14. package/dev-dist/workbox-c676b6d3.js +3391 -3391
  15. package/index.ts +63 -61
  16. package/package.json +109 -109
  17. package/public/fonts/lg.svg +53 -53
  18. package/public/fonts/vwhead-bold-demo.html +549 -549
  19. package/public/fonts/vwhead-regular-demo.html +549 -549
  20. package/public/fonts/vwtext-bold-demo.html +549 -549
  21. package/public/fonts/vwtext-regular-demo.html +549 -549
  22. package/public/github.svg +3 -3
  23. package/public/grid_dot.svg +4 -4
  24. package/public/linkedin.svg +44 -44
  25. package/public/locales/en/translation.json +8 -8
  26. package/public/locales/pl/translation.json +8 -8
  27. package/public/make-scrollable-code-focusable.js +3 -3
  28. package/public/pagefind.yml +3 -3
  29. package/public/polo.blue.svg +29 -29
  30. package/public/spoko.space.svg +71 -71
  31. package/public/twitter.svg +46 -46
  32. package/renovate.json +6 -6
  33. package/sandbox.config.json +11 -11
  34. package/src/MyComponent.astro +8 -8
  35. package/src/components/Badge.vue +19 -19
  36. package/src/components/Badges.vue +21 -21
  37. package/src/components/Breadcrumbs.vue +107 -107
  38. package/src/components/Button.vue +55 -55
  39. package/src/components/ButtonCopy.vue +36 -47
  40. package/src/components/Card.astro +27 -27
  41. package/src/components/Carousel.astro +26 -26
  42. package/src/components/Category/CategoriesCarousel.astro +101 -101
  43. package/src/components/Category/CategoriesSidebar.astro +186 -186
  44. package/src/components/Category/CategoryDetails.astro +82 -82
  45. package/src/components/Category/CategoryLink.vue +23 -23
  46. package/src/components/Category/CategorySection.astro +69 -69
  47. package/src/components/Category/CategorySidebarToggler.vue +9 -9
  48. package/src/components/Category/CategoryTile.astro +42 -42
  49. package/src/components/Category/SubCategoryLink.vue +29 -29
  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 +62 -62
  57. package/src/components/HandDrive.astro +29 -29
  58. package/src/components/Header/Header.astro +210 -210
  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 +141 -141
  71. package/src/components/Product/ProductButton.vue +18 -18
  72. package/src/components/Product/ProductCodes.vue +174 -174
  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 +61 -105
  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/ProductTile.astro +48 -48
  82. package/src/components/Quote.vue +23 -23
  83. package/src/components/ReloadPrompt.astro +50 -50
  84. package/src/components/SlimBanner.vue +72 -72
  85. package/src/components/Table.vue +32 -32
  86. package/src/components/TableOfContents.astro +15 -15
  87. package/src/components/Translations.vue +23 -23
  88. package/src/components/flags/FlagPL.vue +3 -3
  89. package/src/components/flags/FlagUA.vue +2 -2
  90. package/src/components/layout/Container.astro +7 -7
  91. package/src/components/layout/Header.astro +80 -80
  92. package/src/config.ts +56 -56
  93. package/src/design.config.ts +81 -81
  94. package/src/env.d.ts +1 -1
  95. package/src/layouts/Layout.astro +60 -60
  96. package/src/layouts/MainLayout.astro +81 -81
  97. package/src/layouts/partials/FooterCommon.astro +4 -4
  98. package/src/layouts/partials/HeadCommon.astro +44 -44
  99. package/src/layouts/partials/HeadSEO.astro +41 -41
  100. package/src/pages/components/badges.mdx +57 -57
  101. package/src/pages/components/breadcrumbs.mdx +139 -139
  102. package/src/pages/components/buttons.mdx +236 -236
  103. package/src/pages/components/card.mdx +294 -294
  104. package/src/pages/components/carousel.mdx +62 -62
  105. package/src/pages/components/copyright.mdx +42 -42
  106. package/src/pages/components/details-list.mdx +115 -115
  107. package/src/pages/components/features-list.mdx +37 -37
  108. package/src/pages/components/flags.mdx +49 -49
  109. package/src/pages/components/fuck-russia.mdx +39 -39
  110. package/src/pages/components/hand-drive.mdx +38 -38
  111. package/src/pages/components/headline.mdx +152 -152
  112. package/src/pages/components/icons.astro +48 -48
  113. package/src/pages/components/image.mdx +513 -513
  114. package/src/pages/components/input.mdx +45 -45
  115. package/src/pages/components/jumbatron.mdx +95 -95
  116. package/src/pages/components/modal.mdx +64 -64
  117. package/src/pages/components/post-header.mdx +60 -60
  118. package/src/pages/components/pr-code.mdx +65 -65
  119. package/src/pages/components/product-number.mdx +59 -66
  120. package/src/pages/components/product-tile.mdx +51 -51
  121. package/src/pages/components/quote.mdx +33 -33
  122. package/src/pages/components/slimbanner.mdx +35 -35
  123. package/src/pages/components/table.mdx +108 -108
  124. package/src/pages/core/colors.mdx +10 -10
  125. package/src/pages/core/grid.mdx +89 -89
  126. package/src/pages/core/introduction.mdx +77 -77
  127. package/src/pages/core/shadows.astro +20 -20
  128. package/src/pages/core/typography.astro +47 -47
  129. package/src/pages/index.astro +126 -126
  130. package/src/pages/patterns/introduction.mdx +60 -60
  131. package/src/pwa.ts +12 -12
  132. package/src/styles/_variables.scss +70 -70
  133. package/src/styles/base/base.css +184 -184
  134. package/src/styles/base/grid.css +92 -92
  135. package/src/styles/base/typography.css +70 -70
  136. package/src/styles/content.css +73 -73
  137. package/src/styles/main.css +7 -7
  138. package/src/types/Product.ts +31 -31
  139. package/src/types/astro.d.ts +3 -3
  140. package/src/utils/product/getPriceFormatted.ts +15 -15
  141. package/src/utils/product/getProductChecklist.ts +17 -17
  142. package/src/utils/product/useFormatProductNumber.ts +42 -0
  143. package/src/utils/seo/getShorterDescription.ts +14 -14
  144. package/src/utils/text/formatDate.ts +5 -5
  145. package/src/utils/text/formatLocaleNumber.ts +6 -6
  146. package/src/utils/text/formatPad.ts +12 -12
  147. package/src/utils/text/getNumberFormatted.ts +33 -33
  148. package/src/utils/text/getTranslatedLink.ts +7 -7
  149. package/src/utils/text.ts +28 -43
  150. package/tailwind.config.cjs +8 -8
  151. package/tsconfig.json +28 -28
  152. package/uno.config.ts +256 -256
  153. package/src/components/ProductNumber copy.astro +0 -116
  154. package/src/components/ProductNumber.astro +0 -105
@@ -1,4 +1,4 @@
1
- <template>
2
- <span
3
- class="drop-shadow inline-block text-4xl w-6 h-3.5 min-w-[1.25rem] mr-3 bg-gradient-to-b stops-[#fff_50%,50%,#d4213d_100%]" />
1
+ <template>
2
+ <span
3
+ class="drop-shadow inline-block text-4xl w-6 h-3.5 min-w-[1.25rem] mr-3 bg-gradient-to-b stops-[#fff_50%,50%,#d4213d_100%]" />
4
4
  </template>
@@ -1,3 +1,3 @@
1
- <template>
2
- <span class="flag-ua" />
1
+ <template>
2
+ <span class="flag-ua" />
3
3
  </template>
@@ -1,7 +1,7 @@
1
- ---
2
- const { class: className, isFullWidth } = Astro.props;
3
- ---
4
-
5
- <div class:list={[`${isFullWidth ? 'max-w-full' : 'max-w-screen-xl'} mx-auto px-5 py-4`, className]}>
6
- <slot />
7
- </div>
1
+ ---
2
+ const { class: className, isFullWidth } = Astro.props;
3
+ ---
4
+
5
+ <div class:list={[`${isFullWidth ? 'max-w-full' : 'max-w-screen-xl'} mx-auto px-5 py-4`, className]}>
6
+ <slot />
7
+ </div>
@@ -1,80 +1,80 @@
1
- ---
2
- const { class: className } = Astro.props;
3
- import { Icon } from "astro-icon/components";
4
-
5
- const navItemsLeft = [
6
- {
7
- title: "Components",
8
- description: "The building blocks for our UI.",
9
- url: "/components/buttons",
10
- img: "/Components.jpg",
11
- },
12
- {
13
- title: "Patterns",
14
- description: "Common patterns for building interfaces.",
15
- url: "/patterns/introduction",
16
- img: "/Patterns.jpg",
17
- },
18
- ];
19
- ---
20
-
21
- <nav
22
- itemscope
23
- itemtype="http://schema.org/WPHeader"
24
- class:list={[
25
- className,
26
- "nav print-hidden mx-auto px-4 shadow-md relative flex items-center justify-between h-24 sm:h-14 flex-wrap sm:flex-nowrap pt-1 sm:pt-0",
27
- ]}
28
- >
29
- <div class="flex items-center justify-start sm:items-stretch order-1">
30
- <slot name="logo" />
31
-
32
- <div class="hidden sm:block sm:ml-6">
33
- <div class="flex space-x-4" itemprop="hasPart">
34
- {
35
- navItemsLeft.map(({ title, description, url, img }) => (
36
- <a
37
- href={url}
38
- class="text-gray-400 hover:bg-blue-700 hover:text-white px-3 py-1 rounded-full text-sm font-medium"
39
- title={description}
40
- itemprop="url"
41
- >
42
- {title}
43
- </a>
44
- ))
45
- }
46
- </div>
47
- </div>
48
- </div>
49
-
50
- <div
51
- class="relative md:block sm:ml-4 w-full order-4 h-10 md:(w-64 mr-auto order-2)"
52
- >
53
- <slot name="search" />
54
- </div>
55
-
56
- <div
57
- class="flex items-center pr-0 sm:static sm:inset-auto ml-auto sm:ml-6 -mr-2 print:hidden order-3 sm:order-3 w-20 justify-end"
58
- itemprop="hasPart"
59
- itemscope
60
- itemtype="http://schema.org/SiteNavigationElement"
61
- >
62
- <a
63
- class="icon-btn mx-2"
64
- title=""
65
- aria-label=""
66
- href="#"
67
- itemprop="url"
68
- data-astro-reload
69
- >
70
- <Icon name="carbon:language" />
71
- </a>
72
- </div>
73
- </nav>
74
-
75
- <style is:global>
76
- nav {
77
- /* display: grid; */
78
- place-items: center;
79
- }
80
- </style>
1
+ ---
2
+ const { class: className } = Astro.props;
3
+ import { Icon } from "astro-icon/components";
4
+
5
+ const navItemsLeft = [
6
+ {
7
+ title: "Components",
8
+ description: "The building blocks for our UI.",
9
+ url: "/components/buttons",
10
+ img: "/Components.jpg",
11
+ },
12
+ {
13
+ title: "Patterns",
14
+ description: "Common patterns for building interfaces.",
15
+ url: "/patterns/introduction",
16
+ img: "/Patterns.jpg",
17
+ },
18
+ ];
19
+ ---
20
+
21
+ <nav
22
+ itemscope
23
+ itemtype="http://schema.org/WPHeader"
24
+ class:list={[
25
+ className,
26
+ "nav print-hidden mx-auto px-4 shadow-md relative flex items-center justify-between h-24 sm:h-14 flex-wrap sm:flex-nowrap pt-1 sm:pt-0",
27
+ ]}
28
+ >
29
+ <div class="flex items-center justify-start sm:items-stretch order-1">
30
+ <slot name="logo" />
31
+
32
+ <div class="hidden sm:block sm:ml-6">
33
+ <div class="flex space-x-4" itemprop="hasPart">
34
+ {
35
+ navItemsLeft.map(({ title, description, url, img }) => (
36
+ <a
37
+ href={url}
38
+ class="text-gray-400 hover:bg-blue-700 hover:text-white px-3 py-1 rounded-full text-sm font-medium"
39
+ title={description}
40
+ itemprop="url"
41
+ >
42
+ {title}
43
+ </a>
44
+ ))
45
+ }
46
+ </div>
47
+ </div>
48
+ </div>
49
+
50
+ <div
51
+ class="relative md:block sm:ml-4 w-full order-4 h-10 md:(w-64 mr-auto order-2)"
52
+ >
53
+ <slot name="search" />
54
+ </div>
55
+
56
+ <div
57
+ class="flex items-center pr-0 sm:static sm:inset-auto ml-auto sm:ml-6 -mr-2 print:hidden order-3 sm:order-3 w-20 justify-end"
58
+ itemprop="hasPart"
59
+ itemscope
60
+ itemtype="http://schema.org/SiteNavigationElement"
61
+ >
62
+ <a
63
+ class="icon-btn mx-2"
64
+ title=""
65
+ aria-label=""
66
+ href="#"
67
+ itemprop="url"
68
+ data-astro-reload
69
+ >
70
+ <Icon name="carbon:language" />
71
+ </a>
72
+ </div>
73
+ </nav>
74
+
75
+ <style is:global>
76
+ nav {
77
+ /* display: grid; */
78
+ place-items: center;
79
+ }
80
+ </style>
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>