spoko-design-system 0.9.6 → 1.0.1

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 (180) hide show
  1. package/.astro/content.d.ts +1 -1
  2. package/.astro/data-store.json +1 -1
  3. package/.astro/settings.json +4 -4
  4. package/.astro/types.d.ts +2 -1
  5. package/.claude/settings.local.json +11 -1
  6. package/.github/dependabot.yml +11 -11
  7. package/.github/todo.yml +3 -3
  8. package/.github/workflows/deploy.yml +39 -39
  9. package/.github/workflows/release.yml +64 -0
  10. package/.releaserc.json +93 -0
  11. package/.stackblitzrc +5 -5
  12. package/.vscode/extensions.json +4 -5
  13. package/.vscode/launch.json +11 -11
  14. package/.vscode/settings.json +1 -5
  15. package/CHANGELOG.md +20 -0
  16. package/CONTRIBUTING.md +183 -0
  17. package/LICENSE +21 -21
  18. package/README.md +132 -116
  19. package/astro.config.mjs +84 -86
  20. package/dev-dist/sw.js +91 -91
  21. package/dev-dist/workbox-c676b6d3.js +3391 -3391
  22. package/icon.config.ts +340 -310
  23. package/index.ts +70 -70
  24. package/package.json +19 -11
  25. package/public/arrow-bottom.svg +7 -7
  26. package/public/fonts/lg.svg +53 -53
  27. package/public/fonts/vwhead-bold-demo.html +549 -549
  28. package/public/fonts/vwhead-regular-demo.html +549 -549
  29. package/public/fonts/vwtext-bold-demo.html +549 -549
  30. package/public/fonts/vwtext-regular-demo.html +549 -549
  31. package/public/github.svg +3 -3
  32. package/public/grid_dot.svg +4 -4
  33. package/public/linkedin.svg +44 -44
  34. package/public/make-scrollable-code-focusable.js +3 -3
  35. package/public/pagefind.yml +3 -3
  36. package/public/polo.blue.svg +29 -29
  37. package/public/spoko.space.svg +71 -71
  38. package/public/twitter.svg +46 -46
  39. package/renovate.json +6 -6
  40. package/sandbox.config.json +11 -11
  41. package/src/MyComponent.astro +8 -8
  42. package/src/components/Badge.vue +19 -19
  43. package/src/components/Badges.vue +21 -21
  44. package/src/components/Breadcrumbs.vue +94 -94
  45. package/src/components/Button.vue +101 -101
  46. package/src/components/ButtonCopy.astro +183 -183
  47. package/src/components/ButtonCopy.vue +36 -36
  48. package/src/components/Card.astro +27 -27
  49. package/src/components/Carousel.astro +26 -26
  50. package/src/components/Category/CategoriesCarousel.astro +100 -101
  51. package/src/components/Category/CategoryDetails.astro +168 -169
  52. package/src/components/Category/CategoryLink.vue +28 -28
  53. package/src/components/Category/CategorySidebarToggler.vue +9 -9
  54. package/src/components/Category/CategoryTile.astro +37 -37
  55. package/src/components/Category/CategoryViewToggler.astro +89 -89
  56. package/src/components/Category/SubCategoryLink.vue +19 -19
  57. package/src/components/Copyright.astro +12 -12
  58. package/src/components/Date.astro +7 -7
  59. package/src/components/Faq.astro +32 -33
  60. package/src/components/FaqItem.astro +80 -80
  61. package/src/components/FeaturesList.vue +37 -37
  62. package/src/components/FuckRussia.vue +62 -62
  63. package/src/components/HandDrive.astro +55 -29
  64. package/src/components/Header/Header.astro +210 -210
  65. package/src/components/Header/SkipToContent.astro +1 -1
  66. package/src/components/Headline.vue +107 -87
  67. package/src/components/Image.astro +30 -30
  68. package/src/components/LeftSidebar.astro +53 -53
  69. package/src/components/MainColors.vue +22 -22
  70. package/src/components/MainInput.vue +15 -15
  71. package/src/components/Modal.astro +27 -27
  72. package/src/components/PageContent.astro +5 -5
  73. package/src/components/PartNumber.vue +27 -27
  74. package/src/components/Post/PostCategories.astro +41 -41
  75. package/src/components/Post/PostCategories.vue +30 -30
  76. package/src/components/PostHeader.astro +103 -103
  77. package/src/components/PrCode.vue +141 -141
  78. package/src/components/Product/ProductButton.vue +18 -18
  79. package/src/components/Product/ProductCarousel.astro +35 -35
  80. package/src/components/Product/ProductEngineType.vue +42 -42
  81. package/src/components/Product/ProductImage.astro +40 -40
  82. package/src/components/Product/ProductLink.astro +96 -101
  83. package/src/components/Product/ProductLink.vue +59 -59
  84. package/src/components/Product/ProductLinkInfo.astro +37 -37
  85. package/src/components/Product/ProductNumber.astro +60 -60
  86. package/src/components/ProductCarousel.astro +38 -38
  87. package/src/components/ProductCodes.vue +39 -39
  88. package/src/components/ProductDetailName.vue +52 -52
  89. package/src/components/ProductDetailsList.vue +216 -216
  90. package/src/components/ProductTile.astro +47 -48
  91. package/src/components/Quote.vue +23 -23
  92. package/src/components/ReloadPrompt.astro +50 -50
  93. package/src/components/SlimBanner.vue +72 -72
  94. package/src/components/Table.vue +32 -32
  95. package/src/components/TableOfContents.astro +15 -15
  96. package/src/components/Translations.vue +23 -23
  97. package/src/components/flags/FlagPL.vue +3 -3
  98. package/src/components/flags/FlagUA.vue +2 -2
  99. package/src/components/{Layout → layout}/CallToAction.astro +52 -52
  100. package/src/components/{Layout → layout}/Container.astro +7 -7
  101. package/src/components/{Layout → layout}/Header.astro +80 -80
  102. package/src/config.ts +56 -56
  103. package/src/design.config.ts +98 -98
  104. package/src/env.d.ts +6 -6
  105. package/src/layouts/Layout.astro +58 -61
  106. package/src/layouts/MainLayout.astro +78 -81
  107. package/src/layouts/partials/FooterCommon.astro +4 -4
  108. package/src/layouts/partials/HeadCommon.astro +44 -44
  109. package/src/layouts/partials/HeadSEO.astro +41 -41
  110. package/src/pages/components/badges.mdx +57 -57
  111. package/src/pages/components/breadcrumbs.mdx +139 -139
  112. package/src/pages/components/buttons.mdx +359 -360
  113. package/src/pages/components/card.mdx +294 -294
  114. package/src/pages/components/carousel.mdx +62 -62
  115. package/src/pages/components/copyright.mdx +42 -42
  116. package/src/pages/components/details-list.mdx +115 -115
  117. package/src/pages/components/features-list.mdx +37 -37
  118. package/src/pages/components/flags.mdx +49 -49
  119. package/src/pages/components/fuck-russia.mdx +39 -39
  120. package/src/pages/components/hand-drive.mdx +78 -38
  121. package/src/pages/components/headline.mdx +137 -137
  122. package/src/pages/components/icons.astro +135 -135
  123. package/src/pages/components/image.mdx +513 -513
  124. package/src/pages/components/input.mdx +367 -367
  125. package/src/pages/components/jumbotron.mdx +359 -359
  126. package/src/pages/components/modal.mdx +64 -64
  127. package/src/pages/components/post-header.mdx +64 -64
  128. package/src/pages/components/pr-code.mdx +65 -65
  129. package/src/pages/components/product-number.mdx +58 -58
  130. package/src/pages/components/product-tile.mdx +51 -51
  131. package/src/pages/components/quote.mdx +33 -33
  132. package/src/pages/components/slimbanner.mdx +35 -35
  133. package/src/pages/components/table.mdx +108 -108
  134. package/src/pages/core/colors.mdx +10 -10
  135. package/src/pages/core/grid.mdx +89 -89
  136. package/src/pages/core/introduction.mdx +77 -77
  137. package/src/pages/core/shadows.astro +20 -20
  138. package/src/pages/core/typography.astro +49 -49
  139. package/src/pages/index.astro +264 -133
  140. package/src/pages/patterns/introduction.mdx +60 -60
  141. package/src/pwa.ts +12 -12
  142. package/src/styles/_variables.scss +70 -70
  143. package/src/styles/base/base.css +184 -184
  144. package/src/styles/base/grid.css +92 -92
  145. package/src/styles/base/typography.css +70 -70
  146. package/src/styles/content.css +73 -73
  147. package/src/styles/main.css +7 -7
  148. package/src/types/Product.ts +31 -31
  149. package/src/types/astro.d.ts +3 -3
  150. package/src/utils/category/getMainCategoryList.ts +8 -17
  151. package/src/utils/product/getPriceFormatted.ts +12 -15
  152. package/src/utils/product/getProductChecklist.ts +16 -17
  153. package/src/utils/product/useFormatProductNumber.ts +41 -41
  154. package/src/utils/seo/getShorterDescription.ts +14 -14
  155. package/src/utils/text/formatDate.ts +5 -5
  156. package/src/utils/text/formatLocaleNumber.ts +5 -6
  157. package/src/utils/text/formatPad.ts +12 -12
  158. package/src/utils/text/getNumberFormatted.ts +33 -33
  159. package/src/utils/text/getTranslatedLink.ts +5 -5
  160. package/src/utils/text.ts +19 -19
  161. package/tailwind.config.cjs +8 -8
  162. package/tsconfig.json +28 -28
  163. package/uno-config/index.ts +262 -268
  164. package/uno-config/theme/breakpoints.ts +9 -9
  165. package/uno-config/theme/colors.ts +64 -64
  166. package/uno-config/theme/dimensions.ts +17 -17
  167. package/uno-config/theme/effects.ts +14 -14
  168. package/uno-config/theme/grid.ts +10 -10
  169. package/uno-config/theme/index.ts +28 -28
  170. package/uno-config/theme/shortcuts/buttons.ts +53 -53
  171. package/uno-config/theme/shortcuts/components.ts +123 -123
  172. package/uno-config/theme/shortcuts/index.ts +20 -20
  173. package/uno-config/theme/shortcuts/layout.ts +74 -74
  174. package/uno-config/theme/typography.ts +29 -29
  175. package/uno.config.ts +2 -2
  176. package/.astro/icon.d.ts +0 -11909
  177. package/astro-i18next.config.mjs +0 -18
  178. package/astro-i18next.config.ts +0 -11
  179. package/public/locales/en/translation.json +0 -13
  180. package/public/locales/pl/translation.json +0 -13
