spoko-design-system 0.2.49 → 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.
- package/.github/dependabot.yml +11 -11
- package/.github/todo.yml +3 -3
- package/.github/workflows/deploy.yml +39 -39
- package/.stackblitzrc +5 -5
- package/.vscode/extensions.json +5 -5
- package/.vscode/launch.json +11 -11
- package/.vscode/settings.json +5 -5
- package/LICENSE +21 -21
- package/README.md +113 -113
- package/astro-i18next.config.mjs +17 -17
- package/astro-i18next.config.ts +10 -10
- package/astro.config.mjs +147 -147
- package/dev-dist/sw.js +91 -91
- package/dev-dist/workbox-c676b6d3.js +3391 -3391
- package/index.ts +63 -61
- package/package.json +109 -109
- package/public/fonts/lg.svg +53 -53
- package/public/fonts/vwhead-bold-demo.html +549 -549
- package/public/fonts/vwhead-regular-demo.html +549 -549
- package/public/fonts/vwtext-bold-demo.html +549 -549
- package/public/fonts/vwtext-regular-demo.html +549 -549
- package/public/github.svg +3 -3
- package/public/grid_dot.svg +4 -4
- package/public/linkedin.svg +44 -44
- package/public/locales/en/translation.json +8 -8
- package/public/locales/pl/translation.json +8 -8
- package/public/make-scrollable-code-focusable.js +3 -3
- package/public/pagefind.yml +3 -3
- package/public/polo.blue.svg +29 -29
- package/public/spoko.space.svg +71 -71
- package/public/twitter.svg +46 -46
- package/renovate.json +6 -6
- package/sandbox.config.json +11 -11
- package/src/MyComponent.astro +8 -8
- package/src/components/Badge.vue +19 -19
- package/src/components/Badges.vue +21 -21
- package/src/components/Breadcrumbs.vue +107 -107
- package/src/components/Button.vue +55 -55
- package/src/components/ButtonCopy.vue +36 -47
- package/src/components/Card.astro +27 -27
- package/src/components/Carousel.astro +26 -26
- package/src/components/Category/CategoriesCarousel.astro +101 -101
- package/src/components/Category/CategoriesSidebar.astro +186 -186
- package/src/components/Category/CategoryDetails.astro +82 -82
- package/src/components/Category/CategoryLink.vue +23 -23
- package/src/components/Category/CategorySection.astro +69 -69
- package/src/components/Category/CategorySidebarToggler.vue +9 -9
- package/src/components/Category/CategoryTile.astro +42 -42
- package/src/components/Category/SubCategoryLink.vue +29 -29
- package/src/components/CategoryLink.astro +18 -18
- package/src/components/Copyright.astro +12 -12
- package/src/components/Date.astro +7 -7
- package/src/components/Faq.astro +33 -33
- package/src/components/FaqItem.astro +96 -96
- package/src/components/FeaturesList.vue +41 -41
- package/src/components/FuckRussia.vue +62 -62
- package/src/components/HandDrive.astro +29 -29
- package/src/components/Header/Header.astro +210 -210
- package/src/components/Header/SkipToContent.astro +1 -1
- package/src/components/Headline.vue +48 -48
- package/src/components/Image.astro +30 -30
- package/src/components/Jumbatron.vue +40 -40
- package/src/components/LeftSidebar.astro +53 -53
- package/src/components/MainColors.vue +23 -23
- package/src/components/MainInput.vue +15 -15
- package/src/components/Modal.astro +27 -27
- package/src/components/PageContent.astro +5 -5
- package/src/components/PartNumber.vue +27 -27
- package/src/components/PostHeader.astro +103 -103
- package/src/components/PrCode.vue +141 -141
- package/src/components/Product/ProductButton.vue +18 -18
- package/src/components/Product/ProductCodes.vue +174 -174
- package/src/components/Product/ProductEngineType.vue +42 -42
- package/src/components/Product/ProductImage.astro +41 -41
- package/src/components/Product/ProductLinkInfo.astro +37 -37
- package/src/components/Product/ProductNumber.astro +61 -105
- package/src/components/ProductCarousel.astro +38 -38
- package/src/components/ProductCodes.vue +39 -39
- package/src/components/ProductDetailName.vue +52 -52
- package/src/components/ProductDetailsList.vue +65 -65
- package/src/components/ProductTile.astro +48 -48
- package/src/components/Quote.vue +23 -23
- package/src/components/ReloadPrompt.astro +50 -50
- package/src/components/SlimBanner.vue +72 -72
- package/src/components/Table.vue +32 -32
- package/src/components/TableOfContents.astro +15 -15
- package/src/components/Translations.vue +23 -23
- package/src/components/flags/FlagPL.vue +3 -3
- package/src/components/flags/FlagUA.vue +2 -2
- package/src/components/layout/Container.astro +7 -7
- package/src/components/layout/Header.astro +80 -80
- package/src/config.ts +56 -56
- package/src/design.config.ts +81 -81
- package/src/env.d.ts +1 -1
- package/src/layouts/Layout.astro +60 -60
- package/src/layouts/MainLayout.astro +81 -81
- package/src/layouts/partials/FooterCommon.astro +4 -4
- package/src/layouts/partials/HeadCommon.astro +44 -44
- package/src/layouts/partials/HeadSEO.astro +41 -41
- package/src/pages/components/badges.mdx +57 -57
- package/src/pages/components/breadcrumbs.mdx +139 -139
- package/src/pages/components/buttons.mdx +236 -236
- package/src/pages/components/card.mdx +294 -294
- package/src/pages/components/carousel.mdx +62 -62
- package/src/pages/components/copyright.mdx +42 -42
- package/src/pages/components/details-list.mdx +115 -115
- package/src/pages/components/features-list.mdx +37 -37
- package/src/pages/components/flags.mdx +49 -49
- package/src/pages/components/fuck-russia.mdx +39 -39
- package/src/pages/components/hand-drive.mdx +38 -38
- package/src/pages/components/headline.mdx +152 -152
- package/src/pages/components/icons.astro +48 -48
- package/src/pages/components/image.mdx +513 -513
- package/src/pages/components/input.mdx +45 -45
- package/src/pages/components/jumbatron.mdx +95 -95
- package/src/pages/components/modal.mdx +64 -64
- package/src/pages/components/post-header.mdx +60 -60
- package/src/pages/components/pr-code.mdx +65 -65
- package/src/pages/components/product-number.mdx +59 -66
- package/src/pages/components/product-tile.mdx +51 -51
- package/src/pages/components/quote.mdx +33 -33
- package/src/pages/components/slimbanner.mdx +35 -35
- package/src/pages/components/table.mdx +108 -108
- package/src/pages/core/colors.mdx +10 -10
- package/src/pages/core/grid.mdx +89 -89
- package/src/pages/core/introduction.mdx +77 -77
- package/src/pages/core/shadows.astro +20 -20
- package/src/pages/core/typography.astro +47 -47
- package/src/pages/index.astro +126 -126
- package/src/pages/patterns/introduction.mdx +60 -60
- package/src/pwa.ts +12 -12
- package/src/styles/_variables.scss +70 -70
- package/src/styles/base/base.css +184 -184
- package/src/styles/base/grid.css +92 -92
- package/src/styles/base/typography.css +70 -70
- package/src/styles/content.css +73 -73
- package/src/styles/main.css +7 -7
- package/src/types/Product.ts +31 -31
- package/src/types/astro.d.ts +3 -3
- package/src/utils/product/getPriceFormatted.ts +15 -15
- package/src/utils/product/getProductChecklist.ts +17 -17
- package/src/utils/product/useFormatProductNumber.ts +42 -0
- package/src/utils/seo/getShorterDescription.ts +14 -14
- package/src/utils/text/formatDate.ts +5 -5
- package/src/utils/text/formatLocaleNumber.ts +6 -6
- package/src/utils/text/formatPad.ts +12 -12
- package/src/utils/text/getNumberFormatted.ts +33 -33
- package/src/utils/text/getTranslatedLink.ts +7 -7
- package/src/utils/text.ts +28 -43
- package/tailwind.config.cjs +8 -8
- package/tsconfig.json +28 -28
- package/uno.config.ts +256 -256
- package/src/components/ProductNumber copy.astro +0 -116
- 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
|
+
];
|
package/src/design.config.ts
CHANGED
|
@@ -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" />
|
package/src/layouts/Layout.astro
CHANGED
|
@@ -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>
|