@mirweb/mir-web-components 1.15.3 → 2.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 (184) hide show
  1. package/README.md +2 -2
  2. package/dist/assets/index-Cl4fzBs2.js +17 -0
  3. package/dist/assets/scss/globals.scss +231 -0
  4. package/dist/assets/scss/index.scss +4 -0
  5. package/dist/assets/scss/normalize.scss +393 -0
  6. package/dist/assets/scss/reset.scss +102 -0
  7. package/dist/assets/scss/variables.scss +95 -0
  8. package/dist/components/atoms/button/button.vue +81 -0
  9. package/dist/components/atoms/checkbox/checkbox.vue +125 -0
  10. package/dist/components/atoms/chip/chip.vue +55 -0
  11. package/dist/components/atoms/dropdown/dropdown.vue +490 -0
  12. package/dist/components/atoms/image/image.vue +42 -0
  13. package/dist/components/atoms/label/label.vue +52 -0
  14. package/dist/components/atoms/link/link.vue +166 -0
  15. package/dist/components/atoms/radio-button/radio-button.vue +110 -0
  16. package/dist/components/atoms/select/select.vue +116 -0
  17. package/dist/components/atoms/select-multiple/select-multiple.vue +210 -0
  18. package/dist/components/atoms/slider/slider.vue +322 -0
  19. package/dist/components/atoms/text-field/text-field.vue +273 -0
  20. package/dist/components/atoms/textarea/textarea.vue +179 -0
  21. package/dist/components/atoms/video/video.vue +98 -0
  22. package/dist/components/blocks/accordion/accordion.vue +222 -0
  23. package/dist/components/blocks/card-display/card-display.vue +125 -0
  24. package/dist/components/blocks/column-grid/column-grid.vue +201 -0
  25. package/dist/components/blocks/facts/facts.vue +156 -0
  26. package/dist/components/blocks/features/features.vue +176 -0
  27. package/dist/components/blocks/flashcards/flashcards.vue +212 -0
  28. package/dist/components/blocks/form-script/form-script.vue +172 -0
  29. package/dist/components/blocks/frontpage-hero/frontpage-hero.vue +214 -0
  30. package/dist/components/blocks/headline/headline.vue +93 -0
  31. package/dist/components/blocks/hero/hero.vue +173 -0
  32. package/dist/components/blocks/image/image.vue +93 -0
  33. package/dist/components/blocks/image-gallery/image-gallery.vue +289 -0
  34. package/dist/components/blocks/logo-wall/logo-wall.vue +125 -0
  35. package/dist/components/blocks/micro-stories/micro-stories.vue +316 -0
  36. package/dist/components/blocks/pallet-jack/pallet-jack.vue +440 -0
  37. package/dist/components/blocks/policy/policy.vue +106 -0
  38. package/dist/components/blocks/product-hero/product-hero.vue +140 -0
  39. package/dist/components/blocks/promo/promo.vue +403 -0
  40. package/dist/components/blocks/quote/quote.vue +127 -0
  41. package/dist/components/blocks/rich-text/rich-text-columns.vue +159 -0
  42. package/dist/components/blocks/rich-text/rich-text.vue +296 -0
  43. package/dist/components/blocks/timeline/timeline.vue +232 -0
  44. package/dist/components/blocks/vimeo/vimeo.vue +52 -0
  45. package/dist/components/index.ts +51 -0
  46. package/dist/components/molecules/address/address.vue +123 -0
  47. package/dist/components/molecules/bullet-list/bullet-list.vue +99 -0
  48. package/dist/components/molecules/card/card.vue +302 -0
  49. package/dist/components/molecules/column-card/column-card.vue +178 -0
  50. package/dist/components/molecules/event-card/event-card.vue +111 -0
  51. package/dist/components/molecules/flashcard/flashcard.vue +293 -0
  52. package/dist/components/molecules/modal/modal.vue +113 -0
  53. package/dist/components/molecules/text-card/text-card.vue +74 -0
  54. package/dist/components/organisms/404/404.vue +79 -0
  55. package/dist/components/organisms/filter/filter.vue +89 -0
  56. package/dist/components/organisms/footer/footer.vue +356 -0
  57. package/dist/components/organisms/header/header.vue +754 -0
  58. package/dist/components/organisms/language-switcher/language-switcher.vue +68 -0
  59. package/dist/components/organisms/pagination/pagination.vue +85 -0
  60. package/dist/components/organisms/search/search.vue +153 -0
  61. package/dist/components/templates/404-error-page.vue +0 -0
  62. package/dist/directives/clickOutside.ts +15 -0
  63. package/dist/fonts/OpenSans-Light.woff2 +0 -0
  64. package/dist/fonts/OpenSans-Medium.woff2 +0 -0
  65. package/dist/fonts/OpenSans-Regular.woff2 +0 -0
  66. package/dist/fonts/OpenSans-SemiBold.woff2 +0 -0
  67. package/dist/fonts/Oscine_Bd.woff2 +0 -0
  68. package/dist/fonts/Oscine_Lt.woff2 +0 -0
  69. package/dist/fonts/Oscine_Rg.woff2 +0 -0
  70. package/dist/index.html +12 -0
  71. package/dist/main.css +1 -0
  72. package/package.json +8 -10
  73. package/dist/components/atoms/button/button.vue.d.ts +0 -5
  74. package/dist/components/atoms/button/button.vue.d.ts.map +0 -1
  75. package/dist/components/atoms/checkbox/checkbox.vue.d.ts +0 -5
  76. package/dist/components/atoms/checkbox/checkbox.vue.d.ts.map +0 -1
  77. package/dist/components/atoms/chip/chip.vue.d.ts +0 -5
  78. package/dist/components/atoms/chip/chip.vue.d.ts.map +0 -1
  79. package/dist/components/atoms/dropdown/dropdown.vue.d.ts +0 -5
  80. package/dist/components/atoms/dropdown/dropdown.vue.d.ts.map +0 -1
  81. package/dist/components/atoms/image/image.vue.d.ts +0 -5
  82. package/dist/components/atoms/image/image.vue.d.ts.map +0 -1
  83. package/dist/components/atoms/label/label.vue.d.ts +0 -5
  84. package/dist/components/atoms/label/label.vue.d.ts.map +0 -1
  85. package/dist/components/atoms/link/link.vue.d.ts +0 -5
  86. package/dist/components/atoms/link/link.vue.d.ts.map +0 -1
  87. package/dist/components/atoms/radio-button/radio-button.vue.d.ts +0 -5
  88. package/dist/components/atoms/radio-button/radio-button.vue.d.ts.map +0 -1
  89. package/dist/components/atoms/select/select.vue.d.ts +0 -5
  90. package/dist/components/atoms/select/select.vue.d.ts.map +0 -1
  91. package/dist/components/atoms/select-multiple/select-multiple.vue.d.ts +0 -5
  92. package/dist/components/atoms/select-multiple/select-multiple.vue.d.ts.map +0 -1
  93. package/dist/components/atoms/slider/slider.vue.d.ts +0 -5
  94. package/dist/components/atoms/slider/slider.vue.d.ts.map +0 -1
  95. package/dist/components/atoms/text-field/text-field.vue.d.ts +0 -5
  96. package/dist/components/atoms/text-field/text-field.vue.d.ts.map +0 -1
  97. package/dist/components/atoms/textarea/textarea.vue.d.ts +0 -5
  98. package/dist/components/atoms/textarea/textarea.vue.d.ts.map +0 -1
  99. package/dist/components/atoms/video/video.vue.d.ts +0 -5
  100. package/dist/components/atoms/video/video.vue.d.ts.map +0 -1
  101. package/dist/components/blocks/accordion/accordion.vue.d.ts +0 -5
  102. package/dist/components/blocks/accordion/accordion.vue.d.ts.map +0 -1
  103. package/dist/components/blocks/card-display/card-display.vue.d.ts +0 -6
  104. package/dist/components/blocks/card-display/card-display.vue.d.ts.map +0 -1
  105. package/dist/components/blocks/column-grid/column-grid.vue.d.ts +0 -5
  106. package/dist/components/blocks/column-grid/column-grid.vue.d.ts.map +0 -1
  107. package/dist/components/blocks/facts/facts.vue.d.ts +0 -5
  108. package/dist/components/blocks/facts/facts.vue.d.ts.map +0 -1
  109. package/dist/components/blocks/features/features.vue.d.ts +0 -5
  110. package/dist/components/blocks/features/features.vue.d.ts.map +0 -1
  111. package/dist/components/blocks/flashcards/flashcards.vue.d.ts +0 -5
  112. package/dist/components/blocks/flashcards/flashcards.vue.d.ts.map +0 -1
  113. package/dist/components/blocks/form-script/form-script.vue.d.ts +0 -5
  114. package/dist/components/blocks/form-script/form-script.vue.d.ts.map +0 -1
  115. package/dist/components/blocks/frontpage-hero/frontpage-hero.vue.d.ts +0 -5
  116. package/dist/components/blocks/frontpage-hero/frontpage-hero.vue.d.ts.map +0 -1
  117. package/dist/components/blocks/headline/headline.vue.d.ts +0 -5
  118. package/dist/components/blocks/headline/headline.vue.d.ts.map +0 -1
  119. package/dist/components/blocks/hero/hero.vue.d.ts +0 -5
  120. package/dist/components/blocks/hero/hero.vue.d.ts.map +0 -1
  121. package/dist/components/blocks/image/image.vue.d.ts +0 -5
  122. package/dist/components/blocks/image/image.vue.d.ts.map +0 -1
  123. package/dist/components/blocks/image-gallery/image-gallery.vue.d.ts +0 -5
  124. package/dist/components/blocks/image-gallery/image-gallery.vue.d.ts.map +0 -1
  125. package/dist/components/blocks/logo-wall/logo-wall.vue.d.ts +0 -5
  126. package/dist/components/blocks/logo-wall/logo-wall.vue.d.ts.map +0 -1
  127. package/dist/components/blocks/micro-stories/micro-stories.vue.d.ts +0 -5
  128. package/dist/components/blocks/micro-stories/micro-stories.vue.d.ts.map +0 -1
  129. package/dist/components/blocks/pallet-jack/pallet-jack.vue.d.ts +0 -5
  130. package/dist/components/blocks/pallet-jack/pallet-jack.vue.d.ts.map +0 -1
  131. package/dist/components/blocks/policy/policy.vue.d.ts +0 -4
  132. package/dist/components/blocks/policy/policy.vue.d.ts.map +0 -1
  133. package/dist/components/blocks/product-hero/product-hero.vue.d.ts +0 -5
  134. package/dist/components/blocks/product-hero/product-hero.vue.d.ts.map +0 -1
  135. package/dist/components/blocks/promo/promo.vue.d.ts +0 -5
  136. package/dist/components/blocks/promo/promo.vue.d.ts.map +0 -1
  137. package/dist/components/blocks/quote/quote.vue.d.ts +0 -5
  138. package/dist/components/blocks/quote/quote.vue.d.ts.map +0 -1
  139. package/dist/components/blocks/rich-text/rich-text-columns.vue.d.ts +0 -4
  140. package/dist/components/blocks/rich-text/rich-text-columns.vue.d.ts.map +0 -1
  141. package/dist/components/blocks/rich-text/rich-text.vue.d.ts +0 -5
  142. package/dist/components/blocks/rich-text/rich-text.vue.d.ts.map +0 -1
  143. package/dist/components/blocks/timeline/timeline.vue.d.ts +0 -5
  144. package/dist/components/blocks/timeline/timeline.vue.d.ts.map +0 -1
  145. package/dist/components/blocks/vimeo/vimeo.vue.d.ts +0 -5
  146. package/dist/components/blocks/vimeo/vimeo.vue.d.ts.map +0 -1
  147. package/dist/components/index.d.ts +0 -51
  148. package/dist/components/main.d.ts +0 -59
  149. package/dist/components/molecules/address/address.vue.d.ts +0 -5
  150. package/dist/components/molecules/address/address.vue.d.ts.map +0 -1
  151. package/dist/components/molecules/bullet-list/bullet-list.vue.d.ts +0 -5
  152. package/dist/components/molecules/bullet-list/bullet-list.vue.d.ts.map +0 -1
  153. package/dist/components/molecules/card/card.vue.d.ts +0 -5
  154. package/dist/components/molecules/card/card.vue.d.ts.map +0 -1
  155. package/dist/components/molecules/column-card/column-card.vue.d.ts +0 -5
  156. package/dist/components/molecules/column-card/column-card.vue.d.ts.map +0 -1
  157. package/dist/components/molecules/event-card/event-card.vue.d.ts +0 -5
  158. package/dist/components/molecules/event-card/event-card.vue.d.ts.map +0 -1
  159. package/dist/components/molecules/flashcard/flashcard.vue.d.ts +0 -5
  160. package/dist/components/molecules/flashcard/flashcard.vue.d.ts.map +0 -1
  161. package/dist/components/molecules/modal/modal.vue.d.ts +0 -5
  162. package/dist/components/molecules/modal/modal.vue.d.ts.map +0 -1
  163. package/dist/components/molecules/text-card/text-card.vue.d.ts +0 -5
  164. package/dist/components/molecules/text-card/text-card.vue.d.ts.map +0 -1
  165. package/dist/components/organisms/404/404.vue.d.ts +0 -5
  166. package/dist/components/organisms/404/404.vue.d.ts.map +0 -1
  167. package/dist/components/organisms/filter/filter.vue.d.ts +0 -5
  168. package/dist/components/organisms/filter/filter.vue.d.ts.map +0 -1
  169. package/dist/components/organisms/footer/footer.vue.d.ts +0 -5
  170. package/dist/components/organisms/footer/footer.vue.d.ts.map +0 -1
  171. package/dist/components/organisms/header/header.vue.d.ts +0 -6
  172. package/dist/components/organisms/header/header.vue.d.ts.map +0 -1
  173. package/dist/components/organisms/language-switcher/language-switcher.vue.d.ts +0 -5
  174. package/dist/components/organisms/language-switcher/language-switcher.vue.d.ts.map +0 -1
  175. package/dist/components/organisms/pagination/pagination.vue.d.ts +0 -5
  176. package/dist/components/organisms/pagination/pagination.vue.d.ts.map +0 -1
  177. package/dist/components/organisms/search/search.vue.d.ts +0 -4
  178. package/dist/components/organisms/search/search.vue.d.ts.map +0 -1
  179. package/dist/directives/clickOutside.d.ts +0 -3
  180. package/dist/main.d.ts +0 -1
  181. package/dist/mir-web-components.cjs.js +0 -1
  182. package/dist/mir-web-components.css +0 -1
  183. package/dist/mir-web-components.es.js +0 -3187
  184. package/dist/mir-web-components.umd.js +0 -2