@@ -1,43 +1,43 @@
1
- <script setup lang="ts">
2
- interface Engine {
3
- id: number | string;
4
- name: string;
5
- }
6
-
7
- const props = withDefaults(defineProps<{
8
- engines: Engine[];
9
- }>(), {
10
- engines: () => []
11
- });
12
- </script>
13
-
14
- <template>
15
- <ul v-if="engines.length" class="engine-types">
16
- <li
17
- v-for="(engine, index) in engines"
18
- :key="engine.id"
19
- class="engine-type"
20
- :class="{ 'with-comma': index !== engines.length - 1 }"
21
- >
22
- {{ engine.name }}
23
- </li>
24
- </ul>
25
- </template>
26
-
27
- <style >
28
- .engine-types {
29
- @apply flex flex-wrap items-center;
30
- }
31
-
32
- .engine-type {
33
- @apply inline-block;
34
-
35
- &.with-comma {
36
- @apply mr-1;
37
-
38
- &:after {
39
- content: ',';
40
- }
41
- }
42
- }
1
+ <script setup lang="ts">
2
+ interface Engine {
3
+ id: number | string;
4
+ name: string;
5
+ }
6
+
7
+ const props = withDefaults(defineProps<{
8
+ engines: Engine[];
9
+ }>(), {
10
+ engines: () => []
11
+ });
12
+ </script>
13
+
14
+ <template>
15
+ <ul v-if="engines.length" class="engine-types">
16
+ <li
17
+ v-for="(engine, index) in engines"
18
+ :key="engine.id"
19
+ class="engine-type"
20
+ :class="{ 'with-comma': index !== engines.length - 1 }"
21
+ >
22
+ {{ engine.name }}
23
+ </li>
24
+ </ul>
25
+ </template>
26
+
27
+ <style >
28
+ .engine-types {
29
+ @apply flex flex-wrap items-center;
30
+ }
31
+
32
+ .engine-type {
33
+ @apply inline-block;
34
+
35
+ &.with-comma {
36
+ @apply mr-1;
37
+
38
+ &:after {
39
+ content: ',';
40
+ }
41
+ }
42
+ }
43
43
  </style>
