@uh-design-system/component-library 0.5.2 → 0.5.3

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 (146) hide show
  1. package/dist/cjs/component-library.cjs.js +2 -2
  2. package/dist/cjs/{controlUtils-041de0fd.js → controlUtils-8bf55ef0.js} +1 -1
  3. package/dist/cjs/{ds-accordion_3.cjs.entry.js → ds-accordion_5.cjs.entry.js} +115 -20
  4. package/dist/cjs/ds-checkbox-group.cjs.entry.js +37 -27
  5. package/dist/cjs/ds-checkbox.cjs.entry.js +28 -25
  6. package/dist/cjs/ds-input-validity.cjs.entry.js +4 -4
  7. package/dist/cjs/ds-link-with-arrow.cjs.entry.js +3 -3
  8. package/dist/cjs/ds-link.cjs.entry.js +3 -3
  9. package/dist/cjs/ds-radio-button-group.cjs.entry.js +111 -0
  10. package/dist/cjs/ds-radio-button.cjs.entry.js +150 -0
  11. package/dist/cjs/ds-text-input.cjs.entry.js +8 -7
  12. package/dist/cjs/{index-bf84b124.js → index-947af833.js} +36 -4
  13. package/dist/cjs/index.cjs.js +2 -2
  14. package/dist/cjs/loader.cjs.js +2 -2
  15. package/dist/cjs/{store-9bd20f3c.js → store-e8e87298.js} +1 -1
  16. package/dist/collection/collection-manifest.json +4 -1
  17. package/dist/collection/components/01-base-components/ds-accordion/ds-accordion.css +12 -12
  18. package/dist/collection/components/01-base-components/ds-accordion/ds-accordion.js +11 -13
  19. package/dist/collection/components/01-base-components/ds-button/ds-button.css +98 -87
  20. package/dist/collection/components/01-base-components/ds-button/ds-button.js +89 -4
  21. package/dist/collection/components/01-base-components/ds-button/stories/ds-button.examples.stories.js +66 -0
  22. package/dist/collection/components/01-base-components/ds-button/stories/ds-button.stories.js +3 -0
  23. package/dist/collection/components/01-base-components/ds-checkbox/ds-checkbox.css +28 -21
  24. package/dist/collection/components/01-base-components/ds-checkbox/ds-checkbox.js +26 -45
  25. package/dist/collection/components/01-base-components/ds-checkbox-group/ds-checkbox-group.css +1 -1
  26. package/dist/collection/components/01-base-components/ds-checkbox-group/ds-checkbox-group.js +52 -26
  27. package/dist/collection/components/01-base-components/ds-checkbox-group/stories/ds-checkbox-group.features.stories.js +74 -18
  28. package/dist/collection/components/01-base-components/ds-icon/ds-icon.js +1 -1
  29. package/dist/collection/components/01-base-components/ds-input-validity/ds-input-validity.css +2 -2
  30. package/dist/collection/components/01-base-components/ds-input-validity/ds-input-validity.js +1 -1
  31. package/dist/collection/components/01-base-components/ds-link/ds-link.css +12 -12
  32. package/dist/collection/components/01-base-components/ds-link/ds-link.js +1 -1
  33. package/dist/collection/components/01-base-components/ds-link-with-arrow/ds-link-with-arrow.css +10 -10
  34. package/dist/collection/components/01-base-components/ds-link-with-arrow/ds-link-with-arrow.js +1 -1
  35. package/dist/collection/components/01-base-components/ds-radio-button/ds-radio-button.css +116 -0
  36. package/dist/collection/components/01-base-components/ds-radio-button/ds-radio-button.js +468 -0
  37. package/dist/collection/components/01-base-components/ds-radio-button/stories/ds-radio-button.features.stories.js +70 -0
  38. package/dist/collection/components/01-base-components/ds-radio-button/stories/ds-radio-button.stories.js +36 -0
  39. package/dist/collection/components/01-base-components/ds-radio-button-group/ds-radio-button-group.css +31 -0
  40. package/dist/collection/components/01-base-components/ds-radio-button-group/ds-radio-button-group.js +287 -0
  41. package/dist/collection/components/01-base-components/ds-radio-button-group/stories/ds-radio-button-group.examples.stories.js +51 -0
  42. package/dist/collection/components/01-base-components/ds-radio-button-group/stories/ds-radio-button-group.features.stories.js +58 -0
  43. package/dist/collection/components/01-base-components/ds-radio-button-group/stories/ds-radio-button-group.stories.js +59 -0
  44. package/dist/collection/components/01-base-components/ds-spinner/ds-spinner.css +309 -0
  45. package/dist/collection/components/01-base-components/ds-spinner/ds-spinner.js +221 -0
  46. package/dist/collection/components/01-base-components/ds-spinner/stories/ds-spinner.examples.stories.js +122 -0
  47. package/dist/collection/components/01-base-components/ds-spinner/stories/ds-spinner.features.stories.js +107 -0
  48. package/dist/collection/components/01-base-components/ds-spinner/stories/ds-spinner.stories.js +59 -0
  49. package/dist/collection/components/01-base-components/ds-text-input/ds-text-input.css +38 -38
  50. package/dist/collection/components/01-base-components/ds-text-input/ds-text-input.js +4 -3
  51. package/dist/collection/components/01-base-components/ds-visually-hidden/ds-visually-hidden.js +1 -1
  52. package/dist/collection/utils/button/buttonUtils.js +14 -0
  53. package/dist/collection/utils/colours/colourTypes.js +3 -3
  54. package/dist/collection/utils/colours/colourUtils.js +5 -3
  55. package/dist/collection/utils/controls/controlUtils.js +1 -1
  56. package/dist/collection/utils/spinner/spinnerUtils.js +20 -0
  57. package/dist/collection/utils/tests/testUtils.js +1 -0
  58. package/dist/collection/utils/typography/typographyUtils.js +3 -3
  59. package/dist/component-library/component-library.css +1 -1
  60. package/dist/component-library/component-library.esm.js +1 -1
  61. package/dist/component-library/controlUtils-c2ba44bd.js +1 -0
  62. package/dist/component-library/ds-accordion_5.entry.js +1 -0
  63. package/dist/component-library/ds-checkbox-group.entry.js +1 -1
  64. package/dist/component-library/ds-checkbox.entry.js +1 -1
  65. package/dist/component-library/ds-input-validity.entry.js +1 -1
  66. package/dist/component-library/ds-link-with-arrow.entry.js +1 -1
  67. package/dist/component-library/ds-link.entry.js +1 -1
  68. package/dist/component-library/ds-radio-button-group.entry.js +1 -0
  69. package/dist/component-library/ds-radio-button.entry.js +1 -0
  70. package/dist/component-library/ds-text-input.entry.js +1 -1
  71. package/dist/component-library/index-84fd0ee9.js +2 -0
  72. package/dist/component-library/index.esm.js +1 -1
  73. package/dist/component-library/{store-b8d17c10.js → store-73a56075.js} +1 -1
  74. package/dist/components/controlUtils.js +1 -1
  75. package/dist/components/ds-accordion.js +28 -18
  76. package/dist/components/ds-button2.js +48 -7
  77. package/dist/components/ds-checkbox-group.js +38 -27
  78. package/dist/components/ds-checkbox2.js +28 -24
  79. package/dist/components/ds-icon2.js +1 -1
  80. package/dist/components/ds-input-validity2.js +2 -2
  81. package/dist/components/ds-link-with-arrow.js +2 -2
  82. package/dist/components/ds-link.js +2 -2
  83. package/dist/components/ds-radio-button-group.d.ts +11 -0
  84. package/dist/components/ds-radio-button-group.js +147 -0
  85. package/dist/components/ds-radio-button.d.ts +11 -0
  86. package/dist/components/ds-radio-button.js +196 -0
  87. package/dist/components/ds-spinner.d.ts +11 -0
  88. package/dist/components/ds-spinner.js +6 -0
  89. package/dist/components/ds-spinner2.js +90 -0
  90. package/dist/components/ds-text-input.js +17 -10
  91. package/dist/components/ds-visually-hidden2.js +1 -1
  92. package/dist/components/index2.js +36 -5
  93. package/dist/esm/component-library.js +3 -3
  94. package/dist/esm/controlUtils-c2ba44bd.js +4 -0
  95. package/dist/esm/{ds-accordion_3.entry.js → ds-accordion_5.entry.js} +114 -21
  96. package/dist/esm/ds-checkbox-group.entry.js +37 -27
  97. package/dist/esm/ds-checkbox.entry.js +28 -25
  98. package/dist/esm/ds-input-validity.entry.js +4 -4
  99. package/dist/esm/ds-link-with-arrow.entry.js +3 -3
  100. package/dist/esm/ds-link.entry.js +3 -3
  101. package/dist/esm/ds-radio-button-group.entry.js +107 -0
  102. package/dist/esm/ds-radio-button.entry.js +146 -0
  103. package/dist/esm/ds-text-input.entry.js +8 -7
  104. package/dist/esm/{index-434995e1.js → index-84fd0ee9.js} +36 -5
  105. package/dist/esm/index.js +2 -2
  106. package/dist/esm/loader.js +3 -3
  107. package/dist/esm/{store-b8d17c10.js → store-73a56075.js} +1 -1
  108. package/dist/styles/helpers.css +7 -0
  109. package/dist/styles/helpers.css.map +1 -0
  110. package/dist/styles/mixins/_breakpoints.scss +14 -0
  111. package/dist/styles/mixins/_focus.scss +28 -0
  112. package/dist/styles/mixins/_wrapper.scss +5 -0
  113. package/dist/styles/mixins/imports-default/_imports.scss +2 -0
  114. package/dist/styles/mixins/tokens/_breakpoints.scss +13 -0
  115. package/dist/styles/mixins/tokens/_semantic-colours.scss +75 -0
  116. package/dist/styles/mixins.scss +10 -0
  117. package/dist/styles/variables.css +168 -0
  118. package/dist/styles/variables.css.map +1 -0
  119. package/dist/types/components/01-base-components/ds-button/ds-button.d.ts +5 -0
  120. package/dist/types/components/01-base-components/ds-button/stories/ds-button.examples.stories.d.ts +1 -0
  121. package/dist/types/components/01-base-components/ds-checkbox/ds-checkbox.d.ts +6 -10
  122. package/dist/types/components/01-base-components/ds-checkbox-group/ds-checkbox-group.d.ts +5 -4
  123. package/dist/types/components/01-base-components/ds-radio-button/ds-radio-button.d.ts +44 -0
  124. package/dist/types/components/01-base-components/ds-radio-button/stories/ds-radio-button.features.stories.d.ts +15 -0
  125. package/dist/types/components/01-base-components/ds-radio-button/stories/ds-radio-button.stories.d.ts +7 -0
  126. package/dist/types/components/01-base-components/ds-radio-button-group/ds-radio-button-group.d.ts +24 -0
  127. package/dist/types/components/01-base-components/ds-radio-button-group/stories/ds-radio-button-group.examples.stories.d.ts +6 -0
  128. package/dist/types/components/01-base-components/ds-radio-button-group/stories/ds-radio-button-group.features.stories.d.ts +10 -0
  129. package/dist/types/components/01-base-components/ds-radio-button-group/stories/ds-radio-button-group.stories.d.ts +7 -0
  130. package/dist/types/components/01-base-components/ds-spinner/ds-spinner.d.ts +17 -0
  131. package/dist/types/components/01-base-components/ds-spinner/stories/ds-spinner.examples.stories.d.ts +7 -0
  132. package/dist/types/components/01-base-components/ds-spinner/stories/ds-spinner.features.stories.d.ts +7 -0
  133. package/dist/types/components/01-base-components/ds-spinner/stories/ds-spinner.stories.d.ts +7 -0
  134. package/dist/types/components.d.ts +133 -18
  135. package/dist/types/utils/button/buttonUtils.d.ts +1 -0
  136. package/dist/types/utils/colours/colourTypes.d.ts +3 -3
  137. package/dist/types/utils/spinner/spinnerUtils.d.ts +1 -0
  138. package/dist/types/utils/tests/testUtils.d.ts +1 -0
  139. package/package.json +15 -15
  140. package/dist/cjs/ds-visually-hidden.cjs.entry.js +0 -20
  141. package/dist/component-library/controlUtils-9ca4087b.js +0 -1
  142. package/dist/component-library/ds-accordion_3.entry.js +0 -1
  143. package/dist/component-library/ds-visually-hidden.entry.js +0 -1
  144. package/dist/component-library/index-434995e1.js +0 -2
  145. package/dist/esm/controlUtils-9ca4087b.js +0 -4
  146. package/dist/esm/ds-visually-hidden.entry.js +0 -16
