@kickstartds/ds-agency-premium 1.6.69 → 1.6.70--canary.45.1746.0

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 (202) hide show
  1. package/dist/{BlogAsideProps-d9decb7c.d.ts → BlogAsideProps-c760fd2a.d.ts} +5 -5
  2. package/dist/{BlogAuthorProps-88a11566.d.ts → BlogAuthorProps-fb0241df.d.ts} +7 -2
  3. package/dist/{BlogOverviewProps-9f207f1c.d.ts → BlogOverviewProps-7caa223c.d.ts} +2 -2
  4. package/dist/{BlogPostProps-d9decb7c.d.ts → BlogPostProps-c760fd2a.d.ts} +3 -3
  5. package/dist/{ButtonProps-03ff6d21.d.ts → ButtonProps-00ddee3a.d.ts} +4 -4
  6. package/dist/{CtaProps-93230a76.d.ts → CtaProps-babe4ee6.d.ts} +21 -11
  7. package/dist/EventAppointmentProps-443cd1ce.d.ts +38 -0
  8. package/dist/EventDetailProps-42a7eebe.d.ts +387 -0
  9. package/dist/EventLatestTeaserProps-fc9d3281.d.ts +58 -0
  10. package/dist/EventLocationProps-871bc198.d.ts +41 -0
  11. package/dist/{FeaturesProps-e58616a5.d.ts → FeaturesProps-a9041d97.d.ts} +9 -4
  12. package/dist/{FooterProps-171a3067.d.ts → FooterProps-a0a104ca.d.ts} +2 -2
  13. package/dist/{HeaderProps-e22382f1.d.ts → HeaderProps-72763967.d.ts} +2 -2
  14. package/dist/{HeroProps-f704d270.d.ts → HeroProps-40f6c7f5.d.ts} +9 -4
  15. package/dist/{ImageStoryProps-e853e1e7.d.ts → ImageStoryProps-00ddee3a.d.ts} +1 -1
  16. package/dist/MosaicProps-d52c7151.d.ts +4 -4
  17. package/dist/{PageProps-aa29c554.d.ts → PageProps-7caa223c.d.ts} +1 -1
  18. package/dist/{SectionProps-1cfcf6e8.d.ts → SectionProps-00ddee3a.d.ts} +15 -10
  19. package/dist/{SliderProps-93230a76.d.ts → SliderProps-babe4ee6.d.ts} +4 -4
  20. package/dist/{StatProps-79109ad0.d.ts → StatProps-12a3eae0.d.ts} +1 -1
  21. package/dist/StatsProps-bf5ef578.d.ts +1 -1
  22. package/dist/{TeaserCardProps-b9c28e78.d.ts → TeaserCardProps-994cb119.d.ts} +4 -4
  23. package/dist/{VideoCurtainProps-6c625a69.d.ts → VideoCurtainProps-a2c0cc7f.d.ts} +5 -5
  24. package/dist/components/blog-aside/blog-aside.schema.dereffed.json +16 -8
  25. package/dist/components/blog-aside/blog-aside.schema.json +4 -4
  26. package/dist/components/blog-aside/index.d.ts +1 -1
  27. package/dist/components/blog-aside/index.js +1 -1
  28. package/dist/components/blog-author/blog-author.schema.dereffed.json +12 -4
  29. package/dist/components/blog-author/index.d.ts +1 -1
  30. package/dist/components/blog-overview/blog-overview.schema.dereffed.json +178 -85
  31. package/dist/components/blog-overview/index.d.ts +1 -1
  32. package/dist/components/blog-post/blog-post.schema.dereffed.json +194 -93
  33. package/dist/components/blog-post/index.d.ts +1 -1
  34. package/dist/components/blog-teaser/index.js +5 -7
  35. package/dist/components/button/button.css +2 -2
  36. package/dist/components/button/button.schema.dereffed.json +3 -3
  37. package/dist/components/button/button.schema.json +3 -3
  38. package/dist/components/button/index.d.ts +1 -1
  39. package/dist/components/button/index.js +1 -1
  40. package/dist/components/button-group/button-group.schema.dereffed.json +3 -3
  41. package/dist/components/button-group/index.d.ts +1 -1
  42. package/dist/components/contact/contact.schema.dereffed.json +13 -5
  43. package/dist/components/contact/contact.schema.json +11 -5
  44. package/dist/components/contact/index.d.ts +6 -1
  45. package/dist/components/contact/index.js +1 -1
  46. package/dist/components/cta/cta.css +44 -56
  47. package/dist/components/cta/cta.schema.dereffed.json +28 -11
  48. package/dist/components/cta/cta.schema.json +23 -10
  49. package/dist/components/cta/index.d.ts +1 -1
  50. package/dist/components/cta/index.js +25 -26
  51. package/dist/components/downloads/downloads.css +153 -0
  52. package/dist/components/downloads/downloads.schema.dereffed.json +55 -0
  53. package/dist/components/downloads/downloads.schema.json +44 -0
  54. package/dist/components/downloads/index.d.ts +41 -0
  55. package/dist/components/downloads/index.js +18 -0
  56. package/dist/components/event-appointment/event-appointment.css +62 -0
  57. package/dist/components/event-appointment/event-appointment.schema.dereffed.json +56 -0
  58. package/dist/components/event-appointment/event-appointment.schema.json +47 -0
  59. package/dist/components/event-appointment/index.d.ts +7 -0
  60. package/dist/components/event-appointment/index.js +14 -0
  61. package/dist/components/event-detail/event-detail.schema.dereffed.json +287 -0
  62. package/dist/components/event-detail/event-detail.schema.json +74 -0
  63. package/dist/components/event-detail/index.d.ts +5 -0
  64. package/dist/components/event-detail/index.js +36 -0
  65. package/dist/components/event-header/event-header.css +6 -0
  66. package/dist/components/event-header/event-header.schema.dereffed.json +38 -0
  67. package/dist/components/event-header/event-header.schema.json +34 -0
  68. package/dist/components/event-header/index.d.ts +35 -0
  69. package/dist/components/event-header/index.js +20 -0
  70. package/dist/components/event-latest/event-latest.css +5 -0
  71. package/dist/components/event-latest/event-latest.schema.dereffed.json +142 -0
  72. package/dist/components/event-latest/event-latest.schema.json +46 -0
  73. package/dist/components/event-latest/index.d.ts +30 -0
  74. package/dist/components/event-latest/index.js +19 -0
  75. package/dist/components/event-latest-teaser/event-latest-teaser.css +128 -0
  76. package/dist/components/event-latest-teaser/event-latest-teaser.schema.dereffed.json +97 -0
  77. package/dist/components/event-latest-teaser/event-latest-teaser.schema.json +73 -0
  78. package/dist/components/event-latest-teaser/index.d.ts +8 -0
  79. package/dist/components/event-latest-teaser/index.js +18 -0
  80. package/dist/components/event-location/event-location.css +71 -0
  81. package/dist/components/event-location/event-location.schema.dereffed.json +126 -0
  82. package/dist/components/event-location/event-location.schema.json +61 -0
  83. package/dist/components/event-location/index.d.ts +7 -0
  84. package/dist/components/event-location/index.js +18 -0
  85. package/dist/components/feature/feature.schema.dereffed.json +13 -3
  86. package/dist/components/feature/feature.schema.json +11 -3
  87. package/dist/components/feature/index.d.ts +8 -3
  88. package/dist/components/feature/index.js +2 -3
  89. package/dist/components/features/features.css +15 -35
  90. package/dist/components/features/features.schema.dereffed.json +13 -3
  91. package/dist/components/features/features.schema.json +5 -2
  92. package/dist/components/features/index.d.ts +1 -1
  93. package/dist/components/features/index.js +2 -2
  94. package/dist/components/footer/footer.css +1 -1
  95. package/dist/components/footer/footer.schema.dereffed.json +12 -12
  96. package/dist/components/footer/index.d.ts +1 -1
  97. package/dist/components/footer/index.js +1 -1
  98. package/dist/components/gallery/gallery.schema.dereffed.json +2 -1
  99. package/dist/components/gallery/gallery.schema.json +2 -1
  100. package/dist/components/gallery/index.js +1 -1
  101. package/dist/components/header/header.css +47 -9
  102. package/dist/components/header/header.schema.dereffed.json +12 -12
  103. package/dist/components/header/index.d.ts +1 -1
  104. package/dist/components/header/index.js +5 -5
  105. package/dist/components/headline/headline.css +2 -2
  106. package/dist/components/hero/hero.css +61 -25
  107. package/dist/components/hero/hero.schema.dereffed.json +9 -3
  108. package/dist/components/hero/hero.schema.json +8 -2
  109. package/dist/components/hero/index.d.ts +1 -1
  110. package/dist/components/hero/index.js +39 -39
  111. package/dist/components/image-story/image-story.css +5 -2
  112. package/dist/components/image-story/image-story.schema.dereffed.json +3 -3
  113. package/dist/components/image-story/index.d.ts +1 -1
  114. package/dist/components/index/index.d.ts +6 -5
  115. package/dist/components/logos/index.js +1 -1
  116. package/dist/components/mosaic/index.js +1 -1
  117. package/dist/components/mosaic/mosaic.css +1 -1
  118. package/dist/components/mosaic/mosaic.schema.dereffed.json +3 -3
  119. package/dist/components/nav-dropdown/index.d.ts +1 -1
  120. package/dist/components/nav-dropdown/index.js +2 -2
  121. package/dist/components/nav-dropdown/nav-dropdown.css +12 -3
  122. package/dist/components/nav-dropdown/nav-dropdown.schema.dereffed.json +1 -1
  123. package/dist/components/nav-flyout/index.d.ts +2 -2
  124. package/dist/components/nav-flyout/index.js +6 -8
  125. package/dist/components/nav-flyout/nav-flyout.css +29 -15
  126. package/dist/components/nav-flyout/nav-flyout.schema.dereffed.json +12 -12
  127. package/dist/components/nav-main/index.d.ts +5 -5
  128. package/dist/components/nav-main/index.js +0 -2
  129. package/dist/components/nav-main/nav-main.schema.dereffed.json +15 -15
  130. package/dist/components/nav-main/nav-main.schema.json +14 -14
  131. package/dist/components/nav-toggle/index.js +1 -1
  132. package/dist/components/nav-topbar/index.d.ts +2 -2
  133. package/dist/components/nav-topbar/index.js +2 -2
  134. package/dist/components/nav-topbar/nav-topbar.css +15 -2
  135. package/dist/components/nav-topbar/nav-topbar.schema.dereffed.json +12 -12
  136. package/dist/components/page/index.d.ts +1 -1
  137. package/dist/components/page/page.schema.dereffed.json +150 -74
  138. package/dist/components/page-wrapper/index.js +42 -0
  139. package/dist/components/page-wrapper/tokens.css +425 -729
  140. package/dist/components/pagination/index.d.ts +47 -0
  141. package/dist/components/pagination/index.js +52 -0
  142. package/dist/components/pagination/pagination.css +66 -0
  143. package/dist/components/pagination/pagination.schema.dereffed.json +64 -0
  144. package/dist/components/pagination/pagination.schema.json +57 -0
  145. package/dist/components/presets.json +832 -259
  146. package/dist/components/section/index.d.ts +1 -1
  147. package/dist/components/section/index.js +11 -3
  148. package/dist/components/section/section.css +38 -58
  149. package/dist/components/section/section.schema.dereffed.json +150 -74
  150. package/dist/components/section/section.schema.json +8 -10
  151. package/dist/components/settings/settings.schema.dereffed.json +24 -24
  152. package/dist/components/slider/index.d.ts +1 -1
  153. package/dist/components/slider/slider.schema.dereffed.json +59 -26
  154. package/dist/components/split/split.css +2 -2
  155. package/dist/components/stat/index.d.ts +1 -1
  156. package/dist/components/stat/index.js +3 -12
  157. package/dist/components/stat/stat.schema.dereffed.json +3 -4
  158. package/dist/components/stat/stat.schema.json +2 -2
  159. package/dist/components/stats/stats.schema.dereffed.json +3 -4
  160. package/dist/components/teaser-card/index.d.ts +1 -1
  161. package/dist/components/teaser-card/index.js +9 -9
  162. package/dist/components/teaser-card/teaser-card.css +67 -47
  163. package/dist/components/teaser-card/teaser-card.schema.dereffed.json +4 -4
  164. package/dist/components/teaser-card/teaser-card.schema.json +4 -4
  165. package/dist/components/testimonials/index.d.ts +1 -1
  166. package/dist/components/tile/tile.schema.dereffed.json +3 -3
  167. package/dist/components/tile/tile.schema.json +2 -2
  168. package/dist/components/video-curtain/index.d.ts +1 -1
  169. package/dist/components/video-curtain/index.js +12 -4
  170. package/dist/components/video-curtain/video-curtain.css +52 -29
  171. package/dist/components/video-curtain/video-curtain.schema.dereffed.json +6 -4
  172. package/dist/components/video-curtain/video-curtain.schema.json +3 -3
  173. package/dist/global.css +283 -59
  174. package/dist/static/fonts/systemics/Montserrat-Bold.woff2 +0 -0
  175. package/dist/static/fonts/systemics/Montserrat-Light.woff2 +0 -0
  176. package/dist/static/fonts/systemics/Montserrat-Medium.woff2 +0 -0
  177. package/dist/static/fonts/systemics/Montserrat-Regular.woff2 +0 -0
  178. package/dist/static/fonts/systemics/Montserrat-SemiBold.woff2 +0 -0
  179. package/dist/static/img/about/angled-image.png +0 -0
  180. package/dist/static/img/about/cta.png +0 -0
  181. package/dist/static/img/about/cutout.png +0 -0
  182. package/dist/static/img/about/disclaimer.png +0 -0
  183. package/dist/static/img/about/purpose.png +0 -0
  184. package/dist/static/img/about/spoiler.png +0 -0
  185. package/dist/static/img/kickstartDS/CMS-Starter producthunt-slide-01.svg +72 -0
  186. package/dist/static/img/kickstartDS/CMS-Starter producthunt-slide-02.svg +112 -0
  187. package/dist/static/img/kickstartDS/CMS-Starter producthunt-slide-03.svg +197 -0
  188. package/dist/static/img/kickstartDS/CMS-Starter producthunt-slide-04.svg +76 -0
  189. package/dist/static/img/kickstartDS/CMS-Starter producthunt-slide-05.svg +82 -0
  190. package/dist/static/img/kickstartDS/CMS-Starter producthunt-slide-06.svg +219 -0
  191. package/dist/static/img/kickstartDS/CMS-Starter producthunt-slide-07.svg +85 -0
  192. package/dist/static/logo-dark.svg +13 -0
  193. package/dist/static/logo-dsa-inverted.svg +26 -0
  194. package/dist/static/logo-dsa.svg +26 -0
  195. package/dist/static/logo-inverted.svg +12 -25
  196. package/dist/static/logo.svg +12 -25
  197. package/dist/tokens/IconSprite.js +42 -0
  198. package/dist/tokens/icon-sprite.html +16 -0
  199. package/dist/tokens/themes.css +4 -4
  200. package/dist/tokens/tokens.css +425 -729
  201. package/dist/tokens/tokens.js +628 -730
  202. package/package.json +1 -1