@@ -1,41 +1,41 @@
1
- ---
2
- import { Image } from 'astro:assets'
3
- interface ImageObject {
4
- src: string;
5
- alt?: string;
6
- height?: string | number;
7
- width?: string | number;
8
- loading?: 'lazy' | 'eager';
9
- srcset?: string[];
10
- class?: string;
11
- index?: number;
12
- }
13
-
14
- const { imageObject } = Astro.props as { imageObject: ImageObject; };
15
-
16
- let inputProps = {};
17
-
18
-
19
- if (imageObject.index && imageObject.index === 1) {
20
- inputProps['data-pagefind-meta'] = 'image[src], image_alt[alt]';
21
- imageObject.loading = 'eager'
22
- }
23
-
24
- if (imageObject.srcset && imageObject.srcset.length) {
25
- inputProps['widths'] = imageObject.srcset
26
- }
27
-
28
- ---
29
- <Image
30
- src={imageObject.src}
31
- alt={imageObject.alt}
32
- height={Number(imageObject.height)}
33
- width={Number(imageObject.width)}
34
- loading={imageObject.loading ? imageObject.loading : 'lazy'}
35
- itemprop="image"
36
- format="avif"
37
- data-pagefind-index-attrs={imageObject.alt}
38
- onerror="this.style.display='none';"
39
- class={`product-image ${imageObject.class || ''}`}
40
- { ...inputProps}
1
+ ---
2
+ import { Image } from 'astro:assets'
3
+ interface ImageObject {
4
+ src: string;
5
+ alt?: string;
6
+ height?: string | number;
7
+ width?: string | number;
8
+ loading?: 'lazy' | 'eager';
9
+ srcset?: string[];
10
+ class?: string;
11
+ index?: number;
12
+ }
13
+
14
+ const { imageObject } = Astro.props as { imageObject: ImageObject; };
15
+
16
+ let inputProps = {};
17
+
18
+
19
+ if (imageObject.index && imageObject.index === 1) {
20
+ inputProps['data-pagefind-meta'] = 'image[src], image_alt[alt]';
21
+ imageObject.loading = 'eager'
22
+ }
23
+
24
+ if (imageObject.srcset && imageObject.srcset.length) {
25
+ inputProps['widths'] = imageObject.srcset
26
+ }
27
+
28
+ ---
29
+ <Image
30
+ src={imageObject.src}
31
+ alt={imageObject.alt}
32
+ height={Number(imageObject.height)}
33
+ width={Number(imageObject.width)}
34
+ loading={imageObject.loading ? imageObject.loading : 'lazy'}
35
+ itemprop="image"
36
+ format="avif"
37
+ data-pagefind-index-attrs={imageObject.alt}
38
+ onerror="this.style.display='none';"
39
+ class={`product-image ${imageObject.class || ''}`}
40
+ { ...inputProps}
41
41
  />