@@ -5,11 +5,9 @@
5
5
  * It contains typing information for all components that exist in this project.
6
6
  */
7
7
  import { HTMLStencilElement, JSXBase } from "./stencil-public-runtime";
8
- import { DsCheckboxInputEvent } from "./components/01-base-components/ds-checkbox/ds-checkbox";
9
8
  import { DsCheckboxGroupChangeEvent, DsCheckboxGroupIndeterminateChildChangeEvent } from "./components/01-base-components/ds-checkbox-group/ds-checkbox-group";
10
9
  import { DsTextInputType } from "./components/01-base-components/ds-text-input/utils";
11
10
  import { DsTextInputClearEvent } from "./components/01-base-components/ds-text-input/ds-text-input";
12
- export { DsCheckboxInputEvent } from "./components/01-base-components/ds-checkbox/ds-checkbox";
13
11
  export { DsCheckboxGroupChangeEvent, DsCheckboxGroupIndeterminateChildChangeEvent } from "./components/01-base-components/ds-checkbox-group/ds-checkbox-group";
14
12
  export { DsTextInputType } from "./components/01-base-components/ds-text-input/utils";
15
13
  export { DsTextInputClearEvent } from "./components/01-base-components/ds-text-input/ds-text-input";
@@ -32,8 +30,11 @@ export namespace Components {
32
30
  "fullWidth": boolean;
33
31
  "icon": string;
34
32
  "iconPosition": 'start' | 'end';
33
+ "isLoading": boolean;
35
34
  "size": 'small' | 'medium';
35
+ "spinnerHiddenText": string;
36
36
  "type": 'button' | 'submit' | 'reset';
37
+ "useSpinner": boolean;
37
38
  /**
38
39
  * Button text content. Uses a text prop instead of `<slot />` to avoid triggering another render to set correct CSS classes just after initial load.
39
40
  * @example <ds-button value="button"></ds-button> // Do this <ds-button>button</ds-button> // Instead of this
@@ -108,6 +109,40 @@ export namespace Components {
108
109
  "target"?: LinkTarget;
109
110
  "text"?: string;
110
111
  }
112
+ interface DsRadioButton {
113
+ "assistiveText"?: string;
114
+ "checked": boolean;
115
+ "disabled": boolean;
116
+ "errorText": string;
117
+ "errorsDisabled": boolean;
118
+ "identifier"?: string;
119
+ "legend"?: string;
120
+ "optional": boolean;
121
+ "optionalText"?: string;
122
+ "required": boolean;
123
+ "setChecked": () => Promise<void>;
124
+ "setFocus": () => Promise<void>;
125
+ "setFocusable": (flag: boolean) => Promise<void>;
126
+ "text"?: string;
127
+ "value"?: string;
128
+ }
129
+ interface DsRadioButtonGroup {
130
+ "assistiveText"?: string;
131
+ "direction": 'horizontal' | 'vertical';
132
+ "errorText": string;
133
+ "getValue": () => Promise<string>;
134
+ "initialValue"?: string;
135
+ "legend"?: string;
136
+ }
137
+ interface DsSpinner {
138
+ "hiddenAssistiveText": string;
139
+ "size": SpinnerSize;
140
+ "spinnerColor": SpinnerColor;
141
+ "spinnerTextPosition": SpinnerTextPosition;
142
+ "text": string;
143
+ "useAriaLive": boolean;
144
+ "useRoleAlert": boolean;
145
+ }
111
146
  interface DsTextInput {
112
147
  "actionButtonAriaLabel"?: string;
113
148
  "ariaDescribedby"?: string;
@@ -142,14 +177,18 @@ export namespace Components {
142
177
  interface DsVisuallyHidden {
143
178
  }
144
179
  }
145
- export interface DsCheckboxCustomEvent<T> extends CustomEvent<T> {
146
- detail: T;
147
- target: HTMLDsCheckboxElement;
148
- }
149
180
  export interface DsCheckboxGroupCustomEvent<T> extends CustomEvent<T> {
150
181
  detail: T;
151
182
  target: HTMLDsCheckboxGroupElement;
152
183
  }
184
+ export interface DsRadioButtonCustomEvent<T> extends CustomEvent<T> {
185
+ detail: T;
186
+ target: HTMLDsRadioButtonElement;
187
+ }
188
+ export interface DsRadioButtonGroupCustomEvent<T> extends CustomEvent<T> {
189
+ detail: T;
190
+ target: HTMLDsRadioButtonGroupElement;
191
+ }
153
192
  export interface DsTextInputCustomEvent<T> extends CustomEvent<T> {
154
193
  detail: T;
155
194
  target: HTMLDsTextInputElement;
@@ -167,18 +206,7 @@ declare global {
167
206
  prototype: HTMLDsButtonElement;
168
207
  new (): HTMLDsButtonElement;
169
208
  };
170
- interface HTMLDsCheckboxElementEventMap {
171
- "dsCheckboxInput": DsCheckboxInputEvent;
172
- }
173
209
  interface HTMLDsCheckboxElement extends Components.DsCheckbox, HTMLStencilElement {
174
- addEventListener<K extends keyof HTMLDsCheckboxElementEventMap>(type: K, listener: (this: HTMLDsCheckboxElement, ev: DsCheckboxCustomEvent<HTMLDsCheckboxElementEventMap[K]>) => any, options?: boolean | AddEventListenerOptions): void;
175
- addEventListener<K extends keyof DocumentEventMap>(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
176
- addEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
177
- addEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void;
178
- removeEventListener<K extends keyof HTMLDsCheckboxElementEventMap>(type: K, listener: (this: HTMLDsCheckboxElement, ev: DsCheckboxCustomEvent<HTMLDsCheckboxElementEventMap[K]>) => any, options?: boolean | EventListenerOptions): void;
179
- removeEventListener<K extends keyof DocumentEventMap>(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
180
- removeEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
181
- removeEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void;
182
210
  }
183
211
  var HTMLDsCheckboxElement: {
184
212
  prototype: HTMLDsCheckboxElement;
@@ -187,6 +215,7 @@ declare global {
187
215
  interface HTMLDsCheckboxGroupElementEventMap {
188
216
  "dsCheckboxGroupChange": DsCheckboxGroupChangeEvent;
189
217
  "dsCheckboxGroupIndeterminateChildChange": DsCheckboxGroupIndeterminateChildChangeEvent;
218
+ "dsCheckboxGroupInvalidStateChange": boolean;
190
219
  }
191
220
  interface HTMLDsCheckboxGroupElement extends Components.DsCheckboxGroup, HTMLStencilElement {
192
221
  addEventListener<K extends keyof HTMLDsCheckboxGroupElementEventMap>(type: K, listener: (this: HTMLDsCheckboxGroupElement, ev: DsCheckboxGroupCustomEvent<HTMLDsCheckboxGroupElementEventMap[K]>) => any, options?: boolean | AddEventListenerOptions): void;
@@ -226,6 +255,47 @@ declare global {
226
255
  prototype: HTMLDsLinkWithArrowElement;
227
256
  new (): HTMLDsLinkWithArrowElement;
228
257
  };
258
+ interface HTMLDsRadioButtonElementEventMap {
259
+ "dsRadioButtonChecked": any;
260
+ }
261
+ interface HTMLDsRadioButtonElement extends Components.DsRadioButton, HTMLStencilElement {
262
+ addEventListener<K extends keyof HTMLDsRadioButtonElementEventMap>(type: K, listener: (this: HTMLDsRadioButtonElement, ev: DsRadioButtonCustomEvent<HTMLDsRadioButtonElementEventMap[K]>) => any, options?: boolean | AddEventListenerOptions): void;
263
+ addEventListener<K extends keyof DocumentEventMap>(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
264
+ addEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
265
+ addEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void;
266
+ removeEventListener<K extends keyof HTMLDsRadioButtonElementEventMap>(type: K, listener: (this: HTMLDsRadioButtonElement, ev: DsRadioButtonCustomEvent<HTMLDsRadioButtonElementEventMap[K]>) => any, options?: boolean | EventListenerOptions): void;
267
+ removeEventListener<K extends keyof DocumentEventMap>(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
268
+ removeEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
269
+ removeEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void;
270
+ }
271
+ var HTMLDsRadioButtonElement: {
272
+ prototype: HTMLDsRadioButtonElement;
273
+ new (): HTMLDsRadioButtonElement;
274
+ };
275
+ interface HTMLDsRadioButtonGroupElementEventMap {
276
+ "dsRadioGroupValueChange": string | undefined;
277
+ "dsRadioGroupInvalidStateChange": boolean;
278
+ }
279
+ interface HTMLDsRadioButtonGroupElement extends Components.DsRadioButtonGroup, HTMLStencilElement {
280
+ addEventListener<K extends keyof HTMLDsRadioButtonGroupElementEventMap>(type: K, listener: (this: HTMLDsRadioButtonGroupElement, ev: DsRadioButtonGroupCustomEvent<HTMLDsRadioButtonGroupElementEventMap[K]>) => any, options?: boolean | AddEventListenerOptions): void;
281
+ addEventListener<K extends keyof DocumentEventMap>(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
282
+ addEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
283
+ addEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void;
284
+ removeEventListener<K extends keyof HTMLDsRadioButtonGroupElementEventMap>(type: K, listener: (this: HTMLDsRadioButtonGroupElement, ev: DsRadioButtonGroupCustomEvent<HTMLDsRadioButtonGroupElementEventMap[K]>) => any, options?: boolean | EventListenerOptions): void;
285
+ removeEventListener<K extends keyof DocumentEventMap>(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
286
+ removeEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
287
+ removeEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void;
288
+ }
289
+ var HTMLDsRadioButtonGroupElement: {
290
+ prototype: HTMLDsRadioButtonGroupElement;
291
+ new (): HTMLDsRadioButtonGroupElement;
292
+ };
293
+ interface HTMLDsSpinnerElement extends Components.DsSpinner, HTMLStencilElement {
294
+ }
295
+ var HTMLDsSpinnerElement: {
296
+ prototype: HTMLDsSpinnerElement;
297
+ new (): HTMLDsSpinnerElement;
298
+ };
229
299
  interface HTMLDsTextInputElementEventMap {
230
300
  "clear": DsTextInputClearEvent;
231
301
  }
@@ -258,6 +328,9 @@ declare global {
258
328
  "ds-input-validity": HTMLDsInputValidityElement;
259
329
  "ds-link": HTMLDsLinkElement;
260
330
  "ds-link-with-arrow": HTMLDsLinkWithArrowElement;
331
+ "ds-radio-button": HTMLDsRadioButtonElement;
332
+ "ds-radio-button-group": HTMLDsRadioButtonGroupElement;
333
+ "ds-spinner": HTMLDsSpinnerElement;
261
334
  "ds-text-input": HTMLDsTextInputElement;
262
335
  "ds-visually-hidden": HTMLDsVisuallyHiddenElement;
263
336
  }
@@ -281,8 +354,11 @@ declare namespace LocalJSX {
281
354
  "fullWidth"?: boolean;
282
355
  "icon"?: string;
283
356
  "iconPosition"?: 'start' | 'end';
357
+ "isLoading"?: boolean;
284
358
  "size"?: 'small' | 'medium';
359
+ "spinnerHiddenText"?: string;
285
360
  "type"?: 'button' | 'submit' | 'reset';
361
+ "useSpinner"?: boolean;
286
362
  /**
287
363
  * Button text content. Uses a text prop instead of `<slot />` to avoid triggering another render to set correct CSS classes just after initial load.
288
364
  * @example <ds-button value="button"></ds-button> // Do this <ds-button>button</ds-button> // Instead of this
@@ -302,7 +378,6 @@ declare namespace LocalJSX {
302
378
  "identifier"?: string;
303
379
  "indeterminate"?: boolean;
304
380
  "legend"?: string;
305
- "onDsCheckboxInput"?: (event: DsCheckboxCustomEvent<DsCheckboxInputEvent>) => void;
306
381
  "optional"?: boolean;
307
382
  "optionalText"?: string;
308
383
  "required"?: boolean;
@@ -317,6 +392,7 @@ declare namespace LocalJSX {
317
392
  "legend"?: string;
318
393
  "onDsCheckboxGroupChange"?: (event: DsCheckboxGroupCustomEvent<DsCheckboxGroupChangeEvent>) => void;
319
394
  "onDsCheckboxGroupIndeterminateChildChange"?: (event: DsCheckboxGroupCustomEvent<DsCheckboxGroupIndeterminateChildChangeEvent>) => void;
395
+ "onDsCheckboxGroupInvalidStateChange"?: (event: DsCheckboxGroupCustomEvent<boolean>) => void;
320
396
  "text"?: string;
321
397
  }
322
398
  interface DsIcon {
@@ -355,6 +431,39 @@ declare namespace LocalJSX {
355
431
  "target"?: LinkTarget;
356
432
  "text"?: string;
357
433
  }
434
+ interface DsRadioButton {
435
+ "assistiveText"?: string;
436
+ "checked"?: boolean;
437
+ "disabled"?: boolean;
438
+ "errorText"?: string;
439
+ "errorsDisabled"?: boolean;
440
+ "identifier"?: string;
441
+ "legend"?: string;
442
+ "onDsRadioButtonChecked"?: (event: DsRadioButtonCustomEvent<any>) => void;
443
+ "optional"?: boolean;
444
+ "optionalText"?: string;
445
+ "required"?: boolean;
446
+ "text"?: string;
447
+ "value"?: string;
448
+ }
449
+ interface DsRadioButtonGroup {
450
+ "assistiveText"?: string;
451
+ "direction"?: 'horizontal' | 'vertical';
452
+ "errorText"?: string;
453
+ "initialValue"?: string;
454
+ "legend"?: string;
455
+ "onDsRadioGroupInvalidStateChange"?: (event: DsRadioButtonGroupCustomEvent<boolean>) => void;
456
+ "onDsRadioGroupValueChange"?: (event: DsRadioButtonGroupCustomEvent<string | undefined>) => void;
457
+ }
458
+ interface DsSpinner {
459
+ "hiddenAssistiveText"?: string;
460
+ "size"?: SpinnerSize;
461
+ "spinnerColor"?: SpinnerColor;
462
+ "spinnerTextPosition"?: SpinnerTextPosition;
463
+ "text"?: string;
464
+ "useAriaLive"?: boolean;
465
+ "useRoleAlert"?: boolean;
466
+ }
358
467
  interface DsTextInput {
359
468
  "actionButtonAriaLabel"?: string;
360
469
  "ariaDescribedby"?: string;
@@ -396,6 +505,9 @@ declare namespace LocalJSX {
396
505
  "ds-input-validity": DsInputValidity;
397
506
  "ds-link": DsLink;
398
507
  "ds-link-with-arrow": DsLinkWithArrow;
508
+ "ds-radio-button": DsRadioButton;
509
+ "ds-radio-button-group": DsRadioButtonGroup;
510
+ "ds-spinner": DsSpinner;
399
511
  "ds-text-input": DsTextInput;
400
512
  "ds-visually-hidden": DsVisuallyHidden;
401
513
  }
@@ -412,6 +524,9 @@ declare module "@stencil/core" {
412
524
  "ds-input-validity": LocalJSX.DsInputValidity & JSXBase.HTMLAttributes<HTMLDsInputValidityElement>;
413
525
  "ds-link": LocalJSX.DsLink & JSXBase.HTMLAttributes<HTMLDsLinkElement>;
414
526
  "ds-link-with-arrow": LocalJSX.DsLinkWithArrow & JSXBase.HTMLAttributes<HTMLDsLinkWithArrowElement>;
527
+ "ds-radio-button": LocalJSX.DsRadioButton & JSXBase.HTMLAttributes<HTMLDsRadioButtonElement>;
528
+ "ds-radio-button-group": LocalJSX.DsRadioButtonGroup & JSXBase.HTMLAttributes<HTMLDsRadioButtonGroupElement>;
529
+ "ds-spinner": LocalJSX.DsSpinner & JSXBase.HTMLAttributes<HTMLDsSpinnerElement>;
415
530
  "ds-text-input": LocalJSX.DsTextInput & JSXBase.HTMLAttributes<HTMLDsTextInputElement>;
416
531
  "ds-visually-hidden": LocalJSX.DsVisuallyHidden & JSXBase.HTMLAttributes<HTMLDsVisuallyHiddenElement>;
417
532
  }
@@ -0,0 +1 @@
1
+ export declare function handleButtonLoading(buttonElement: HTMLElement, originalValue: string, loadValue: string, loadingDuration?: number): void;
@@ -12,7 +12,7 @@ export declare const opaque: {
12
12
  '--ds-overlay-white': string;
13
13
  };
14
14
  export declare const semantic: {
15
- '--ds-textColor': string;
16
- '--ds-bgColor': string;
17
- '--ds-borderColor': string;
15
+ $dsTextColor: string;
16
+ $dsBgColor: string;
17
+ $dsBorderColor: string;
18
18
  };
@@ -0,0 +1 @@
1
+ export declare function toggleSpinnerLoad(buttonElement: HTMLElement, spinnerElement: HTMLElement, results: HTMLElement, buttonOriginalValue: string, loadValue: string, loadingDuration?: number): void;
@@ -100,3 +100,4 @@ export declare const withinShadowRoot: (customElem: HTMLElement, selector: strin
100
100
  export declare const getShadowRoot: (customElem: HTMLElement, selector: string) => Promise<ShadowRoot>;
101
101
  export declare const getDsElem: (customElem: HTMLElement, selector: string) => Promise<Element>;
102
102
  export declare const addMockEventListener: (container: HTMLElement, selector: string, eventName: string) => import("@vitest/spy").Mock<(...args: any[]) => any>;
103
+ export declare const sleep: (ms: number) => Promise<unknown>;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@uh-design-system/component-library",
3
- "version": "0.5.2",
3
+ "version": "0.5.3",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -38,19 +38,19 @@
38
38
  "dist/"
39
39
  ],
40
40
  "scripts": {
41
- "build": "stencil build",
42
- "build.watch": "stencil build --watch",
43
- "develop": "run-p build.watch storybook",
44
- "start": "stencil build --dev --watch --serve",
45
- "test-storybook": "test-storybook",
46
- "test-storybook:update": "rm -rf __snapshots__ && test-storybook -u",
47
- "test:unit": "stencil test --spec",
48
- "test": "stencil test --spec --e2e",
49
- "test.watch": "stencil test --spec --e2e --watchAll",
50
- "generate": "stencil generate",
51
- "storybook": "storybook dev -p 6006",
52
- "build-storybook-static": "storybook build",
53
- "build-storybook": "run-s build build-storybook-static"
41
+ "build": "run-s stencil.build storybook.build styles.build",
42
+ "develop": "run-p stencil.build:watch storybook.dev",
43
+ "lint": "eslint --ext .ts,.tsx,.js,.jsx ./src",
44
+ "stencil.build": "stencil build",
45
+ "stencil.build:watch": "stencil build --watch",
46
+ "stencil.test": "stencil test --spec",
47
+ "stencil.test:watch": "stencil test --spec --watchAll",
48
+ "stencil.generate": "stencil generate",
49
+ "storybook.dev": "storybook dev -p 6006",
50
+ "storybook.build": "storybook build",
51
+ "storybook.test": "test-storybook",
52
+ "storybook.test:update": "rm -rf __snapshots__ && storybook.test -- -u",
53
+ "styles.build": "sass src/styles/helpers.scss dist/styles/helpers.css && sass src/styles/variables.scss dist/styles/variables.css"
54
54
  },
55
55
  "devDependencies": {
56
56
  "@chromatic-com/storybook": "^3.2.5",
@@ -95,5 +95,5 @@
95
95
  "glob": "^9.0.0"
96
96
  },
97
97
  "license": "MIT",
98
- "gitHead": "eed49403d98c03e19f57b8b391c9c9057d03b7c0"
98
+ "gitHead": "0df2c5c875523a507d6fd42dec1948594671d16c"
99
99
  }
@@ -1,20 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- const index = require('./index-bf84b124.js');
6
-
7
- const dsVisuallyHiddenCss = ".ds-visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}";
8
- const DsVisuallyHiddenStyle0 = dsVisuallyHiddenCss;
9
-
10
- const DsVisuallyHidden = class {
11
- constructor(hostRef) {
12
- index.registerInstance(this, hostRef);
13
- }
14
- render() {
15
- return (index.h("div", { key: 'f488f0f134c76c308763d47c57360e54ae299a06', class: "ds-visually-hidden" }, index.h("slot", { key: '20d5cdef8c333e5421c670e2558b511b1f235e7f' })));
16
- }
17
- };
18
- DsVisuallyHidden.style = DsVisuallyHiddenStyle0;
19
-
20
- exports.ds_visually_hidden = DsVisuallyHidden;
@@ -1 +0,0 @@
1
- const o=(o,a)=>[o,Boolean(a)?a:"(optional)"].join(" "),a=o=>[o,"*"].join(" ");export{o as a,a as g}