@iamproperty/components 3.4.5 → 3.4.7

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 (203) hide show
  1. package/assets/css/components/accordion.css +1 -0
  2. package/assets/css/components/accordion.css.map +1 -0
  3. package/assets/css/components/alert.css +1 -0
  4. package/assets/css/components/alert.css.map +1 -0
  5. package/assets/css/components/applied-filters.css +1 -0
  6. package/assets/css/components/applied-filters.css.map +1 -0
  7. package/assets/css/components/buttons.css +1 -0
  8. package/assets/css/components/buttons.css.map +1 -0
  9. package/assets/css/components/card.css +1 -0
  10. package/assets/css/components/card.css.map +1 -0
  11. package/assets/css/components/carousel.css +1 -0
  12. package/assets/css/components/carousel.css.map +1 -0
  13. package/assets/css/components/charts.css +1 -0
  14. package/assets/css/components/charts.css.map +1 -0
  15. package/assets/css/components/container.css +1 -0
  16. package/assets/css/components/container.css.map +1 -0
  17. package/assets/css/components/dialog.css +1 -0
  18. package/assets/css/components/dialog.css.map +1 -0
  19. package/assets/css/components/forms.css +1 -0
  20. package/assets/css/components/forms.css.map +1 -0
  21. package/assets/css/components/header.css +1 -0
  22. package/assets/css/components/header.css.map +1 -0
  23. package/assets/css/components/lists.css +1 -0
  24. package/assets/css/components/lists.css.map +1 -0
  25. package/assets/css/components/nav.css +1 -0
  26. package/assets/css/components/nav.css.map +1 -0
  27. package/assets/css/components/pagination.css +1 -0
  28. package/assets/css/components/pagination.css.map +1 -0
  29. package/assets/css/components/panel.css +1 -0
  30. package/assets/css/components/panel.css.map +1 -0
  31. package/assets/css/components/property-searchbar.css +1 -0
  32. package/assets/css/components/property-searchbar.css.map +1 -0
  33. package/assets/css/components/snapshot.css +1 -0
  34. package/assets/css/components/snapshot.css.map +1 -0
  35. package/assets/css/components/stepper.css +1 -0
  36. package/assets/css/components/stepper.css.map +1 -0
  37. package/assets/css/components/table.css +1 -0
  38. package/assets/css/components/table.css.map +1 -0
  39. package/assets/css/components/tabs.css +1 -0
  40. package/assets/css/components/tabs.css.map +1 -0
  41. package/assets/css/components/testimonial.css +1 -0
  42. package/assets/css/components/testimonial.css.map +1 -0
  43. package/assets/css/components/timeline.css +1 -0
  44. package/assets/css/components/timeline.css.map +1 -0
  45. package/assets/css/components/tooltips.css +1 -0
  46. package/assets/css/components/tooltips.css.map +1 -0
  47. package/assets/css/core.min.css +1 -1
  48. package/assets/css/core.min.css.map +1 -1
  49. package/assets/css/style.min.css +1 -1
  50. package/assets/css/style.min.css.map +1 -1
  51. package/assets/fonts/qanelas-bold-webfont.woff +0 -0
  52. package/assets/fonts/qanelas-bold-webfont.woff2 +0 -0
  53. package/assets/js/bundle.js +68 -0
  54. package/assets/js/components/accordion/accordion.component.js +33 -0
  55. package/assets/js/components/accordion/accordion.component.min.js +14 -0
  56. package/assets/js/components/accordion/accordion.component.min.js.map +1 -0
  57. package/assets/js/components/applied-filters/applied-filters.component.js +26 -0
  58. package/assets/js/components/card/card.component.js +91 -0
  59. package/assets/js/components/card/card.component.min.js +21 -0
  60. package/assets/js/components/card/card.component.min.js.map +1 -0
  61. package/assets/js/components/filterlist/filterlist.component.js +49 -0
  62. package/assets/js/components/filterlist/filterlist.component.min.js +23 -0
  63. package/assets/js/components/filterlist/filterlist.component.min.js.map +1 -0
  64. package/assets/js/components/header/header.component.js +51 -0
  65. package/assets/js/components/header/header.component.min.js +30 -0
  66. package/assets/js/components/header/header.component.min.js.map +1 -0
  67. package/assets/js/components/pagination/pagination.component.js +34 -0
  68. package/assets/js/components/table/table.component.js +104 -0
  69. package/assets/js/components/table/table.component.min.js +24 -0
  70. package/assets/js/components/table/table.component.min.js.map +1 -0
  71. package/assets/js/components/tabs/tabs.component.js +34 -0
  72. package/assets/js/components/tabs/tabs.component.min.js +17 -0
  73. package/assets/js/components/tabs/tabs.component.min.js.map +1 -0
  74. package/assets/js/dynamic.js +74 -0
  75. package/assets/js/dynamic.min.js +5 -0
  76. package/assets/js/dynamic.min.js.map +1 -0
  77. package/assets/js/flat-components.js +79 -0
  78. package/assets/js/modules/accordion.js +11 -14
  79. package/assets/js/modules/applied-filters.js +100 -0
  80. package/assets/js/modules/data-layer.js +45 -0
  81. package/assets/js/modules/filterlist.js +32 -0
  82. package/assets/js/modules/helpers.js +80 -47
  83. package/assets/js/modules/pagination.js +33 -0
  84. package/assets/js/modules/table.js +507 -420
  85. package/assets/js/modules/tabs.js +97 -0
  86. package/assets/js/modules/youtubevideo.js +53 -61
  87. package/assets/js/scripts.bundle.js +111 -984
  88. package/assets/js/scripts.bundle.js.map +1 -1
  89. package/assets/js/scripts.bundle.min.js +3 -4
  90. package/assets/js/scripts.bundle.min.js.map +1 -1
  91. package/assets/js/tests/filterlist.spec.js +22 -0
  92. package/assets/js/tests/pagination.spec.js +15 -0
  93. package/assets/js/tests/table.spec.js +147 -0
  94. package/assets/sass/_components.scss +1 -2
  95. package/assets/sass/_corefiles.scss +5 -4
  96. package/assets/sass/_fonts.scss +4 -4
  97. package/assets/sass/_func.scss +1 -0
  98. package/assets/sass/_functions/functions.scss +6 -0
  99. package/assets/sass/_functions/mixins.scss +9 -9
  100. package/assets/sass/_functions/utilities.scss +16 -0
  101. package/assets/sass/_functions/variables.scss +128 -86
  102. package/assets/sass/_tests/colours.spec.scss +1 -1
  103. package/assets/sass/_tests/mixins.spec.scss +1 -1
  104. package/assets/sass/_tests/typography.spec.scss +2 -2
  105. package/assets/sass/components/accordion.scss +9 -6
  106. package/assets/sass/components/applied-filters.scss +65 -0
  107. package/assets/sass/components/card.scss +178 -227
  108. package/assets/sass/components/charts.scss +4 -0
  109. package/assets/sass/components/container.scss +13 -8
  110. package/assets/sass/components/dialog.scss +202 -0
  111. package/assets/sass/components/forms.scss +39 -5
  112. package/assets/sass/components/header.scss +34 -11
  113. package/assets/sass/components/lists.scss +15 -0
  114. package/assets/sass/components/nav.scss +5 -1
  115. package/assets/sass/components/pagination.scss +140 -0
  116. package/assets/sass/components/panel.scss +3 -4
  117. package/assets/sass/components/snapshot.scss +1 -1
  118. package/assets/sass/components/table.scss +419 -0
  119. package/assets/sass/components/tabs.scss +52 -36
  120. package/assets/sass/components/timeline.scss +2 -2
  121. package/assets/sass/foundations/icons.scss +1 -1
  122. package/assets/sass/{components → foundations}/links.scss +29 -2
  123. package/assets/sass/foundations/reboot.scss +21 -15
  124. package/assets/sass/foundations/root.scss +12 -5
  125. package/assets/sass/foundations/type.scss +90 -66
  126. package/assets/svg/illustrations/table.svg +165 -0
  127. package/assets/ts/README.md +12 -0
  128. package/assets/ts/bundle.ts +87 -0
  129. package/assets/ts/components/accordion/README.md +17 -0
  130. package/assets/ts/components/accordion/accordion.component.ts +43 -0
  131. package/assets/ts/components/applied-filters/README.md +5 -0
  132. package/assets/ts/components/applied-filters/applied-filters.component.ts +33 -0
  133. package/assets/ts/components/card/README.md +22 -0
  134. package/assets/ts/components/card/card.component.ts +117 -0
  135. package/assets/ts/components/filterlist/README.md +17 -0
  136. package/assets/ts/components/filterlist/filterlist.component.ts +60 -0
  137. package/assets/ts/components/header/README.md +26 -0
  138. package/assets/ts/components/header/header.component.ts +61 -0
  139. package/assets/ts/components/pagination/README.md +11 -0
  140. package/assets/ts/components/pagination/pagination.component.ts +45 -0
  141. package/assets/ts/components/table/README.md +23 -0
  142. package/assets/ts/components/table/table.component.ts +128 -0
  143. package/assets/ts/components/tabs/README.md +18 -0
  144. package/assets/ts/components/tabs/tabs.component.ts +41 -0
  145. package/assets/ts/dynamic.ts +98 -0
  146. package/assets/ts/flat-components.ts +100 -0
  147. package/assets/ts/html.d.ts +4 -0
  148. package/assets/ts/modules/accordion.ts +15 -21
  149. package/assets/ts/modules/applied-filters.ts +146 -0
  150. package/assets/ts/modules/data-layer.ts +58 -0
  151. package/assets/ts/modules/filterlist.ts +46 -0
  152. package/assets/ts/modules/helpers.ts +93 -55
  153. package/assets/ts/modules/pagination.ts +44 -0
  154. package/assets/ts/modules/table.ts +598 -433
  155. package/assets/ts/modules/tabs.ts +136 -0
  156. package/assets/ts/modules/youtubevideo.ts +58 -63
  157. package/assets/ts/tests/filterlist.spec.ts +29 -0
  158. package/assets/ts/tests/pagination.spec.ts +21 -0
  159. package/assets/ts/tests/table.spec.ts +191 -0
  160. package/dist/components.es.js +1359 -1356
  161. package/dist/components.umd.js +103 -54
  162. package/dist/style.css +1 -1
  163. package/package.json +20 -12
  164. package/src/components/Accordion/Accordion.spec.js +1 -1
  165. package/src/components/Accordion/Accordion.vue +7 -5
  166. package/src/components/Accordion/AccordionItem.vue +3 -6
  167. package/src/components/Accordion/README.md +0 -2
  168. package/src/components/AppliedFilters/AppliedFilters.vue +20 -0
  169. package/src/components/AppliedFilters/README.md +5 -0
  170. package/src/components/Card/Card.vue +11 -112
  171. package/src/components/Card/README.md +16 -18
  172. package/src/components/Carousel/Carousel.vue +49 -10
  173. package/src/components/Chart/Chart.vue +46 -4
  174. package/src/components/Filterlist/Filterlist.vue +20 -0
  175. package/src/components/Filterlist/README.md +17 -0
  176. package/src/components/Header/Header.spec.js +5 -4
  177. package/src/components/Header/Header.vue +14 -20
  178. package/src/components/Pagination/Pagination.vue +30 -0
  179. package/src/components/Pagination/README.md +11 -0
  180. package/src/components/Snapshot/Snapshot.vue +1 -1
  181. package/src/components/Table/README.md +29 -44
  182. package/src/components/Table/Table.spec.js +5 -37
  183. package/src/components/Table/Table.vue +16 -91
  184. package/src/components/Tabs/README.md +0 -2
  185. package/src/components/Tabs/Tab.vue +3 -2
  186. package/src/components/Tabs/Tabs.vue +8 -64
  187. package/src/foundations/YoutubeVideo/YoutubeVideo.vue +1 -1
  188. package/src/index.js +3 -2
  189. package/assets/fonts/qanelassoft-extrabold-webfont.woff +0 -0
  190. package/assets/fonts/qanelassoft-extrabold-webfont.woff2 +0 -0
  191. package/assets/js/main.js +0 -57
  192. package/assets/js/modules/modal.js +0 -69
  193. package/assets/sass/components/cardDeck.scss +0 -108
  194. package/assets/sass/components/modal.scss +0 -136
  195. package/assets/sass/components/tables.scss +0 -291
  196. package/assets/ts/main.ts +0 -68
  197. package/assets/ts/modules/modal.ts +0 -91
  198. package/src/components/CardDeck/CardDeck.spec.js +0 -99
  199. package/src/components/CardDeck/CardDeck.vue +0 -77
  200. package/src/components/CardDeck/README.md +0 -25
  201. package/src/components/Modal/Modal.spec.js +0 -22
  202. package/src/components/Modal/Modal.vue +0 -43
  203. package/src/components/Modal/README.md +0 -20