@@ -1,101 +1,96 @@
1
- ---
2
- import type { Product } from 'types/index';
3
-
4
- interface Props {
5
- productId?: number;
6
- productObject?: Product;
7
- locale: string;
8
- index: number;
9
- bigTile?: boolean;
10
- loading?: "eager" | "lazy";
11
- isShopProduct?: boolean;
12
- }
13
-
14
- const {
15
- productId,
16
- productObject,
17
- bigTile,
18
- locale,
19
- index,
20
- loading = "lazy",
21
- isShopProduct = false,
22
- } = Astro.props;
23
-
24
- import { getProductById } from '@utils/product/getProductById';
25
- import { getShopProductById } from '@utils/product/getShopProductById';
26
- import { getProductUrl } from "@utils/product/getProductUrl";
27
- import { getShopProductUrl } from "@utils/product/getShopProductUrl";
28
- import { getProductTranslation } from "@utils/product/getProductTranslation";
29
- import { getImageUrl } from '@utils/getImageUrl';
30
- import i18next, { t } from "i18next";
31
- import { ProductImage, ProductNumber, removeSemicolon, getPriceFormatted } from "spoko-design-system";
32
-
33
- // Użycie productObject jeśli przekazane, inaczej pobranie produktu na podstawie productId
34
- const product = productObject || (productId ? (isShopProduct ? await getShopProductById(productId) : await getProductById(productId)) : null);
35
-
36
- // Określenie URL miniatury produktu
37
- const thumb = product ? (
38
- isShopProduct
39
- ? await getImageUrl(product.images?.[0]?.path || "", "SHOP")
40
- : await getImageUrl(product.photo || "", `'ProductLink' ${product.number}`)
41
- ) : "";
42
-
43
- // Tłumaczenie nazwy produktu jeśli dostępne
44
- const productTranslation = i18next.exists(`parts.${product?.number}.name`)
45
- ? null
46
- : productId ? await getProductTranslation(productId, product?.number || "") : null;
47
-
48
- // const productName = product ? (
49
- // isShopProduct
50
- // ? (locale === "pl" ? product.name_pl : product.name_en)
51
- // : productTranslation?.name || t(`parts.${product.number}.name`)
52
- // ) : "";
53
-
54
- const productName = product.name || 'NO NAME';
55
-
56
- const nameFormatted = removeSemicolon(productName.toString());
57
- ---
58
-
59
- {product && (
60
- <div class={bigTile ? 'product-link--big-tile' : 'product-thumb--plp product-thumb--carousel'}>
61
- {product.photo !== null && thumb ? (
62
- <ProductImage
63
- imagesApiUrl="https://api.polo.blue"
64
- imageObject={{
65
- src: thumb,
66
- alt: productName,
67
- height: '180',
68
- width: '240',
69
- loading
70
- }}
71
- />
72
- ) : (
73
- <img src="/1x1.png" class="bg-neutral-lightest/70" alt={productName} />
74
- )}
75
- </div>
76
-
77
- <div class={bigTile ? '' : 'sm:pl-4'}>
78
- {product.price_pln && (
79
- <p class="block mb-2 font-600 font-headbold text-5">
80
- {getPriceFormatted(product)}
81
- </p>
82
- )}
83
-
84
- <a
85
- class="product-link--url"
86
- href={isShopProduct ? getShopProductUrl(product.slug, locale) : getProductUrl(product.number, locale)}
87
- itemprop="url"
88
- title={product.number}
89
- set:html={nameFormatted}
90
- />
91
-
92
- <ProductNumber productNumber={product.number} copyDisabled={true} />
93
-
94
- {index !== null && (
95
- <>
96
- <meta itemprop="position" content={index.toString()} />
97
- <meta itemprop="name" content={nameFormatted} />
98
- </>
99
- )}
100
- </div>
101
- )}
1
+ ---
2
+ import type { Product } from 'types/index';
3
+
4
+ interface Props {
5
+ productId?: number;
6
+ productObject?: Product;
7
+ locale: string;
8
+ index: number;
9
+ bigTile?: boolean;
10
+ loading?: "eager" | "lazy";
11
+ isShopProduct?: boolean;
12
+ }
13
+
14
+ const {
15
+ productId,
16
+ productObject,
17
+ bigTile,
18
+ locale,
19
+ index,
20
+ loading = "lazy",
21
+ isShopProduct = false,
22
+ } = Astro.props;
23
+
24
+ import { getProductById } from '@utils/product/getProductById';
25
+ import { getShopProductById } from '@utils/product/getShopProductById';
26
+ import { getProductUrl } from "@utils/product/getProductUrl";
27
+ import { getShopProductUrl } from "@utils/product/getShopProductUrl";
28
+ import { getProductTranslation } from "@utils/product/getProductTranslation";
29
+ import { getImageUrl } from '@utils/getImageUrl';
30
+ import { ProductImage, ProductNumber, removeSemicolon, getPriceFormatted } from "spoko-design-system";
31
+
32
+ // Użycie productObject jeśli przekazane, inaczej pobranie produktu na podstawie productId
33
+ const product = productObject || (productId ? (isShopProduct ? await getShopProductById(productId) : await getProductById(productId)) : null);
34
+
35
+ // Określenie URL miniatury produktu
36
+ const thumb = product ? (
37
+ isShopProduct
38
+ ? await getImageUrl(product.images?.[0]?.path || "", "SHOP")
39
+ : await getImageUrl(product.photo || "", `'ProductLink' ${product.number}`)
40
+ ) : "";
41
+
42
+ // Product translation removed - using English only
43
+ const productTranslation = productId ? await getProductTranslation(productId, product?.number || "") : null;
44
+
45
+ const productName = product ? (
46
+ isShopProduct
47
+ ? product.name_en || product.name
48
+ : productTranslation?.name || product.name
49
+ ) : 'NO NAME';
50
+
51
+ const nameFormatted = removeSemicolon(productName.toString());
52
+ ---
53
+
54
+ {product && (
55
+ <div class={bigTile ? 'product-link--big-tile' : 'product-thumb--plp product-thumb--carousel'}>
56
+ {product.photo !== null && thumb ? (
57
+ <ProductImage
58
+ imagesApiUrl="https://api.polo.blue"
59
+ imageObject={{
60
+ src: thumb,
61
+ alt: productName,
62
+ height: '180',
63
+ width: '240',
64
+ loading
65
+ }}
66
+ />
67
+ ) : (
68
+ <img src="/1x1.png" class="bg-neutral-lightest/70" alt={productName} />
69
+ )}
70
+ </div>
71
+
72
+ <div class={bigTile ? '' : 'sm:pl-4'}>
73
+ {product.price_pln && (
74
+ <p class="block mb-2 font-600 font-headbold text-5">
75
+ {getPriceFormatted(product)}
76
+ </p>
77
+ )}
78
+
79
+ <a
80
+ class="product-link--url"
81
+ href={isShopProduct ? getShopProductUrl(product.slug, locale) : getProductUrl(product.number, locale)}
82
+ itemprop="url"
83
+ title={product.number}
84
+ set:html={nameFormatted}
85
+ />
86
+
87
+ <ProductNumber productNumber={product.number} copyDisabled={true} />
88
+
89
+ {index !== null && (
90
+ <>
91
+ <meta itemprop="position" content={index.toString()} />
92
+ <meta itemprop="name" content={nameFormatted} />
93
+ </>
94
+ )}
95
+ </div>
96
+ )}
@@ -1,60 +1,60 @@
1
- <template>
2
- <div class="product-link" itemscope itemtype="https://schema.org/Product">
3
- <div :class="[
4
- bigTile ? 'product-link--big-tile' : 'product-thumb--plp product-thumb--carousel'
5
- ]">
6
- <!-- Slot na ProductImage z Astro -->
7
- <slot name="image">
8
- <img src="/1x1.png" class="bg-neutral-lightest/70" :alt="productName" />
9
- </slot>
10
- </div>
11
-
12
- <div :class="[bigTile ? '' : 'sm:pl-4']">
13
- <p v-if="price" class="block mb-2 font-600 font-headbold text-5">
14
- {{ price }}
15
- </p>
16
-
17
- <a
18
- class="product-link--url"
19
- :href="url"
20
- itemprop="url"
21
- :title="productNumber"
22
- v-html="nameFormatted"
23
- />
24
-
25
- <ProductNumber
26
- :productNumber="productNumber"
27
- :copyDisabled="true"
28
- />
29
-
30
- <template v-if="index !== null">
31
- <meta itemprop="position" :content="index.toString()" />
32
- <meta itemprop="name" :content="nameFormatted" />
33
- </template>
34
- </div>
35
- </div>
36
- </template>
37
-
38
- <script setup lang="ts">
39
- import { computed } from 'vue'
40
- import { ProductNumber } from 'spoko-design-system'
41
- import { removeSemicolon } from 'spoko-design-system'
42
-
43
- interface Props {
44
- productName: string
45
- productNumber: string
46
- url: string
47
- price?: string
48
- bigTile?: boolean
49
- index?: number
50
- }
51
-
52
- const props = withDefaults(defineProps<Props>(), {
53
- bigTile: false,
54
- index: null,
55
- })
56
-
57
- const nameFormatted = computed(() => {
58
- return removeSemicolon(props.productName.toString())
59
- })
1
+ <template>
2
+ <div class="product-link" itemscope itemtype="https://schema.org/Product">
3
+ <div :class="[
4
+ bigTile ? 'product-link--big-tile' : 'product-thumb--plp product-thumb--carousel'
5
+ ]">
6
+ <!-- Slot na ProductImage z Astro -->
7
+ <slot name="image">
8
+ <img src="/1x1.png" class="bg-neutral-lightest/70" :alt="productName" />
9
+ </slot>
10
+ </div>
11
+
12
+ <div :class="[bigTile ? '' : 'sm:pl-4']">
13
+ <p v-if="price" class="block mb-2 font-600 font-headbold text-5">
14
+ {{ price }}
15
+ </p>
16
+
17
+ <a
18
+ class="product-link--url"
19
+ :href="url"
20
+ itemprop="url"
21
+ :title="productNumber"
22
+ v-html="nameFormatted"
23
+ />
24
+
25
+ <ProductNumber
26
+ :productNumber="productNumber"
27
+ :copyDisabled="true"
28
+ />
29
+
30
+ <template v-if="index !== null">
31
+ <meta itemprop="position" :content="index.toString()" />
32
+ <meta itemprop="name" :content="nameFormatted" />
33
+ </template>
34
+ </div>
35
+ </div>
36
+ </template>
37
+
38
+ <script setup lang="ts">
39
+ import { computed } from 'vue'
40
+ import { ProductNumber } from 'spoko-design-system'
41
+ import { removeSemicolon } from 'spoko-design-system'
42
+
43
+ interface Props {
44
+ productName: string
45
+ productNumber: string
46
+ url: string
47
+ price?: string
48
+ bigTile?: boolean
49
+ index?: number
50
+ }
51
+
52
+ const props = withDefaults(defineProps<Props>(), {
53
+ bigTile: false,
54
+ index: null,
55
+ })
56
+
57
+ const nameFormatted = computed(() => {
58
+ return removeSemicolon(props.productName.toString())
59
+ })
60
60
  </script>
