spoko-design-system 0.2.80 → 0.2.81
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 +65 -65
- package/package.json +3 -3
- 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 -36
- 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 +49 -49
- 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/ProductCarousel.astro +35 -35
- package/src/components/Product/ProductCodes.vue +174 -174
- package/src/components/Product/ProductEngineType.vue +42 -42
- package/src/components/Product/ProductImage.astro +40 -40
- package/src/components/Product/ProductLink.astro +101 -101
- package/src/components/Product/ProductLink.vue +59 -59
- package/src/components/Product/ProductLinkInfo.astro +37 -37
- package/src/components/Product/ProductNumber.astro +61 -61
- 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 +58 -58
- 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 +41 -41
- 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 +5 -5
- package/src/utils/text.ts +28 -28
- package/tailwind.config.cjs +8 -8
- package/tsconfig.json +28 -28
- package/uno.config.ts +256 -256
package/src/components/Faq.astro
CHANGED
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
---
|
|
2
|
-
|
|
3
|
-
/*
|
|
4
|
-
FAQ component for questons & answers with structured microdata for rich snippets
|
|
5
|
-
https://developers.google.com/search/docs/appearance/structured-data/faqpage?hl=en
|
|
6
|
-
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import {t } from "i18next"
|
|
10
|
-
import FaqItem from "@components/FaqItem.astro"
|
|
11
|
-
|
|
12
|
-
interface Props {
|
|
13
|
-
|
|
14
|
-
questions: {
|
|
15
|
-
question: string;
|
|
16
|
-
answer: string;
|
|
17
|
-
}[]
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
const { questions } = Astro.props
|
|
21
|
-
---
|
|
22
|
-
|
|
23
|
-
<div class="flex flex-col mt-6 mb-4 w-full px-4 md:px-0" itemscope itemtype="https://schema.org/FAQPage" >
|
|
24
|
-
<div class="mb-6 text-4xl font-headbold sm:text-4xl text-blue-802 faq-heading">
|
|
25
|
-
{t('faq.title')}
|
|
26
|
-
</div>
|
|
27
|
-
<div class="flex flex-col divide-y dark:divide-gray-700">
|
|
28
|
-
{
|
|
29
|
-
questions.map((question) =>
|
|
30
|
-
<FaqItem data={question} />)
|
|
31
|
-
}
|
|
32
|
-
</div>
|
|
33
|
-
</div>
|
|
1
|
+
---
|
|
2
|
+
|
|
3
|
+
/*
|
|
4
|
+
FAQ component for questons & answers with structured microdata for rich snippets
|
|
5
|
+
https://developers.google.com/search/docs/appearance/structured-data/faqpage?hl=en
|
|
6
|
+
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
import {t } from "i18next"
|
|
10
|
+
import FaqItem from "@components/FaqItem.astro"
|
|
11
|
+
|
|
12
|
+
interface Props {
|
|
13
|
+
|
|
14
|
+
questions: {
|
|
15
|
+
question: string;
|
|
16
|
+
answer: string;
|
|
17
|
+
}[]
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
const { questions } = Astro.props
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
<div class="flex flex-col mt-6 mb-4 w-full px-4 md:px-0" itemscope itemtype="https://schema.org/FAQPage" >
|
|
24
|
+
<div class="mb-6 text-4xl font-headbold sm:text-4xl text-blue-802 faq-heading">
|
|
25
|
+
{t('faq.title')}
|
|
26
|
+
</div>
|
|
27
|
+
<div class="flex flex-col divide-y dark:divide-gray-700">
|
|
28
|
+
{
|
|
29
|
+
questions.map((question) =>
|
|
30
|
+
<FaqItem data={question} />)
|
|
31
|
+
}
|
|
32
|
+
</div>
|
|
33
|
+
</div>
|
|
@@ -1,96 +1,96 @@
|
|
|
1
|
-
---
|
|
2
|
-
import { Markdown } from 'astro-remote';
|
|
3
|
-
|
|
4
|
-
/*
|
|
5
|
-
Question & Answer based on details & summary HTML tag
|
|
6
|
-
https://web.dev/learn/html/details
|
|
7
|
-
https://developer.mozilla.org/en-US/docs/Web/HTML/Element/summary
|
|
8
|
-
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
interface Props {
|
|
12
|
-
data: {
|
|
13
|
-
question: string;
|
|
14
|
-
answer: string;
|
|
15
|
-
};
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
const { data } = Astro.props;
|
|
19
|
-
---
|
|
20
|
-
|
|
21
|
-
{ data.answer &&
|
|
22
|
-
<details itemscope itemprop="mainEntity" itemtype="https://schema.org/Question" class="[&_summary:after]:open:-rotate-180">
|
|
23
|
-
<summary
|
|
24
|
-
class="py-2 outline-none cursor-pointer focus:underline text-xl font-500 relative items-center flex justify-between list-none
|
|
25
|
-
after:(block duration-200 content-empty bg-contain bg-center bg-no-repeat h-3 w-4 min-w-4 my-auto ml-4 opacity-60 bg-[url(/arrow-bottom.svg)])"
|
|
26
|
-
>
|
|
27
|
-
<h2 itemprop="name" class=" font-headbold" set:html={data.question} />
|
|
28
|
-
</summary>
|
|
29
|
-
<div
|
|
30
|
-
itemscope
|
|
31
|
-
itemprop="acceptedAnswer"
|
|
32
|
-
itemtype="https://schema.org/Answer"
|
|
33
|
-
>
|
|
34
|
-
<div itemprop="text" class="px-0 pb-4">
|
|
35
|
-
<Markdown content={data.answer} />
|
|
36
|
-
</div>
|
|
37
|
-
</div>
|
|
38
|
-
</details>
|
|
39
|
-
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
<style is:global>
|
|
44
|
-
|
|
45
|
-
details {
|
|
46
|
-
|
|
47
|
-
&[open] {
|
|
48
|
-
h2 {
|
|
49
|
-
color: var(--clr-primary-450);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
ul {
|
|
55
|
-
@apply list-disc pl-5;
|
|
56
|
-
|
|
57
|
-
&+p {
|
|
58
|
-
@apply mt-2;
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
ol {
|
|
63
|
-
@apply list-decimal pl-5;
|
|
64
|
-
&+p {
|
|
65
|
-
@apply mt-2;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
h2 {
|
|
70
|
-
color: var(--clr-primary-700);
|
|
71
|
-
/* font-size: clamp(1.5rem, 1.29rem + 0.59vw, 2rem);
|
|
72
|
-
line-height: 120%;
|
|
73
|
-
letter-spacing: calc(-0.02em + 0.02rem); */
|
|
74
|
-
&:hover {
|
|
75
|
-
color: var(--clr-primary-450);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
h3 {
|
|
80
|
-
@apply mt-2;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
/* table {
|
|
84
|
-
@apply table-auto;
|
|
85
|
-
} */
|
|
86
|
-
|
|
87
|
-
td, th {
|
|
88
|
-
@apply border-b text-left py-2 pr-4;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
a {
|
|
92
|
-
@apply underline decoration-light-blue-400 underline-offset-2;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
</style>
|
|
1
|
+
---
|
|
2
|
+
import { Markdown } from 'astro-remote';
|
|
3
|
+
|
|
4
|
+
/*
|
|
5
|
+
Question & Answer based on details & summary HTML tag
|
|
6
|
+
https://web.dev/learn/html/details
|
|
7
|
+
https://developer.mozilla.org/en-US/docs/Web/HTML/Element/summary
|
|
8
|
+
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
interface Props {
|
|
12
|
+
data: {
|
|
13
|
+
question: string;
|
|
14
|
+
answer: string;
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const { data } = Astro.props;
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
{ data.answer &&
|
|
22
|
+
<details itemscope itemprop="mainEntity" itemtype="https://schema.org/Question" class="[&_summary:after]:open:-rotate-180">
|
|
23
|
+
<summary
|
|
24
|
+
class="py-2 outline-none cursor-pointer focus:underline text-xl font-500 relative items-center flex justify-between list-none
|
|
25
|
+
after:(block duration-200 content-empty bg-contain bg-center bg-no-repeat h-3 w-4 min-w-4 my-auto ml-4 opacity-60 bg-[url(/arrow-bottom.svg)])"
|
|
26
|
+
>
|
|
27
|
+
<h2 itemprop="name" class=" font-headbold" set:html={data.question} />
|
|
28
|
+
</summary>
|
|
29
|
+
<div
|
|
30
|
+
itemscope
|
|
31
|
+
itemprop="acceptedAnswer"
|
|
32
|
+
itemtype="https://schema.org/Answer"
|
|
33
|
+
>
|
|
34
|
+
<div itemprop="text" class="px-0 pb-4">
|
|
35
|
+
<Markdown content={data.answer} />
|
|
36
|
+
</div>
|
|
37
|
+
</div>
|
|
38
|
+
</details>
|
|
39
|
+
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
<style is:global>
|
|
44
|
+
|
|
45
|
+
details {
|
|
46
|
+
|
|
47
|
+
&[open] {
|
|
48
|
+
h2 {
|
|
49
|
+
color: var(--clr-primary-450);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
ul {
|
|
55
|
+
@apply list-disc pl-5;
|
|
56
|
+
|
|
57
|
+
&+p {
|
|
58
|
+
@apply mt-2;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
ol {
|
|
63
|
+
@apply list-decimal pl-5;
|
|
64
|
+
&+p {
|
|
65
|
+
@apply mt-2;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
h2 {
|
|
70
|
+
color: var(--clr-primary-700);
|
|
71
|
+
/* font-size: clamp(1.5rem, 1.29rem + 0.59vw, 2rem);
|
|
72
|
+
line-height: 120%;
|
|
73
|
+
letter-spacing: calc(-0.02em + 0.02rem); */
|
|
74
|
+
&:hover {
|
|
75
|
+
color: var(--clr-primary-450);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
h3 {
|
|
80
|
+
@apply mt-2;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/* table {
|
|
84
|
+
@apply table-auto;
|
|
85
|
+
} */
|
|
86
|
+
|
|
87
|
+
td, th {
|
|
88
|
+
@apply border-b text-left py-2 pr-4;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
a {
|
|
92
|
+
@apply underline decoration-light-blue-400 underline-offset-2;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
</style>
|
|
@@ -1,41 +1,41 @@
|
|
|
1
|
-
|
|
2
|
-
<script lang="ts" setup>
|
|
3
|
-
import { PropType } from 'vue';
|
|
4
|
-
|
|
5
|
-
const props = defineProps({
|
|
6
|
-
items: {
|
|
7
|
-
type: Object as PropType<String[] | null>,
|
|
8
|
-
default: null,
|
|
9
|
-
required: true,
|
|
10
|
-
},
|
|
11
|
-
caption: {
|
|
12
|
-
type: Object as PropType<String | null>,
|
|
13
|
-
default: null,
|
|
14
|
-
required: false,
|
|
15
|
-
}
|
|
16
|
-
})
|
|
17
|
-
</script>
|
|
18
|
-
|
|
19
|
-
<template>
|
|
20
|
-
<h2 class="mb-2 colon-after text-xl font-textbold block leading-none" v-if="props.caption">{{ props.caption }}</h2>
|
|
21
|
-
<ul class="mb-6">
|
|
22
|
-
<li v-for="item in props.items" class="leading-5">
|
|
23
|
-
{{ item }}
|
|
24
|
-
</li>
|
|
25
|
-
</ul>
|
|
26
|
-
</template>
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
<style scoped>
|
|
30
|
-
ul {
|
|
31
|
-
@apply list-square pl-5;
|
|
32
|
-
|
|
33
|
-
li {
|
|
34
|
-
@apply relative mb-2;
|
|
35
|
-
|
|
36
|
-
&::marker {
|
|
37
|
-
@apply text-blue-400;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
</style>
|
|
1
|
+
|
|
2
|
+
<script lang="ts" setup>
|
|
3
|
+
import { PropType } from 'vue';
|
|
4
|
+
|
|
5
|
+
const props = defineProps({
|
|
6
|
+
items: {
|
|
7
|
+
type: Object as PropType<String[] | null>,
|
|
8
|
+
default: null,
|
|
9
|
+
required: true,
|
|
10
|
+
},
|
|
11
|
+
caption: {
|
|
12
|
+
type: Object as PropType<String | null>,
|
|
13
|
+
default: null,
|
|
14
|
+
required: false,
|
|
15
|
+
}
|
|
16
|
+
})
|
|
17
|
+
</script>
|
|
18
|
+
|
|
19
|
+
<template>
|
|
20
|
+
<h2 class="mb-2 colon-after text-xl font-textbold block leading-none" v-if="props.caption">{{ props.caption }}</h2>
|
|
21
|
+
<ul class="mb-6">
|
|
22
|
+
<li v-for="item in props.items" class="leading-5">
|
|
23
|
+
{{ item }}
|
|
24
|
+
</li>
|
|
25
|
+
</ul>
|
|
26
|
+
</template>
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
<style scoped>
|
|
30
|
+
ul {
|
|
31
|
+
@apply list-square pl-5;
|
|
32
|
+
|
|
33
|
+
li {
|
|
34
|
+
@apply relative mb-2;
|
|
35
|
+
|
|
36
|
+
&::marker {
|
|
37
|
+
@apply text-blue-400;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
</style>
|
|
@@ -1,62 +1,62 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div class="relative flex" title="FUCK PUTIN! FUCK RUZZIA!">
|
|
3
|
-
<div i-mdi:tank class="inline-block bg-ukraine mr-1 mt-0.5" />
|
|
4
|
-
<div i-mdi:tank class="inline-block bg-ukraine mr-1 mt-0.5" />
|
|
5
|
-
<div i-mdi:tank class="inline-block bg-ukraine mr-5 mt-0.5" />
|
|
6
|
-
<div class="relative">
|
|
7
|
-
<div class="inline-block absolute" i-noto-v1:flag-for-flag-russia />
|
|
8
|
-
<div i-emojione:fire class="inline-block absolute -mt-1 animate-ping animate-pulseR" />
|
|
9
|
-
</div>
|
|
10
|
-
<div class="absolute left-0 animate-bull animate-bull--1 -mt-1">
|
|
11
|
-
<div i-mdi:bullet class="rotate-90 inline-block bg-yellow " />
|
|
12
|
-
</div>
|
|
13
|
-
<div class="absolute left-0 animate-bull animate-bull animate-bull--2 -mt-1">
|
|
14
|
-
<div i-mdi:bullet class="rotate-90 inline-block bg-yellow " />
|
|
15
|
-
</div>
|
|
16
|
-
<div class="absolute left-0 animate-bull animate-bull--3 -mt-1">
|
|
17
|
-
<div i-mdi:bullet class="rotate-90 inline-block bg-yellow " />
|
|
18
|
-
</div>
|
|
19
|
-
</div>
|
|
20
|
-
</template>
|
|
21
|
-
|
|
22
|
-
<style >
|
|
23
|
-
.bg-ukraine {
|
|
24
|
-
background: linear-gradient(180deg, #0066cc 56%, #ffcc00 44%); }
|
|
25
|
-
|
|
26
|
-
.animate-bull {
|
|
27
|
-
top: -2px;
|
|
28
|
-
animation-iteration-count: infinite; }
|
|
29
|
-
|
|
30
|
-
.animate-bull--1 {
|
|
31
|
-
animation-duration: 2s;
|
|
32
|
-
animation-name: AnimateBull1; }
|
|
33
|
-
|
|
34
|
-
.animate-bull--2 {
|
|
35
|
-
animation-duration: 1.332s;
|
|
36
|
-
animation-name: AnimateBull2;
|
|
37
|
-
animation-delay: 1s; }
|
|
38
|
-
|
|
39
|
-
.animate-bull--3 {
|
|
40
|
-
animation-duration: 0.666s;
|
|
41
|
-
animation-name: AnimateBull3;
|
|
42
|
-
animation-delay: 2s; }
|
|
43
|
-
|
|
44
|
-
@keyframes AnimateBull1 {
|
|
45
|
-
0% {
|
|
46
|
-
transform: translate(14px, 0px); }
|
|
47
|
-
100% {
|
|
48
|
-
transform: translate(86px, 0px); } }
|
|
49
|
-
|
|
50
|
-
@keyframes AnimateBull2 {
|
|
51
|
-
0% {
|
|
52
|
-
transform: translate(38px, 0px); }
|
|
53
|
-
100% {
|
|
54
|
-
transform: translate(80px, 0px); } }
|
|
55
|
-
|
|
56
|
-
@keyframes AnimateBull3 {
|
|
57
|
-
0% {
|
|
58
|
-
transform: translate(62px, 0px); }
|
|
59
|
-
100% {
|
|
60
|
-
transform: translate(88px, 0px); } }
|
|
61
|
-
|
|
62
|
-
</style>
|
|
1
|
+
<template>
|
|
2
|
+
<div class="relative flex" title="FUCK PUTIN! FUCK RUZZIA!">
|
|
3
|
+
<div i-mdi:tank class="inline-block bg-ukraine mr-1 mt-0.5" />
|
|
4
|
+
<div i-mdi:tank class="inline-block bg-ukraine mr-1 mt-0.5" />
|
|
5
|
+
<div i-mdi:tank class="inline-block bg-ukraine mr-5 mt-0.5" />
|
|
6
|
+
<div class="relative">
|
|
7
|
+
<div class="inline-block absolute" i-noto-v1:flag-for-flag-russia />
|
|
8
|
+
<div i-emojione:fire class="inline-block absolute -mt-1 animate-ping animate-pulseR" />
|
|
9
|
+
</div>
|
|
10
|
+
<div class="absolute left-0 animate-bull animate-bull--1 -mt-1">
|
|
11
|
+
<div i-mdi:bullet class="rotate-90 inline-block bg-yellow " />
|
|
12
|
+
</div>
|
|
13
|
+
<div class="absolute left-0 animate-bull animate-bull animate-bull--2 -mt-1">
|
|
14
|
+
<div i-mdi:bullet class="rotate-90 inline-block bg-yellow " />
|
|
15
|
+
</div>
|
|
16
|
+
<div class="absolute left-0 animate-bull animate-bull--3 -mt-1">
|
|
17
|
+
<div i-mdi:bullet class="rotate-90 inline-block bg-yellow " />
|
|
18
|
+
</div>
|
|
19
|
+
</div>
|
|
20
|
+
</template>
|
|
21
|
+
|
|
22
|
+
<style >
|
|
23
|
+
.bg-ukraine {
|
|
24
|
+
background: linear-gradient(180deg, #0066cc 56%, #ffcc00 44%); }
|
|
25
|
+
|
|
26
|
+
.animate-bull {
|
|
27
|
+
top: -2px;
|
|
28
|
+
animation-iteration-count: infinite; }
|
|
29
|
+
|
|
30
|
+
.animate-bull--1 {
|
|
31
|
+
animation-duration: 2s;
|
|
32
|
+
animation-name: AnimateBull1; }
|
|
33
|
+
|
|
34
|
+
.animate-bull--2 {
|
|
35
|
+
animation-duration: 1.332s;
|
|
36
|
+
animation-name: AnimateBull2;
|
|
37
|
+
animation-delay: 1s; }
|
|
38
|
+
|
|
39
|
+
.animate-bull--3 {
|
|
40
|
+
animation-duration: 0.666s;
|
|
41
|
+
animation-name: AnimateBull3;
|
|
42
|
+
animation-delay: 2s; }
|
|
43
|
+
|
|
44
|
+
@keyframes AnimateBull1 {
|
|
45
|
+
0% {
|
|
46
|
+
transform: translate(14px, 0px); }
|
|
47
|
+
100% {
|
|
48
|
+
transform: translate(86px, 0px); } }
|
|
49
|
+
|
|
50
|
+
@keyframes AnimateBull2 {
|
|
51
|
+
0% {
|
|
52
|
+
transform: translate(38px, 0px); }
|
|
53
|
+
100% {
|
|
54
|
+
transform: translate(80px, 0px); } }
|
|
55
|
+
|
|
56
|
+
@keyframes AnimateBull3 {
|
|
57
|
+
0% {
|
|
58
|
+
transform: translate(62px, 0px); }
|
|
59
|
+
100% {
|
|
60
|
+
transform: translate(88px, 0px); } }
|
|
61
|
+
|
|
62
|
+
</style>
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
---
|
|
2
|
-
|
|
3
|
-
const { class: className, handDrive, biggerText } = Astro.props;
|
|
4
|
-
import { t } from "i18next";
|
|
5
|
-
import { Image } from 'astro:assets';
|
|
6
|
-
import handDriveImage from "../assets/hand-drive.svg";
|
|
7
|
-
|
|
8
|
-
const getHandDriveName = (value: number) => {
|
|
9
|
-
if (value === 1)
|
|
10
|
-
return 'lhd'
|
|
11
|
-
|
|
12
|
-
else
|
|
13
|
-
return 'rhd'
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
const handDriveName = getHandDriveName(handDrive)
|
|
17
|
-
---
|
|
18
|
-
<div title={handDriveName.toUpperCase()} class="flex items-center" class:list={className}>
|
|
19
|
-
<Image src={handDriveImage} alt="infoObject.product.hand_drive" width={48} height={34} class={handDriveName} />
|
|
20
|
-
<div data-pagefind-filter={`${t('part.sw-position')}:${handDriveName.toUpperCase()}`}
|
|
21
|
-
class={`
|
|
22
|
-
set:html={t(`part.for-${handDriveName}`)}
|
|
23
|
-
/>
|
|
24
|
-
</div>
|
|
25
|
-
|
|
26
|
-
<style>
|
|
27
|
-
.rhd {
|
|
28
|
-
transform: scaleX(-1);
|
|
29
|
-
}
|
|
1
|
+
---
|
|
2
|
+
|
|
3
|
+
const { class: className, handDrive, biggerText } = Astro.props;
|
|
4
|
+
import { t } from "i18next";
|
|
5
|
+
import { Image } from 'astro:assets';
|
|
6
|
+
import handDriveImage from "../assets/hand-drive.svg";
|
|
7
|
+
|
|
8
|
+
const getHandDriveName = (value: number) => {
|
|
9
|
+
if (value === 1)
|
|
10
|
+
return 'lhd'
|
|
11
|
+
|
|
12
|
+
else
|
|
13
|
+
return 'rhd'
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const handDriveName = getHandDriveName(handDrive)
|
|
17
|
+
---
|
|
18
|
+
<div title={handDriveName.toUpperCase()} class="flex items-center" class:list={className}>
|
|
19
|
+
<Image src={handDriveImage} alt="infoObject.product.hand_drive" width={48} height={34} class={handDriveName} />
|
|
20
|
+
<div data-pagefind-filter={`${t('part.sw-position')}:${handDriveName.toUpperCase()}`}
|
|
21
|
+
class={`ml-2 order-0 ${!biggerText ? 'text-xxs md:text-xs' : 'order-0'}`}
|
|
22
|
+
set:html={t(`part.for-${handDriveName}`)}
|
|
23
|
+
/>
|
|
24
|
+
</div>
|
|
25
|
+
|
|
26
|
+
<style>
|
|
27
|
+
.rhd {
|
|
28
|
+
transform: scaleX(-1);
|
|
29
|
+
}
|
|
30
30
|
</style>
|