@@ -0,0 +1,153 @@
1
+ .dsa-downloads {
2
+ --dsa-downloads--gap: var(--ks-spacing-stack-xs);
3
+ --dsa-downloads-item--transition: var(--ks-transition-hover);
4
+ --dsa-downloads-item__gap: var(--ks-spacing-inline-s);
5
+ --dsa-downloads-item--background-color_hover: var(--ks-background-color-accent);
6
+ --dsa-downloads-item--padding: var(--ks-spacing-inset-xs);
7
+ --dsa-downloads-item--border-radius: var(--ks-border-radius-control);
8
+ --dsa-downloads-item__header-flex-basis: 120px;
9
+ --dsa-downloads-item__name--color: var(--ks-text-color-display);
10
+ --dsa-downloads-item__name--font: var(--ks-font-interface-s);
11
+ --dsa-downloads-item__name--font-weight: var(--ks-font-weight-semi-bold);
12
+ --dsa-downloads-item__description--font: var(--ks-font-interface-s);
13
+ --dsa-downloads-item__description--color: var(--ks-text-color-interface);
14
+ --dsa-downloads-item__infos--gap: var(--ks-spacing-xxs);
15
+ --dsa-downloads-item__infos--font: var(--ks-font-interface-s);
16
+ --dsa-downloads-item__infos--color: var(--ks-text-color-interface);
17
+ --dsa-downloads-item__infos--border: 1px solid var(--ks-border-color-default);
18
+ --dsa-downloads-item__placeholder-icon--color: var(--ks-color-fg-inverted);
19
+ --dsa-downloads-item__placeholder-icon--background-color: var(--ks-color-fg-to-bg-5);
20
+ --dsa-downloads-item__placeholder-icon--border-radius: var(--ks-border-radius-control);
21
+ --dsa-downloads-item__placeholder-icon--size: 2.65rem;
22
+ --dsa-downloads-item__button--color: var(--ks-text-color-interface-interactive);
23
+ --dsa-downloads-item__button--color_hover: var(--ks-text-color-interface-interactive-hover);
24
+ --dsa-downloads-item__button--font: var(--ks-font-interface-s);
25
+ --dsa-downloads-item__button--font-weight: var(--ks-font-weight-semi-bold);
26
+ --dsa-downloads-item__button--gap: var(--ks-spacing-xxs);
27
+ --dsa-downloads-item__download-icon--size: 1.5rem;
28
+ }
29
+
30
+ .dsa-downloads {
31
+ display: flex;
32
+ flex-direction: column;
33
+ justify-content: stretch;
34
+ gap: var(--dsa-downloads--gap, var(--ks-spacing-stack-xs));
35
+ }
36
+ .dsa-downloads .dsa-downloads-item {
37
+ --g-link--text-decoration: none;
38
+ --g-link--text-decoration-hover: none;
39
+ --g-link--color: var(--ks-text-color-interface-interactive);
40
+ --g-link--color-hover: var(--ks-text-color-interface-interactive);
41
+ --g-link--border-radius: var(--ks-border-radius-control);
42
+ --g-link--background: var(--ks-background-color-default);
43
+ --g-link--background-hover: var(--ks-background-color-default);
44
+ position: relative;
45
+ display: flex;
46
+ flex-wrap: wrap;
47
+ align-items: stretch;
48
+ justify-content: flex-end;
49
+ gap: var(--dsa-downloads-item__gap, var(--ks-spacing-inline-s));
50
+ border-radius: var(--dsa-downloads-item--border-radius, var(--ks-border-radius-control));
51
+ padding: var(--dsa-downloads-item--padding, var(--ks-spacing-xxs));
52
+ transition: var(--dsa-downloads-item--transition, var(--ks-transition-hover));
53
+ }
54
+ .dsa-downloads .dsa-downloads-item:hover {
55
+ cursor: pointer;
56
+ background-color: var(--dsa-downloads-item--background-color_hover, var(--ks-background-color-accent));
57
+ }
58
+ @media (min-width: 992px) {
59
+ .dsa-downloads .dsa-downloads-item:hover .dsa-downloads-item__button span {
60
+ background: linear-gradient(270deg, var(--dsa-downloads-item--background-color_hover, var(--ks-background-color-accent)) 80%, transparent);
61
+ opacity: 1;
62
+ transform: translateX(0%);
63
+ }
64
+ }
65
+ .dsa-downloads .dsa-downloads-item__header {
66
+ display: flex;
67
+ flex-direction: column;
68
+ align-self: center;
69
+ flex-shrink: 0;
70
+ flex-grow: 1;
71
+ flex-basis: var(--dsa-downloads-item__header-flex-basis, 120px);
72
+ }
73
+ .dsa-downloads .dsa-downloads-item__name {
74
+ font: var(--dsa-downloads-item__name--font, var(--ks-font-interface-s));
75
+ font-weight: var(--dsa-downloads-item__name--font-weight, var(--ks-font-weight-semi-bold));
76
+ color: var(--dsa-downloads-item__name--color, var(--ks-text-color-display));
77
+ }
78
+ .dsa-downloads .dsa-downloads-item__description {
79
+ font: var(--dsa-downloads-item__description--font, var(--ks-font-interface-s));
80
+ color: var(--dsa-downloads-item__description--color, var(--ks-text-color-interface));
81
+ }
82
+ .dsa-downloads .dsa-downloads-item__infos {
83
+ display: flex;
84
+ flex-wrap: wrap;
85
+ gap: var(--dsa-downloads-item__infos--gap, var(--ks-spacing-xxs));
86
+ }
87
+ .dsa-downloads .dsa-downloads-item__info {
88
+ color: var(--dsa-downloads-item__infos--color, var(--ks-text-color-interface));
89
+ font: var(--dsa-downloads-item__infos--font, var(--ks-font-interface-s));
90
+ padding-right: var(--dsa-downloads-item__infos--gap, var(--ks-spacing-xxs));
91
+ }
92
+ .dsa-downloads .dsa-downloads-item__info:not(:last-child) {
93
+ border-right: var(--dsa-downloads-item__infos--border, 1px solid var(--ks-border-color-default));
94
+ }
95
+ .dsa-downloads .dsa-downloads-item .l-container {
96
+ container-type: unset;
97
+ }
98
+ .dsa-downloads .dsa-downloads-item__image {
99
+ aspect-ratio: 1;
100
+ object-fit: contain;
101
+ width: var(--dsa-downloads-item__placeholder-icon--size, 2.65rem);
102
+ height: var(--dsa-downloads-item__placeholder-icon--size, 2.65rem);
103
+ }
104
+ .dsa-downloads .dsa-downloads-item__placeholder-icon {
105
+ aspect-ratio: 1;
106
+ flex-shrink: 0;
107
+ width: var(--dsa-downloads-item__placeholder-icon--size, 2.65rem);
108
+ height: var(--dsa-downloads-item__placeholder-icon--size, 2.65rem);
109
+ color: var(--dsa-downloads-item__placeholder-icon--color, var(--ks-color-fg-to-bg-3));
110
+ background-color: var(--dsa-downloads-item__placeholder-icon--background-color, var(--ks-color-fg-alpha-2));
111
+ border-radius: var(--dsa-downloads-item__placeholder-icon--border-radius, var(--ks-border-radius-control));
112
+ padding: var(--dsa-downloads-item__placeholder-icon--padding, var(--ks-spacing-xxs));
113
+ }
114
+ .dsa-downloads .dsa-downloads-item__button {
115
+ display: flex;
116
+ align-items: center;
117
+ position: relative;
118
+ text-decoration: none;
119
+ z-index: 2;
120
+ color: var(--dsa-downloads-item__button--color, var(--ks-text-color-interface-interactive));
121
+ font: var(--dsa-downloads-item__button--font, var(--ks-font-interface-s));
122
+ font-weight: var(--dsa-downloads-item__button--font-weight, var(--ks-font-weight-semi-bold));
123
+ transition: var(--dsa-downloads-item--transition, var(--ks-transition-hover));
124
+ border-radius: 0 var(--ks-border-radius-control) var(--ks-border-radius-control) 0;
125
+ }
126
+ .dsa-downloads .dsa-downloads-item__button .icon {
127
+ width: var(--dsa-downloads-item__download-icon--size, 1.5rem);
128
+ height: var(--dsa-downloads-item__download-icon--size, 1.5rem);
129
+ margin-left: var(--dsa-downloads-item__download-icon--gap, var(--ks-spacing-xxs));
130
+ transform: translateY(-1px);
131
+ }
132
+ .dsa-downloads .dsa-downloads-item__button:hover {
133
+ color: var(--dsa-downloads-item__button--color_hover, var(--ks-text-color-interface-interactive-hover));
134
+ }
135
+ .dsa-downloads .dsa-downloads-item__button:active, .dsa-downloads .dsa-downloads-item__button:visited, .dsa-downloads .dsa-downloads-item__button:hover, .dsa-downloads .dsa-downloads-item__button:focus {
136
+ text-decoration: none;
137
+ }
138
+ @media (min-width: 992px) {
139
+ .dsa-downloads .dsa-downloads-item__button span {
140
+ position: absolute;
141
+ padding-left: 3em;
142
+ display: block;
143
+ display: flex;
144
+ align-items: center;
145
+ transform: translateX(5%);
146
+ height: 100%;
147
+ background: transparent;
148
+ transition: var(--dsa-downloads-item--transition, var(--ks-transition-hover));
149
+ transition-property: transform opacity;
150
+ right: 100%;
151
+ opacity: 0;
152
+ }
153
+ }
@@ -0,0 +1,55 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/schema#",
3
+ "$id": "http://schema.mydesignsystem.com/downloads.schema.json",
4
+ "title": "Downloads",
5
+ "type": "object",
6
+ "properties": {
7
+ "downloads": {
8
+ "type": "array",
9
+ "items": {
10
+ "type": "object",
11
+ "properties": {
12
+ "name": {
13
+ "type": "string",
14
+ "description": "The name of the file"
15
+ },
16
+ "description": {
17
+ "type": "string",
18
+ "description": "A brief description of the file"
19
+ },
20
+ "previewImage": {
21
+ "type": "string",
22
+ "format": "uri",
23
+ "description": "A URL to an image that previews the file."
24
+ },
25
+ "url": {
26
+ "type": "string",
27
+ "format": "uri",
28
+ "description": "The URL to download the file from."
29
+ },
30
+ "size": {
31
+ "type": [
32
+ "string"
33
+ ],
34
+ "description": "The size of the download file"
35
+ },
36
+ "format": {
37
+ "type": [
38
+ "string"
39
+ ],
40
+ "description": "The format of the download file"
41
+ }
42
+ },
43
+ "required": [
44
+ "name",
45
+ "url"
46
+ ],
47
+ "additionalProperties": false
48
+ }
49
+ },
50
+ "type": {
51
+ "const": "downloads"
52
+ }
53
+ },
54
+ "additionalProperties": false
55
+ }
@@ -0,0 +1,44 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/schema#",
3
+ "$id": "http://schema.mydesignsystem.com/downloads.schema.json",
4
+ "title": "Downloads",
5
+ "type": "object",
6
+ "properties": {
7
+ "downloads": {
8
+ "type": "array",
9
+ "items": {
10
+ "type": "object",
11
+ "properties": {
12
+ "name": {
13
+ "type": "string",
14
+ "description": "The name of the file"
15
+ },
16
+ "description": {
17
+ "type": "string",
18
+ "description": "A brief description of the file"
19
+ },
20
+ "previewImage": {
21
+ "type": "string",
22
+ "format": "uri",
23
+ "description": "A URL to an image that previews the file."
24
+ },
25
+ "url": {
26
+ "type": "string",
27
+ "format": "uri",
28
+ "description": "The URL to download the file from."
29
+ },
30
+ "size": {
31
+ "type": ["string"],
32
+ "description": "The size of the download file"
33
+ },
34
+ "format": {
35
+ "type": ["string"],
36
+ "description": "The format of the download file"
37
+ }
38
+ },
39
+ "required": ["name", "url"]
40
+ }
41
+ }
42
+ },
43
+ "additionalProperties": false
44
+ }
@@ -0,0 +1,41 @@
1
+ /// <reference types="react" />
2
+ import { HTMLAttributes } from "react";
3
+ /* eslint-disable */
4
+ /**
5
+ * This file was automatically generated by json-schema-to-typescript.
6
+ * DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
7
+ * and run json-schema-to-typescript to regenerate this file.
8
+ */
9
+ interface DownloadsProps {
10
+ downloads?: {
11
+ /**
12
+ * The name of the file
13
+ */
14
+ name: string;
15
+ /**
16
+ * A brief description of the file
17
+ */
18
+ description?: string;
19
+ /**
20
+ * A URL to an image that previews the file.
21
+ */
22
+ previewImage?: string;
23
+ /**
24
+ * The URL to download the file from.
25
+ */
26
+ url: string;
27
+ /**
28
+ * The size of the download file
29
+ */
30
+ size?: string;
31
+ /**
32
+ * The format of the download file
33
+ */
34
+ format?: string;
35
+ }[];
36
+ }
37
+ declare const DownloadsContextDefault: import("react").ForwardRefExoticComponent<DownloadsProps & HTMLAttributes<HTMLDivElement> & import("react").RefAttributes<HTMLDivElement>>;
38
+ declare const DownloadsContext: import("react").Context<import("react").ForwardRefExoticComponent<DownloadsProps & HTMLAttributes<HTMLDivElement> & import("react").RefAttributes<HTMLDivElement>>>;
39
+ declare const Downloads: import("react").ForwardRefExoticComponent<DownloadsProps & HTMLAttributes<HTMLDivElement> & import("react").RefAttributes<HTMLDivElement>>;
40
+ export type { DownloadsProps };
41
+ export { DownloadsContextDefault, DownloadsContext, Downloads };
@@ -0,0 +1,18 @@
1
+ import "./downloads.css";
2
+ import { jsx, jsxs } from 'react/jsx-runtime';
3
+ import { forwardRef, createContext, useContext } from 'react';
4
+ import { RichText } from '@kickstartds/base/lib/rich-text';
5
+ import { Icon } from '@kickstartds/base/lib/icon';
6
+ import { Picture } from '@kickstartds/base/lib/picture';
7
+
8
+ const DownloadsContextDefault = forwardRef(({ downloads }, ref) => {
9
+ return (jsx("div", { className: "dsa-downloads", ref: ref, children: downloads.map((item, index) => (jsxs("a", { href: item?.url, target: "_blank", className: "dsa-downloads-item", "aria-label": "Download file", children: [item?.previewImage ? (jsx(Picture, { "aria-hidden": true, className: "dsa-downloads-item__image", src: item.previewImage, alt: "" })) : (jsx(Icon, { "aria-hidden": true, className: "dsa-downloads-item__placeholder-icon", icon: "file" })), jsxs("div", { className: "dsa-downloads-item__header", children: [jsx("span", { className: "dsa-downloads-item__name", children: item.name }), (item?.format || item?.size || item?.description) && (jsxs("div", { className: "dsa-downloads-item__infos", children: [item?.format && (jsx("span", { className: "dsa-downloads-item__info dsa-downloads-item__format", children: item.format })), item?.size && (jsx("span", { className: "dsa-downloads-item__info dsa-downloads-item__size", children: item.size })), item?.description && (jsx(RichText, { className: "dsa-downloads-item__description", text: item.description }))] }))] }), jsxs("span", { "aria-hidden": true, className: "dsa-downloads-item__button", children: [jsx("span", { children: "Download" }), jsx(Icon, { "aria-hidden": true, icon: "download" })] })] }, index))) }));
10
+ });
11
+ const DownloadsContext = createContext(DownloadsContextDefault);
12
+ const Downloads = forwardRef((props, ref) => {
13
+ const Component = useContext(DownloadsContext);
14
+ return jsx(Component, { ...props, ref: ref });
15
+ });
16
+ Downloads.displayName = "Downloads";
17
+
18
+ export { Downloads, DownloadsContext, DownloadsContextDefault };
@@ -0,0 +1,62 @@
1
+ .dsa-event-appointment {
2
+ --g-link--color: var(--ks-text-color-interface-interactive);
3
+ --g-link--color-hover: var(--ks-text-color-interface-interactive);
4
+ --g-link--border-radius: var(--ks-border-radius-card);
5
+ --g-link--background: var(--ks-background-color-default);
6
+ --g-link--background-hover: var(--ks-background-color-default);
7
+ display: flex;
8
+ flex-direction: row;
9
+ flex-wrap: wrap;
10
+ justify-content: space-between;
11
+ gap: var(--ks-spacing-inline-s);
12
+ padding: var(--ks-spacing-inset-s);
13
+ border: var(--ks-border-width-default) solid var(--ks-border-color-interface-interactive);
14
+ height: fit-content;
15
+ font: inherit;
16
+ }
17
+ .dsa-event-appointment:hover {
18
+ border-color: var(--ks-border-color-interface-interactive-hover);
19
+ }
20
+ .dsa-event-appointment__info {
21
+ display: flex;
22
+ gap: var(--ks-spacing-xxs);
23
+ text-decoration: none;
24
+ align-items: center;
25
+ }
26
+ .dsa-event-appointment__info--date {
27
+ font-weight: var(--ks-font-weight-semi-bold);
28
+ color: var(--ks-text-color-display);
29
+ }
30
+ .dsa-event-appointment__info--time {
31
+ font-weight: var(--ks-font-weight-regular);
32
+ }
33
+ .dsa-event-appointment__infos {
34
+ flex-direction: column;
35
+ display: flex;
36
+ gap: var(--ks-spacing-stack-xs);
37
+ }
38
+ .dsa-event-appointment__label {
39
+ display: flex;
40
+ align-items: center;
41
+ color: var(--dsa-link--color);
42
+ font: var(--ks-font-interface-s);
43
+ align-self: flex-end;
44
+ font-weight: var(--ks-font-weight-semi-bold);
45
+ transition: var(--ks-transition-hover);
46
+ transition-property: color;
47
+ }
48
+ .dsa-event-appointment__label:hover {
49
+ color: var(--dsa-link--color_hover);
50
+ }
51
+ .dsa-event-appointment__label .icon {
52
+ width: 1.75em;
53
+ height: 1.75em;
54
+ }
55
+ .dsa-event-appointment__icon {
56
+ color: var(--ks-text-color-primary);
57
+ width: 1.75em;
58
+ height: 1.75em;
59
+ }
60
+ .dsa-event-appointment .l-container--rich-text {
61
+ container-type: normal;
62
+ }
@@ -0,0 +1,56 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/schema#",
3
+ "$id": "http://schema.mydesignsystem.com/event-appointment.schema.json",
4
+ "title": "Event Appointment",
5
+ "type": "object",
6
+ "properties": {
7
+ "date": {
8
+ "title": "Date",
9
+ "description": "Date of the appointment",
10
+ "type": "string",
11
+ "format": "date",
12
+ "examples": [
13
+ "2025-09-18"
14
+ ]
15
+ },
16
+ "time": {
17
+ "title": "Time",
18
+ "description": "Time of the appointment",
19
+ "type": "string",
20
+ "examples": [
21
+ "09:00 – 17:00"
22
+ ]
23
+ },
24
+ "label": {
25
+ "title": "CTA Label",
26
+ "description": "Label for the call to action button",
27
+ "type": "string",
28
+ "examples": [
29
+ "Register"
30
+ ]
31
+ },
32
+ "url": {
33
+ "title": "URL",
34
+ "description": "URL for the call to action button",
35
+ "type": "string",
36
+ "format": "uri",
37
+ "default": "#"
38
+ },
39
+ "newTab": {
40
+ "title": "Open in New Tab",
41
+ "description": "Whether the link should open in a new tab",
42
+ "type": "boolean",
43
+ "default": true
44
+ },
45
+ "ariaLabel": {
46
+ "title": "Aria Label",
47
+ "description": "Aria label for the link",
48
+ "type": "string",
49
+ "default": "Event Appointment"
50
+ },
51
+ "type": {
52
+ "const": "event-appointment"
53
+ }
54
+ },
55
+ "additionalProperties": false
56
+ }
@@ -0,0 +1,47 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/schema#",
3
+ "$id": "http://schema.mydesignsystem.com/event-appointment.schema.json",
4
+ "title": "Event Appointment",
5
+ "type": "object",
6
+ "properties": {
7
+ "date": {
8
+ "title": "Date",
9
+ "description": "Date of the appointment",
10
+ "type": "string",
11
+ "format": "date",
12
+ "examples": ["2025-09-18"]
13
+ },
14
+ "time": {
15
+ "title": "Time",
16
+ "description": "Time of the appointment",
17
+ "type": "string",
18
+ "examples": ["09:00 – 17:00"]
19
+ },
20
+ "label": {
21
+ "title": "CTA Label",
22
+ "description": "Label for the call to action button",
23
+ "type": "string",
24
+ "examples": ["Register"]
25
+ },
26
+ "url": {
27
+ "title": "URL",
28
+ "description": "URL for the call to action button",
29
+ "type": "string",
30
+ "format": "uri",
31
+ "default": "#"
32
+ },
33
+ "newTab": {
34
+ "title": "Open in New Tab",
35
+ "description": "Whether the link should open in a new tab",
36
+ "type": "boolean",
37
+ "default": true
38
+ },
39
+ "ariaLabel": {
40
+ "title": "Aria Label",
41
+ "description": "Aria label for the link",
42
+ "type": "string",
43
+ "default": "Event Appointment"
44
+ }
45
+ },
46
+ "additionalProperties": false
47
+ }
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import { EventAppointmentProps } from "../../EventAppointmentProps-443cd1ce.js";
3
+ declare const EventAppointmentContextDefault: import("react").ForwardRefExoticComponent<EventAppointmentProps & import("react").RefAttributes<HTMLAnchorElement>>;
4
+ declare const EventAppointmentContext: import("react").Context<import("react").ForwardRefExoticComponent<EventAppointmentProps & import("react").RefAttributes<HTMLAnchorElement>>>;
5
+ declare const EventAppointment: import("react").ForwardRefExoticComponent<EventAppointmentProps & import("react").RefAttributes<HTMLAnchorElement>>;
6
+ export type { EventAppointmentProps };
7
+ export { EventAppointmentContextDefault, EventAppointmentContext, EventAppointment };
@@ -0,0 +1,14 @@
1
+ import "./event-appointment.css";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import { forwardRef, createContext, useContext } from 'react';
4
+ import { Icon } from '@kickstartds/base/lib/icon';
5
+
6
+ const EventAppointmentContextDefault = forwardRef(({ date, time, label, url, newTab, ariaLabel }, ref) => (jsxs("a", { className: "dsa-event-appointment", target: newTab ? "_blank" : "_self", "aria-label": ariaLabel, href: url, ref: ref, children: [jsxs("span", { className: "dsa-event-appointment__infos", children: [date && (jsxs("span", { className: "dsa-event-appointment__info dsa-event-appointment__info--date", children: [jsx(Icon, { className: "dsa-event-appointment__icon", "aria-hidden": true, icon: "date" }), date] })), time && (jsxs("span", { className: "dsa-event-appointment__info dsa-event-appointment__info--time", children: [jsx(Icon, { className: "dsa-event-appointment__icon", "aria-hidden": true, icon: "time" }), time] }))] }), jsxs("span", { className: "dsa-event-appointment__label", children: [label, jsx(Icon, { icon: "chevron-right" })] })] })));
7
+ const EventAppointmentContext = createContext(EventAppointmentContextDefault);
8
+ const EventAppointment = forwardRef((props, ref) => {
9
+ const Component = useContext(EventAppointmentContext);
10
+ return jsx(Component, { ...props, ref: ref });
11
+ });
12
+ EventAppointment.displayName = "EventAppointment";
13
+
14
+ export { EventAppointment, EventAppointmentContext, EventAppointmentContextDefault };