@@ -1,38 +1,38 @@
1
- ---
2
- import type { Product } from '../../types/Product';
3
- import ProductNumber from "./ProductNumber.astro"
4
-
5
- interface Props {
6
- product: Product;
7
- nameFormatted: string;
8
- price?: string;
9
- url: string;
10
- index?: number | null;
11
- bigTile?: boolean;
12
- }
13
-
14
- const { product, nameFormatted, price, url, index, bigTile } = Astro.props;
15
-
16
- ---
17
-
18
- <div class={`flex flex-col ${bigTile ? '' : 'sm:pl-4'}`}>
19
- {price && (
20
- <p class="block mb-2 font-600 font-headbold text-5">
21
- {price}
22
- </p>
23
- )}
24
- <a
25
- class="product-link--url"
26
- href={url}
27
- itemprop="url"
28
- title={product.number}
29
- set:html={nameFormatted}
30
- />
31
- <ProductNumber productNumber={product.number} copyDisabled={true} />
32
- {index !== null && (
33
- <>
34
- <meta itemprop="position" content={index} />
35
- <meta itemprop="name" content={nameFormatted} />
36
- </>
37
- )}
1
+ ---
2
+ import type { Product } from '../../types/Product';
3
+ import ProductNumber from "./ProductNumber.astro"
4
+
5
+ interface Props {
6
+ product: Product;
7
+ nameFormatted: string;
8
+ price?: string;
9
+ url: string;
10
+ index?: number | null;
11
+ bigTile?: boolean;
12
+ }
13
+
14
+ const { product, nameFormatted, price, url, index, bigTile } = Astro.props;
15
+
16
+ ---
17
+
18
+ <div class={`flex flex-col ${bigTile ? '' : 'sm:pl-4'}`}>
19
+ {price && (
20
+ <p class="block mb-2 font-600 font-headbold text-5">
21
+ {price}
22
+ </p>
23
+ )}
24
+ <a
25
+ class="product-link--url"
26
+ href={url}
27
+ itemprop="url"
28
+ title={product.number}
29
+ set:html={nameFormatted}
30
+ />
31
+ <ProductNumber productNumber={product.number} copyDisabled={true} />
32
+ {index !== null && (
33
+ <>
34
+ <meta itemprop="position" content={index} />
35
+ <meta itemprop="name" content={nameFormatted} />
36
+ </>
37
+ )}
38
38
  </div>