@@ -0,0 +1,419 @@
1
+ @use "../_func.scss" as *;
2
+
3
+ // #region Default table
4
+ table {
5
+ --border-width: 2px;
6
+ --inner-border-width: 2px;
7
+ width: 100%;
8
+ font-size: rem(16);
9
+ border: none;
10
+ margin-bottom: rem(32);
11
+ overflow: auto;
12
+ }
13
+
14
+ td,th {
15
+ padding: rem(12) rem(32) rem(12) 0;
16
+
17
+ font-weight: normal;
18
+ text-align: left;
19
+ vertical-align: top;
20
+ border: none;
21
+ font-size: rem(16);
22
+ line-height: rem(24);
23
+ color: var(--colour-body);
24
+
25
+ @include media-breakpoint-up(sm) {
26
+ min-width: #{$td-mw};
27
+ }
28
+
29
+ &:last-child {
30
+ padding-right: 0;
31
+ }
32
+ }
33
+
34
+ th {
35
+ font-weight: bold;
36
+ @include var(color,--colour-heading);
37
+ }
38
+
39
+ thead {
40
+
41
+ th {
42
+ font-weight: bold;
43
+ vertical-align: bottom;
44
+
45
+ @include media-breakpoint-up(sm) {
46
+ white-space: nowrap;
47
+ min-width: #{$td-mw};
48
+ }
49
+ }
50
+ }
51
+
52
+
53
+ tbody tr {
54
+
55
+
56
+ &:is(:hover,:focus,.hover) {
57
+
58
+ td {
59
+ --bg-colour-rgb: 238,238,238;
60
+ background: #EEEEEE;
61
+ }
62
+ }
63
+
64
+ td {
65
+
66
+ border-top: var(--border-width) solid currentColor;
67
+ @include var(border-color,--colour-border);
68
+ }
69
+
70
+ &:first-child td{
71
+ border-top: var(--border-width) solid currentColor;
72
+ @include var(border-color,--colour-primary);
73
+ }
74
+
75
+ &:last-child td{
76
+ border-bottom: var(--border-width) solid currentColor;
77
+ @include var(border-color,--colour-border);
78
+ }
79
+ }
80
+
81
+ .border-0 > table,
82
+ table.border-0 {
83
+
84
+ --border-width: 0px;
85
+ --inner-border-width: 0px;
86
+ }
87
+ // #endregion
88
+
89
+ // #region Table wrapper - Add via JS if needed, provides a safe space to scroll
90
+ :is(iam-table, .iam-table) {
91
+
92
+ display: block;
93
+ padding: rem(32);
94
+ box-shadow: 0px 6px 12px rgba(0,0,0,0.11);
95
+ border-radius: rem(8);
96
+ margin-bottom: rem(32);
97
+
98
+ table {
99
+ margin-bottom: 0;
100
+ }
101
+ }
102
+
103
+ .table__wrapper {
104
+ display: block;
105
+ width: 100%;
106
+ overflow-x: auto;
107
+ -webkit-overflow-scrolling: touch;
108
+ -ms-overflow-style: -ms-autohiding-scrollbar; // See https://github.com/twbs/bootstrap/pull/10057
109
+ }
110
+ // #endregion
111
+
112
+ // #region Tables are only stacked on mobile
113
+ *:has(> iam-table){
114
+ container-type: inline-size;
115
+ }
116
+ *:has(> .iam-table){
117
+ container-type: inline-size;
118
+ }
119
+ @container (width < 23.4375em) {
120
+
121
+ .table__wrapper:not(.table--fullwidth) {
122
+
123
+ overflow: hidden;
124
+ max-height: none!important;
125
+
126
+ }
127
+ :is(iam-table, .iam-table):not(.table--fullwidth) {
128
+
129
+ table {
130
+
131
+ thead {
132
+ display: none;
133
+ }
134
+
135
+ tbody {
136
+ display: block;
137
+
138
+ tr td:first-child {
139
+ padding-top:0;
140
+ }
141
+ }
142
+
143
+ tr {
144
+ display: block;
145
+ position: relative;
146
+ border: none;
147
+
148
+ & + tr {
149
+ margin-top: rem(32);
150
+ }
151
+
152
+ &:is(:hover,:focus,.hover) {
153
+
154
+ td {
155
+ background: transparent;
156
+ }
157
+ }
158
+
159
+ &:last-child td:not(:last-child) {
160
+ border-bottom:none;
161
+ }
162
+
163
+ &:first-child td:first-child {
164
+ border-top: none;
165
+ border-color: var(--colour-border);
166
+ }
167
+ &:first-child td {
168
+ border-color: var(--colour-border);
169
+ }
170
+ }
171
+
172
+ td,
173
+ th {
174
+ display: block;
175
+ @include var(border-color,--colour-border);
176
+
177
+ &:nth-child(1){
178
+
179
+ border-top: none;
180
+ }
181
+
182
+ &[data-label]:before {
183
+ content: attr(data-label);
184
+ color: var(--colour-heading);
185
+ padding: 0;
186
+ margin-bottom: 0;
187
+ display: block;
188
+ font-weight: bold;
189
+ margin: 0;
190
+ }
191
+ }
192
+
193
+ tbody tr:first-child td:not(:first-child) {
194
+ border-top: var(--border-width) solid currentColor!important;
195
+ border-color: var(--colour-border)!important;
196
+ }
197
+
198
+ tbody tr:has(td:nth-child(4)) td:first-child {
199
+
200
+ position: relative;
201
+
202
+ button {
203
+ display: block!important;
204
+ top: 0;
205
+ left: 0;
206
+ height: 100%;
207
+ width: 100%;
208
+ background: transparent;
209
+ border: none;
210
+ position: absolute;
211
+ overflow: hidden;
212
+ text-indent: -300%;
213
+
214
+ &:after {
215
+ font-family: "Font Awesome 6 Pro";
216
+ content: "\f055";
217
+ position: absolute;
218
+ top: 1px;
219
+ right: 1px;
220
+ font-size: rem(28);
221
+ line-height: rem(28);
222
+ font-weight: 300;
223
+ color: var(--colour-primary);
224
+ text-indent: 0;
225
+ }
226
+ }
227
+ }
228
+
229
+ tbody tr:has(td:nth-child(4))[data-view="full"] td:first-child {
230
+ button:after {
231
+ content: "\f056";
232
+ font-weight: 900;
233
+ }
234
+ }
235
+ }
236
+ }
237
+ body:not(.js-enabled) :is(iam-table, .iam-table):not(.table--fullwidth) tbody tr:not(:hover):not(:focus-within),
238
+ :is(iam-table, .iam-table):not(.table--fullwidth) tbody tr:not([data-view="full"]) {
239
+
240
+ td:not(:first-child):not(:nth-child(2)):not(:nth-child(3)){
241
+ display: none;
242
+ }
243
+ td:first-child {
244
+
245
+ button:after {
246
+ content: "\f055";
247
+ }
248
+ }
249
+ }
250
+
251
+ .table--cta:not(.table--fullwidth) tr td:last-child {
252
+ display: block!important;
253
+ }
254
+
255
+ }
256
+ // #endregion
257
+
258
+ // #region CTA column
259
+ @include media-breakpoint-up(sm) {
260
+
261
+ :is(iam-table) {
262
+
263
+ --cta-width: 8rem;
264
+ }
265
+
266
+ :not(iam-table).table--cta {
267
+
268
+ position: relative;
269
+ margin-right: calc(var(--cta-width) - 1.5rem);
270
+
271
+ &::after {
272
+ content: "";
273
+ display: block;
274
+ position: absolute;
275
+ bottom: 0;
276
+ left: 0;
277
+ width: calc(100% + calc(var(--cta-width) - 1.5rem));
278
+ border-bottom: 2px solid currentColor;
279
+ @include var(border-color,--colour-border);
280
+ z-index: 99;
281
+ }
282
+ }
283
+
284
+ .table--cta .table__wrapper {
285
+ overflow-y: hidden;
286
+ margin-bottom: 0;
287
+ }
288
+
289
+ .table--cta {
290
+
291
+ tr > *:last-child {
292
+
293
+ position: absolute;
294
+ left: 100%;
295
+ top: auto;
296
+ z-index: 3;
297
+ background: transparent;
298
+ width: var(--cta-width);
299
+ padding-left: rem(40);
300
+ margin-left: rem(-40);
301
+ min-width: fit-content;
302
+ min-height: var(--row-height);
303
+ text-align: right;
304
+ background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 1.25rem);
305
+ background: linear-gradient(90deg, rgba(var(--bg-colour-rgb,255,255,255),0) 0%, rgba(var(--bg-colour-rgb,255,255,255),1) 1.25rem);
306
+
307
+ a {
308
+ white-space: nowrap;
309
+ }
310
+ }
311
+
312
+ tbody tr > *:last-child {
313
+ margin-top: -1px;
314
+ }
315
+ tbody tr {
316
+
317
+ &:last-child td{
318
+ border-bottom: none;
319
+ }
320
+ }
321
+ }
322
+ }
323
+ // #endregion
324
+
325
+ // #region Max height tables
326
+ .table__wrapper:is(.table--mh-small,.table--mh-medium,.table--mh-large) {
327
+ max-height: var(--table-mh,#{rem(200)});
328
+ overflow: auto;
329
+ position: relative;
330
+
331
+ &::before {
332
+ content: "";
333
+ top: calc(100% - 1.2rem);
334
+ bottom: 2px;
335
+ left: 0;
336
+ right: 0;
337
+ height: 1.2rem;
338
+ position: sticky;
339
+ display: block;
340
+ background: linear-gradient(180deg, rgba(var(--bg-colour-rgb, 255, 255, 255), 0) 0%, rgba(var(--bg-colour-rgb, 255, 255, 255), 1) 100%);
341
+ border-bottom: 2px solid var(--colour-border);
342
+ z-index: 2;
343
+ margin-bottom: -1.2rem;
344
+ }
345
+ }
346
+
347
+ .table__wrapper.table--mh-small {
348
+ --table-mh: #{$table-mh-sm};
349
+ }
350
+ .table__wrapper.table--mh-medium {
351
+ --table-mh: #{$table-mh-md};
352
+ }
353
+ .table__wrapper.table--mh-large {
354
+ --table-mh: #{$table-mh-lg};
355
+ }
356
+
357
+ // If table CTA class is set then undo max-height
358
+ .table--cta > .table__wrapper:is(.table--mh-small,.table--mh-medium,.table--mh-large) {
359
+ max-height: none;
360
+ position: static;
361
+
362
+ &::before {
363
+ display: none;
364
+ }
365
+ }
366
+
367
+ iam-table:is(.table--mh-small,.table--mh-medium,.table--mh-large):not(.table--cta) {
368
+
369
+ position: relative;
370
+
371
+ thead {
372
+ position: sticky;
373
+ top: 0;
374
+ left: 0;
375
+ z-index: 1;
376
+ background-color: var(--colour-white);;
377
+
378
+ &:before {
379
+ content: "";
380
+ position: absolute;
381
+ bottom: 0;
382
+ left: 0;
383
+ width: 100%;
384
+ height: 2px;
385
+ background: var(--colour-primary);
386
+ }
387
+ }
388
+ tbody {
389
+ position: relative;
390
+
391
+ tr:first-child td {
392
+ border-top: 0;
393
+ }
394
+ tr:last-child td {
395
+ border-bottom: 0;
396
+ }
397
+
398
+ }
399
+ }
400
+ //#endregion
401
+
402
+ // filters
403
+ .table--filtered tbody tr:not(.filtered--show) {
404
+ display: none!important;
405
+ }
406
+
407
+ table:not(.table--filtered) tbody tr:nth-child(15) ~ tr {
408
+ display: none;
409
+ }
410
+
411
+ // Statuses
412
+ /* Will be used in the future
413
+ [data-content="Incomplete"] {
414
+ background-color: red;
415
+ }
416
+ [data-content="Verified"] {
417
+ background-color: green;
418
+ }
419
+ */
@@ -1,16 +1,9 @@
1
1
  @use "../_func" as *;
2
2
 
3
- .tabs__container {
3
+ .tabs {
4
4
 
5
5
  position: relative;
6
6
 
7
- .tab__input {
8
- position: absolute;
9
- top: 0;
10
- left: 0;
11
- opacity: 0;
12
- }
13
-
14
7
  > .tabs__links {
15
8
  margin-bottom: 1.5rem;
16
9
  overflow: hidden;
@@ -24,6 +17,7 @@
24
17
  margin: 0 0 0.5rem 0;
25
18
  float: left;
26
19
  clear: both;
20
+ padding: 0;
27
21
 
28
22
  @include media-breakpoint-up(sm) {
29
23
  clear: none;
@@ -37,51 +31,73 @@
37
31
  }
38
32
 
39
33
  &:hover:before,
40
- &:focus:before {
34
+ &:focus:before,
35
+ &.focus:before {
41
36
  width: 100%;
42
37
  }
43
38
  }
44
39
  }
45
40
 
46
- .tab {
47
- display: none;
48
- }
49
-
50
- input:focus-visible ~ .tabs__links {
51
- outline: blue outset 1px;
52
- }
53
-
54
- @for $i from 1 through 10 {
55
- input:checked:nth-child(#{$i}) ~ .tabs__links .link:not(.text-decoration-none):not(.btn):nth-child(#{$i}) {
41
+ .tabs__links .link:not(.text-decoration-none):not(.btn)[aria-pressed="true"] {
56
42
 
57
- --is-current: 1;
58
- --panel-tab-colour: white;
59
- --panel-tab-border: var(--colour-secondary)
60
- }
61
- input:checked:nth-child(#{$i}) ~ .tabs > .tab:nth-child(#{$i}){
62
- display: block;
63
- display: contents;
64
- }
43
+ --is-current: 1;
44
+ --panel-tab-colour: white;
45
+ --panel-tab-border: var(--colour-secondary)
65
46
  }
66
47
  }
67
48
 
68
49
  // #region admin panel
69
- .admin-panel > .tabs__container:first-child {
50
+ .admin-panel .tabs__links,
51
+ :host(.admin-panel) .tabs__links {
52
+
53
+ margin-top: -3px!important;
54
+ margin-left: calc(var(--panel-gutter) * -1);
55
+ margin-right: calc(var(--panel-gutter) * -1);
56
+ display: flex;
57
+ flex-direction: column;
58
+ background-color: var(--body-bg);
59
+ border-bottom: 2px solid var(--colour-border-light);
60
+ margin-bottom: var(--panel-gutter);
61
+
62
+ @include media-breakpoint-up(sm) {
63
+
64
+ flex-direction: row;
65
+ border-top: 1px solid var(--colour-border-light);
66
+ }
70
67
 
71
- display: contents;
68
+ .link:not(.text-decoration-none):not(.btn) {
69
+ padding: var(--panel-gutter);
70
+ margin: 0;
71
+ width: 100%;
72
+ background: var(--panel-tab-colour);
73
+ border-top: 1px solid var(--colour-border-light);
74
+ border-left: 3px solid var(--panel-tab-border, #fafafa);
75
+ text-align: left;
76
+
77
+ &:before {
78
+ display: none;
79
+ }
72
80
 
73
- > .tabs {
74
- display: contents;
75
- }
81
+ @include media-breakpoint-up(sm) {
76
82
 
77
- > .tabs__links {
83
+ margin-right: 0!important;
78
84
 
79
- padding-bottom: 0;
85
+ &:first-child{
86
+ border-left: none!important;
87
+ }
80
88
 
81
- .link:not(.text-decoration-none):not(.btn) {
89
+ &:not(:first-child){
82
90
 
83
- margin-bottom: 0;
91
+ border-left: 1px solid var(--colour-border-light)!important;
92
+ }
93
+
94
+ border-top: 3px solid var(--panel-tab-border, #fafafa);
84
95
  }
85
96
  }
86
97
  }
98
+
99
+ :host(.admin-panel) {
100
+
101
+ display: block;
102
+ }
87
103
  // #endregion
@@ -60,12 +60,12 @@
60
60
  }
61
61
 
62
62
  > * {
63
- max-width: rem(math.div(1320,2) - 96);
63
+ max-width: rem(math.div(1112,2) - 96);
64
64
  order: 1;
65
65
  }
66
66
 
67
67
  > img {
68
- max-width: min(100%, #{rem(math.div(1320,2) - 96)});
68
+ max-width: min(100%, #{rem(math.div(1112,2) - 96)});
69
69
  margin-bottom: 2rem;
70
70
  }
71
71
 
@@ -4,7 +4,7 @@
4
4
  fill: currentColor;
5
5
  stroke: currentColor;
6
6
  stroke-width: 0;
7
- @include var(color,--colour-brand);
7
+ @include var(color,--colour-primary);
8
8
  width: rem(64);
9
9
  height: rem(64);
10
10
  display: inline-block;
@@ -8,6 +8,8 @@ a,
8
8
  margin-bottom: rem(16);
9
9
  position: relative;
10
10
  text-decoration: none;
11
+ background: none;
12
+ border: none;
11
13
 
12
14
  &:not(.text-decoration-none):not(.btn):before {
13
15
  content: '';
@@ -30,8 +32,7 @@ a,
30
32
  width: 0%;
31
33
  }
32
34
 
33
- &:hover,
34
- &:focus,
35
+ &:is(:hover, :focus, .focus),
35
36
  .card:hover &,
36
37
  .card:focus & {
37
38
  @include var (color, --colour-hover);
@@ -95,4 +96,30 @@ a,
95
96
  margin-right: 0.2em;
96
97
  }
97
98
  }
99
+ }
100
+
101
+ // Support card component
102
+ :is(a,button,label):has(.card, iam-card){
103
+ &:before {
104
+ display: none;
105
+ }
106
+ border: none;
107
+ background: none;
108
+ padding:0;
109
+ display: flex;
110
+ margin: 0 0 rem(24) 0;
111
+ outline: none!important;
112
+
113
+ &:not(.d-inline-block){
114
+
115
+ width: 100%;
116
+ }
117
+
118
+ iam-card {
119
+ width: 100%;
120
+ }
121
+ }
122
+
123
+ .col > :is(a,button):has(.card, iam-card):first-child:last-child{
124
+ min-height: calc(100% - rem(24));
98
125
  }
@@ -8,9 +8,8 @@ html {
8
8
  -webkit-font-smoothing: antialiased; // Fix for Safari/iOS
9
9
  height: 100%;
10
10
  width: 100%;
11
- overflow: hidden;
12
- overflow-y: scroll;
13
11
  overflow-x: hidden;
12
+ overflow-y: scroll;
14
13
  font-size: vw($device-xs-width);
15
14
  scroll-padding-top: rem(100);
16
15
 
@@ -22,7 +21,7 @@ html {
22
21
  }
23
22
 
24
23
  @if $mobileOnly != "true" {
25
- @media (min-width: #{em(1440)}) {
24
+ @media (min-width: #{em(1280)}) {
26
25
  font-size: 100%;
27
26
  }
28
27
 
@@ -45,25 +44,32 @@ html {
45
44
 
46
45
  body {
47
46
 
48
- font-family: 'qanelasmedium', arial, sans-serif;
47
+ @include var(font-family,--font-body);
49
48
  @include var(color,--colour-body);
50
49
  width: 100%;
51
- line-height: 1.5;
52
- height: 100%;
53
- //overflow-y: scroll;
54
- //overflow-x: hidden;
50
+ line-height: 1.2;
51
+ min-height: 100%;
52
+
55
53
  }
56
54
 
57
- @media (hover: none) {
58
- body {
59
- height: 100%;
60
- overflow-y: scroll;
61
- overflow-x: hidden;
62
- }
55
+ // #region scrollbars
56
+ div::-webkit-scrollbar {
57
+ width: 8px;
58
+ height: 8px;
59
+ }
60
+
61
+ div::-webkit-scrollbar-track {
62
+ background-color: #f1f1f1;
63
+ border-radius: 2px;
63
64
  }
65
+
66
+ div::-webkit-scrollbar-thumb {
67
+ background-color: #c1c1c1;
68
+ border-radius: 2px;
69
+ }
70
+ //#endregion
64
71
 
65
72
  #app {
66
- min-height: 100%;
67
73
  }
68
74
 
69
75
  body > footer,