@@ -0,0 +1,173 @@
1
+ <template>
2
+ <div class="hero__wrapper">
3
+ <div class="hero__content">
4
+ <div class="hero__top">
5
+ <div class="hero__elements">
6
+ <div class="hero__headline">
7
+ <h1>{{ headline }}</h1>
8
+ </div>
9
+ <div class="hero__link">
10
+ <atom-link link-type="regular_light" arrow>
11
+ <slot name="hero-link"></slot>
12
+ </atom-link>
13
+ </div>
14
+ </div>
15
+ </div>
16
+
17
+ <div class="hero__video">
18
+ <div class="hero__gradient"></div>
19
+ <div class="hero__video__video">
20
+ <slot name="hero-video" />
21
+ </div>
22
+ <div class="hero__image">
23
+ <slot name="hero-image" />
24
+ </div>
25
+ </div>
26
+ </div>
27
+ </div>
28
+ </template>
29
+
30
+ <script setup lang="ts">
31
+ import AtomLink from "../../atoms/link/link.vue";
32
+
33
+ defineProps({
34
+ headline: {
35
+ type: String,
36
+ required: true,
37
+ },
38
+ });
39
+ </script>
40
+
41
+ <style lang="scss" scoped>
42
+ @use "../../../assets/scss/variables.scss" as *;
43
+ .hero {
44
+ &__wrapper {
45
+ width: 100%;
46
+ background-color: $blue-100;
47
+ display: flex;
48
+ flex-direction: row;
49
+ justify-content: center;
50
+ margin-bottom: 30px;
51
+ @include md {
52
+ margin-bottom: 60px;
53
+ }
54
+ }
55
+
56
+ &__content {
57
+ display: grid;
58
+ position: relative;
59
+ grid-template-rows: 1fr auto;
60
+ grid-template-columns: 1fr;
61
+ overflow-x: clip;
62
+ max-height: 100%;
63
+
64
+ @include sm {
65
+ grid-template-columns: fit-content(repeat(2, 1fr auto));
66
+ grid-template-rows: 1fr;
67
+ }
68
+
69
+ @include md {
70
+ grid-template-columns: 1fr 984px 1fr;
71
+ }
72
+
73
+ @include lg {
74
+ grid-template-columns: minmax(0, 1fr) 164px 984px 164px minmax(0, 1fr);
75
+ }
76
+ }
77
+
78
+ &__top {
79
+ grid-area: 2;
80
+ padding: 30px;
81
+ height: 100%;
82
+ width: 100%;
83
+ display: flex;
84
+ flex-direction: column;
85
+ align-items: flex-start;
86
+ justify-content: center;
87
+
88
+ @include sm {
89
+ position: absolute;
90
+ z-index: 2;
91
+ top: 0;
92
+ left: 0;
93
+ margin-left: 30px;
94
+ grid-area: auto;
95
+ padding: 0;
96
+ }
97
+ @include md {
98
+ grid-area: 1 / 2 / 2 / 4;
99
+ margin: 0px;
100
+ }
101
+
102
+ @include lg {
103
+ grid-area: 1 / 3 / 2 / 5;
104
+ }
105
+ }
106
+
107
+ &__elements {
108
+ display: flex;
109
+ flex-direction: column;
110
+ text-align: center;
111
+ gap: 30px;
112
+ justify-content: center;
113
+ width: 100%;
114
+
115
+ @include sm {
116
+ max-width: 45%;
117
+
118
+ text-align: left;
119
+ }
120
+ }
121
+
122
+ &__headline {
123
+ h1 {
124
+ font-size: $font-size-lg;
125
+ line-height: $line-height-lg;
126
+
127
+ @include md {
128
+ font-size: $font-size-xlg;
129
+ line-height: $line-height-xlg;
130
+ }
131
+ }
132
+ }
133
+
134
+ &__gradient {
135
+ @include sm {
136
+ position: absolute;
137
+ top: 0;
138
+ left: 0;
139
+ width: 100%;
140
+ height: 100%;
141
+ background: linear-gradient(
142
+ to right,
143
+ $blue-100 0%,
144
+ rgb(249, 253, 255, 0.75) 45%,
145
+ transparent 70%
146
+ ),
147
+ linear-gradient(to left, $blue-100 0%, transparent 35%),
148
+ linear-gradient(to bottom, $blue-100 0%, transparent 25%),
149
+ linear-gradient(to top, $blue-100 0%, transparent 25%);
150
+ z-index: 1;
151
+ }
152
+ }
153
+
154
+ &__video {
155
+ grid-area: 1 / 1 / 2 / 5;
156
+ height: auto;
157
+ width: 100%;
158
+
159
+ :deep(video) {
160
+ width: 100%;
161
+ height: auto;
162
+ outline: 4px solid $blue-100;
163
+ outline-offset: -4px;
164
+ position: relative;
165
+ z-index: 0;
166
+
167
+ @include sm {
168
+ outline: none;
169
+ }
170
+ }
171
+ }
172
+ }
173
+ </style>
@@ -0,0 +1,93 @@
1
+ <template>
2
+ <div class="image__wrapper">
3
+ <div class="image__content">
4
+ <div class="image__image">
5
+ <atom-image>
6
+ <slot
7
+ name="image"
8
+ v-bind="{
9
+ width: 984,
10
+ height: fullHeight ? '100%' : 554,
11
+ src: src,
12
+ alt: alt,
13
+ class: fullHeight ? 'full-height' : 'default',
14
+ }"
15
+ ></slot>
16
+ </atom-image>
17
+ </div>
18
+ <p class="image__caption">
19
+ {{ caption }}
20
+ </p>
21
+ </div>
22
+ </div>
23
+ </template>
24
+
25
+ <script setup lang="ts">
26
+ import AtomImage from "../../atoms/image/image.vue";
27
+
28
+ defineProps({
29
+ caption: {
30
+ type: String,
31
+ required: false,
32
+ default: "",
33
+ },
34
+ src: {
35
+ type: String,
36
+ required: true,
37
+ },
38
+ alt: {
39
+ type: String,
40
+ required: true,
41
+ },
42
+ fullHeight: {
43
+ type: Boolean,
44
+ required: false,
45
+ default: false,
46
+ },
47
+ });
48
+
49
+ defineOptions({
50
+ inheritAttrs: false,
51
+ });
52
+ </script>
53
+
54
+ <style scoped lang="scss">
55
+ @use "../../../assets/scss/variables.scss" as *;
56
+ .image {
57
+ &__wrapper {
58
+ width: 100%;
59
+ }
60
+
61
+ &__content {
62
+ max-width: $max-width;
63
+ margin: 0 auto;
64
+ display: flex;
65
+ flex-direction: column;
66
+ padding: $padding-mobile;
67
+ @include md {
68
+ padding: $padding-desktop;
69
+ }
70
+ }
71
+
72
+ &__image {
73
+ :slotted(.full-height) {
74
+ object-fit: contain;
75
+ max-height: 100%;
76
+ }
77
+ :slotted(.default) {
78
+ object-fit: cover;
79
+ max-height: 554px;
80
+ }
81
+ }
82
+
83
+ &__caption {
84
+ font-size: $font-size-xsm;
85
+ margin-top: 15px;
86
+ padding: 0px 30px;
87
+
88
+ @include md {
89
+ padding: 0px;
90
+ }
91
+ }
92
+ }
93
+ </style>
@@ -0,0 +1,289 @@
1
+ <template>
2
+ <div :class="['gallery__wrapper', selectedBgColor]">
3
+ <div
4
+ :class="[
5
+ 'gallery__content',
6
+ flipHorizontal
7
+ ? 'gallery__content--reverse'
8
+ : 'gallery__content--default',
9
+ ]"
10
+ >
11
+ <div class="gallery__large">
12
+ <div
13
+ v-if="mediaLarge && mediaType === 'image'"
14
+ class="image image--large"
15
+ >
16
+ <atom-image
17
+ ><slot
18
+ name="image-large"
19
+ v-bind="{
20
+ height: 530,
21
+ src: mediaLarge.src,
22
+ alt: mediaLarge.alt,
23
+ }"
24
+ ></slot
25
+ ></atom-image>
26
+ </div>
27
+ <div v-if="mediaLarge && mediaType === 'video'" class="video">
28
+ <atom-video
29
+ :src="mediaLarge.src"
30
+ local-video
31
+ :aria-label="mediaLarge.alt"
32
+ :controls="false"
33
+ height="530"
34
+ width="617"
35
+ autoplay
36
+ loop
37
+ muted
38
+ play
39
+ ></atom-video>
40
+ </div>
41
+ </div>
42
+ <div
43
+ :style="[mediaSmall.length === 2 ? 'grid-gap: 38px;' : '']"
44
+ :class="[
45
+ 'gallery__small',
46
+ flipVertical ? 'gallery__small--reverse' : 'gallery__small--default',
47
+ ]"
48
+ >
49
+ <div
50
+ v-for="img in mediaSmall"
51
+ :key="img.src + img.alt"
52
+ class="image image--small"
53
+ >
54
+ <atom-image
55
+ ><slot
56
+ name="image-small"
57
+ v-bind="{
58
+ height: 246,
59
+ src: img.src,
60
+ alt: img.alt,
61
+ }"
62
+ ></slot
63
+ ></atom-image>
64
+ </div>
65
+ <div
66
+ v-if="mediaSmall.length < 2"
67
+ class="body"
68
+ :class="bgColor === 'dark' ? 'body--dark' : ''"
69
+ >
70
+ <p>{{ body }}</p>
71
+ <atom-link
72
+ v-if="linkType === 'link'"
73
+ :link-type="
74
+ bgColor === 'dark'
75
+ ? 'regular_dark'
76
+ : bgColor === 'light'
77
+ ? 'regular_light'
78
+ : 'regular_light'
79
+ "
80
+ arrow
81
+ ><slot name="gallery-link"></slot
82
+ ></atom-link>
83
+ </div>
84
+ </div>
85
+ </div>
86
+ </div>
87
+ </template>
88
+
89
+ <script setup lang="ts">
90
+ import { computed } from "vue";
91
+ import AtomImage from "../../atoms/image/image.vue";
92
+ import AtomVideo from "../../atoms/video/video.vue";
93
+ import AtomLink from "../../atoms/link/link.vue";
94
+
95
+ interface Media {
96
+ src: string;
97
+ alt: string;
98
+ }
99
+
100
+ const BGCOLORS = {
101
+ white: "",
102
+ light: "gallery__wrapper--light",
103
+ dark: "gallery__wrapper--dark mirsaic--dark",
104
+ } as const;
105
+
106
+ type BgColor = keyof typeof BGCOLORS;
107
+
108
+ export type Props = {
109
+ mediaLarge: Media;
110
+ mediaType?: "image" | "video";
111
+ mediaSmall: Media[];
112
+ body?: string;
113
+ flipHorizontal?: boolean;
114
+ flipVertical?: boolean;
115
+ bgColor?: BgColor;
116
+ linkText?: string;
117
+ linkType?: string;
118
+ };
119
+
120
+ const props = withDefaults(defineProps<Props>(), {
121
+ mediaType: "image",
122
+ body: "",
123
+ flipHorizontal: false,
124
+ flipVertical: false,
125
+ bgColor: "white",
126
+ linkText: "",
127
+ linkType: "link",
128
+ });
129
+
130
+ const selectedBgColor = computed(() => BGCOLORS[props.bgColor]);
131
+ </script>
132
+
133
+ <style scoped lang="scss">
134
+ @use "../../../assets/scss/variables.scss" as *;
135
+ .gallery {
136
+ &__wrapper {
137
+ width: 100%;
138
+ padding: $padding-mobile;
139
+ margin: $extra-margin-mobile-bg;
140
+ background-color: $white;
141
+ @include md {
142
+ padding: $padding-desktop;
143
+ margin: $extra-margin-desktop-bg;
144
+ }
145
+
146
+ &--light {
147
+ background-color: $blue-100;
148
+ }
149
+
150
+ &--dark {
151
+ background-color: $blue-900;
152
+ color: $white;
153
+ }
154
+ }
155
+
156
+ &__content {
157
+ max-width: $max-width;
158
+ grid-template-columns: auto;
159
+ display: grid;
160
+
161
+ @include md {
162
+ margin: 0 auto;
163
+ grid-template-columns: auto auto;
164
+ grid-gap: 41px;
165
+ }
166
+
167
+ .image {
168
+ &--large {
169
+ width: 100%;
170
+ max-height: 530px;
171
+ height: 100%;
172
+ }
173
+ &--small {
174
+ width: 328px;
175
+ height: 246px;
176
+ }
177
+
178
+ :slotted(img) {
179
+ width: 100%;
180
+ height: 100%;
181
+ object-fit: cover;
182
+ }
183
+ }
184
+
185
+ &--reverse {
186
+ :nth-child(1) {
187
+ order: 2;
188
+ }
189
+ .body {
190
+ flex-direction: column-reverse;
191
+ margin-bottom: 30px;
192
+ @include md {
193
+ margin-bottom: 0;
194
+ }
195
+ }
196
+ }
197
+
198
+ &--default {
199
+ .body {
200
+ flex-direction: column;
201
+ margin-top: 30px;
202
+ @include md {
203
+ margin-top: 0;
204
+ }
205
+ }
206
+ }
207
+ }
208
+
209
+ &__large {
210
+ max-width: 100%;
211
+ max-height: 530px;
212
+
213
+ @include md {
214
+ margin: 0;
215
+ max-width: 617px;
216
+ height: 530px;
217
+ width: 100%;
218
+ }
219
+ }
220
+
221
+ &__small {
222
+ width: 100%;
223
+
224
+ @include md {
225
+ display: grid;
226
+ grid-template-rows: auto auto;
227
+ }
228
+
229
+ &--reverse {
230
+ .image {
231
+ display: none;
232
+ @include md {
233
+ display: block;
234
+ }
235
+ &--small {
236
+ order: 2;
237
+ }
238
+ .body {
239
+ flex-direction: column-reverse;
240
+ }
241
+ }
242
+
243
+ :nth-child(2) {
244
+ order: 1;
245
+ }
246
+ }
247
+
248
+ &--default {
249
+ .image {
250
+ display: none;
251
+ @include md {
252
+ display: block;
253
+ }
254
+ &--small {
255
+ order: 1;
256
+ }
257
+ }
258
+ :nth-child(2) {
259
+ order: 2;
260
+ }
261
+ .body {
262
+ flex-direction: column;
263
+ }
264
+ }
265
+
266
+ .body {
267
+ display: flex;
268
+ gap: 15px;
269
+ justify-content: center;
270
+ @include md {
271
+ width: 328px;
272
+ height: 284px;
273
+ }
274
+
275
+ p {
276
+ font-size: $font-size-lg;
277
+ line-height: $line-height-lg;
278
+ }
279
+
280
+ &--dark {
281
+ color: $white;
282
+ p {
283
+ color: $white;
284
+ }
285
+ }
286
+ }
287
+ }
288
+ }
289
+ </style>
@@ -0,0 +1,125 @@
1
+ <template>
2
+ <div class="logo-wall__wrapper">
3
+ <div class="logo-wall__content">
4
+ <div v-if="headline || body" class="logo-wall__text">
5
+ <h2 v-if="headline">{{ headline }}</h2>
6
+ <p v-if="body">{{ body }}</p>
7
+ </div>
8
+ <div class="logo-wall__logos">
9
+ <div
10
+ v-for="logo in logos"
11
+ :key="logo.src + logo.alt"
12
+ class="logo-wall__logo"
13
+ >
14
+ <atom-image
15
+ ><slot
16
+ name="logo-wall-logo"
17
+ v-bind="{
18
+ width: 130,
19
+ height: 130,
20
+ src: logo.src,
21
+ alt: logo.alt,
22
+ }"
23
+ ></slot
24
+ ></atom-image>
25
+ </div>
26
+ </div>
27
+ <div class="logo-wall__link">
28
+ <atom-link link-type="regular_light" :arrow="true"
29
+ ><slot name="logo-wall-link"></slot
30
+ ></atom-link>
31
+ </div>
32
+ </div>
33
+ </div>
34
+ </template>
35
+
36
+ <script setup lang="ts">
37
+ import AtomImage from "../../atoms/image/image.vue";
38
+ import AtomLink from "../../atoms/link/link.vue";
39
+
40
+ interface Logo {
41
+ src: string;
42
+ alt: string;
43
+ }
44
+
45
+ defineProps({
46
+ headline: {
47
+ type: String,
48
+ default: "",
49
+ },
50
+ body: {
51
+ type: String,
52
+ default: "",
53
+ },
54
+ logos: {
55
+ type: Array as () => Logo[],
56
+ required: true,
57
+ validator: (logos: Logo[]) => logos.length <= 5,
58
+ },
59
+ });
60
+ </script>
61
+
62
+ <style lang="scss" scoped>
63
+ @use "../../../assets/scss/variables.scss" as *;
64
+ .logo-wall {
65
+ &__wrapper {
66
+ width: 100%;
67
+ }
68
+
69
+ &__content {
70
+ display: flex;
71
+ gap: 30px;
72
+ flex-direction: column;
73
+ max-width: $max-width;
74
+ margin: 0 auto;
75
+ padding: $padding-mobile;
76
+ @include md {
77
+ padding: $padding-desktop;
78
+ }
79
+ }
80
+
81
+ &__text {
82
+ max-width: 658px;
83
+ display: flex;
84
+ flex-direction: column;
85
+ gap: 30px;
86
+ }
87
+
88
+ &__logos {
89
+ @include sm {
90
+ display: grid;
91
+ grid-template-columns: repeat(5, 1fr);
92
+ grid-column-gap: 60px;
93
+ }
94
+
95
+ @media screen and (max-width: 723px) {
96
+ display: flex;
97
+ flex-direction: row;
98
+ flex-wrap: wrap;
99
+ justify-content: center;
100
+ gap: 30px;
101
+ }
102
+ }
103
+
104
+ &__logo {
105
+ max-width: 100%;
106
+ height: auto;
107
+
108
+ :deep(.image__wrapper) {
109
+ display: flex;
110
+ align-items: center;
111
+ justify-content: center;
112
+ height: auto;
113
+ }
114
+
115
+ @include sm {
116
+ //height: 123px;
117
+ }
118
+ }
119
+
120
+ &__link {
121
+ margin: 0 auto;
122
+ padding-top: 30px;
123
+ }
124
+ }
125
+ </style>