@vonage/vivid 3.30.0 → 3.32.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 (135) hide show
  1. package/alert/index.js +2 -1
  2. package/checkbox/index.js +2 -1
  3. package/combobox/index.js +2 -1
  4. package/custom-elements.json +811 -18
  5. package/date-picker/index.js +35 -0
  6. package/dialog/index.js +1 -1
  7. package/divider/index.js +1 -1
  8. package/empty-state/index.js +1 -1
  9. package/fab/index.js +1 -1
  10. package/file-picker/index.js +3 -2
  11. package/header/index.js +1 -1
  12. package/index.d.ts +1 -0
  13. package/index.js +48 -46
  14. package/layout/index.js +1 -1
  15. package/lib/button/button.d.ts +2 -0
  16. package/lib/components.d.ts +20 -19
  17. package/lib/date-picker/calendar/calendarGrid.d.ts +17 -0
  18. package/lib/date-picker/calendar/dateStr.d.ts +6 -0
  19. package/lib/date-picker/calendar/month.d.ts +11 -0
  20. package/lib/date-picker/calendar/monthPickerGrid.d.ts +10 -0
  21. package/lib/date-picker/calendar/presentationDate.d.ts +4 -0
  22. package/lib/date-picker/date-picker.d.ts +16 -0
  23. package/lib/date-picker/date-picker.template.d.ts +4 -0
  24. package/lib/date-picker/definition.d.ts +3 -0
  25. package/lib/date-picker/index.d.ts +1 -0
  26. package/lib/date-picker/locale.d.ts +21 -0
  27. package/lib/nav-disclosure/nav-disclosure.d.ts +1 -0
  28. package/lib/pagination/definition.d.ts +1 -0
  29. package/lib/pagination/pagination.d.ts +3 -1
  30. package/lib/select/select.d.ts +4 -2
  31. package/listbox/index.js +3 -2
  32. package/locales/en-GB.d.ts +3 -0
  33. package/locales/en-GB.js +25 -0
  34. package/locales/en-US.d.ts +3 -0
  35. package/locales/en-US.js +25 -0
  36. package/locales/ja-JP.d.ts +3 -0
  37. package/locales/ja-JP.js +25 -0
  38. package/locales/zh-CN.d.ts +3 -0
  39. package/locales/zh-CN.js +25 -0
  40. package/menu/index.js +2 -2
  41. package/menu-item/index.js +1 -1
  42. package/nav/index.js +1 -1
  43. package/nav-disclosure/index.js +1 -1
  44. package/nav-item/index.js +1 -1
  45. package/note/index.js +3 -2
  46. package/number-field/index.js +4 -3
  47. package/option/index.js +2 -1
  48. package/package.json +2 -1
  49. package/pagination/index.js +1 -1
  50. package/progress/index.js +1 -1
  51. package/radio/index.js +1 -1
  52. package/radio-group/index.js +1 -1
  53. package/select/index.js +3 -2
  54. package/shared/definition.js +1 -1
  55. package/shared/definition10.js +1 -1
  56. package/shared/definition11.js +1 -1
  57. package/shared/definition12.js +1 -1
  58. package/shared/definition14.js +1 -1
  59. package/shared/definition15.js +1 -1
  60. package/shared/definition16.js +1 -1
  61. package/shared/definition17.js +1 -1
  62. package/shared/definition18.js +2 -2
  63. package/shared/definition19.js +2 -2
  64. package/shared/definition2.js +1 -1
  65. package/shared/definition21.js +3 -3
  66. package/shared/definition22.js +2 -2
  67. package/shared/definition23.js +5750 -189
  68. package/shared/definition24.js +116 -68
  69. package/shared/definition25.js +68 -38
  70. package/shared/definition26.js +222 -74
  71. package/shared/definition27.js +33 -2282
  72. package/shared/definition28.js +76 -47
  73. package/shared/definition29.js +2287 -38
  74. package/shared/definition30.js +39 -417
  75. package/shared/definition31.js +38 -364
  76. package/shared/definition32.js +427 -12
  77. package/shared/definition33.js +351 -53
  78. package/shared/definition34.js +12 -26
  79. package/shared/definition35.js +67 -31
  80. package/shared/definition36.js +20 -431
  81. package/shared/definition37.js +34 -181
  82. package/shared/definition38.js +427 -45
  83. package/shared/definition39.js +195 -33
  84. package/shared/definition4.js +1 -1
  85. package/shared/definition40.js +53 -425
  86. package/shared/definition41.js +29 -645
  87. package/shared/definition42.js +420 -73
  88. package/shared/definition43.js +549 -444
  89. package/shared/definition44.js +68 -90
  90. package/shared/definition45.js +501 -79
  91. package/shared/definition46.js +84 -45
  92. package/shared/definition47.js +131 -17
  93. package/shared/definition48.js +44 -471
  94. package/shared/definition49.js +21 -108
  95. package/shared/definition5.js +1 -1
  96. package/shared/definition50.js +487 -15
  97. package/shared/definition51.js +92 -255
  98. package/shared/definition52.js +16 -115
  99. package/shared/definition53.js +264 -115
  100. package/shared/definition54.js +91 -82
  101. package/shared/definition55.js +111 -65
  102. package/shared/definition56.js +64 -291
  103. package/shared/definition57.js +303 -0
  104. package/shared/definition6.js +2 -2
  105. package/shared/definition7.js +10 -3
  106. package/shared/definition9.js +1 -1
  107. package/shared/{form-elements.js → index2.js} +14 -2
  108. package/shared/localization/Locale.d.ts +4 -0
  109. package/shared/localization/index.d.ts +7 -0
  110. package/shared/patterns/form-elements/form-elements.d.ts +4 -4
  111. package/shared/patterns/index.d.ts +1 -0
  112. package/shared/patterns/localized.d.ts +4 -0
  113. package/shared/text-field.js +1 -1
  114. package/side-drawer/index.js +1 -1
  115. package/slider/index.js +1 -1
  116. package/split-button/index.js +1 -1
  117. package/styles/core/all.css +25 -3
  118. package/styles/core/theme.css +1 -1
  119. package/styles/core/typography.css +25 -3
  120. package/styles/tokens/theme-dark.css +4 -4
  121. package/styles/tokens/theme-light.css +4 -4
  122. package/styles/tokens/vivid-2-compat.css +14 -0
  123. package/switch/index.js +3 -2
  124. package/tab/index.js +1 -1
  125. package/tab-panel/index.js +1 -1
  126. package/tabs/index.js +3 -3
  127. package/tag/index.js +1 -1
  128. package/tag-group/index.js +1 -1
  129. package/text-area/index.js +3 -2
  130. package/text-field/index.js +3 -2
  131. package/toggletip/index.js +1 -1
  132. package/tooltip/index.js +1 -1
  133. package/tree-item/index.js +1 -1
  134. package/tree-view/index.js +1 -1
  135. package/vivid.api.json +262 -0
@@ -1,56 +1,85 @@
1
- import { F as FoundationElement, _ as __decorate, a as attr, b as __metadata, h as html, r as registerFactory } from './index.js';
2
- import { E as Elevation, e as elevationRegistries } from './definition8.js';
1
+ import { _ as __decorate, a as attr, b as __metadata, h as html, r as registerFactory } from './index.js';
2
+ import { i as iconRegistries } from './definition3.js';
3
+ import { f as focusRegistries } from './definition4.js';
4
+ import { A as AffixIconWithTrailing, a as affixIconTemplateFactory } from './affix.js';
5
+ import { B as Button } from './button.js';
6
+ import { a as applyMixins } from './apply-mixins.js';
7
+ import { f as focusTemplateFactory } from './focus2.js';
8
+ import { r as ref } from './ref.js';
3
9
  import { c as classNames } from './class-names.js';
4
10
 
5
- var css_248z = "/**\n * Do not edit directly\n * Generated on Mon, 14 Aug 2023 13:17:40 GMT\n */\n.base {\n z-index: 1;\n block-size: calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density, 0), 2))) + calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density, 0), 2) - 16)));\n font: var(--vvd-typography-heading-4);\n inline-size: 100%;\n}\n.base .header-content {\n display: inline-flex;\n align-items: center;\n column-gap: 4px;\n}\n\n.container {\n display: flex;\n box-sizing: border-box;\n justify-content: space-between;\n background-color: var(--header-bg-color, var(--vvd-color-canvas));\n block-size: inherit;\n color: var(--vvd-color-canvas-text);\n column-gap: 12px;\n padding-block: 8px;\n padding-inline: 16px;\n}\n.container[part~=vvd-theme-alternate] {\n color-scheme: var(--vvd-color-scheme);\n}\n\n.app-content {\n --vvd-header-block-size: calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density, 0), 2))) + calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density, 0), 2) - 16)));\n}";
11
+ var css_248z = "/**\n * Do not edit directly\n * Generated on Tue, 22 Aug 2023 13:37:39 GMT\n */\n.control {\n position: relative;\n display: inline-flex;\n box-sizing: border-box;\n align-items: center;\n border: 0 none;\n background: var(--_appearance-color-fill, var(--_elevation-fill));\n block-size: var(--_fab-block-size);\n border-radius: var(--_fab-border-radius);\n color: var(--_appearance-color-text, var(--vvd-color-canvas-text));\n column-gap: var(--fab-icon-gap);\n filter: var(--_elevation-shadow);\n font: var(--vvd-typography-base-bold);\n transition: background-color 0.15s linear, filter 0.15s linear;\n vertical-align: middle;\n /* Size */\n}\n.control.connotation-accent {\n /* @cssprop [--vvd-fab-accent-primary=var(--vvd-color-canvas-text)] */\n --_connotation-color-primary: var(--vvd-fab-accent-primary, var(--vvd-color-canvas-text));\n /* @cssprop [--vvd-fab-accent-primary-text=var(--vvd-color-canvas)] */\n --_connotation-color-primary-text: var(--vvd-fab-accent-primary-text, var(--vvd-color-canvas));\n /* @cssprop [--vvd-fab-accent-primary-increment=var(--vvd-color-neutral-800)] */\n --_connotation-color-primary-increment: var(--vvd-fab-accent-primary-increment, var(--vvd-color-neutral-800));\n /* @cssprop [--vvd-fab-accent-contrast=var(--vvd-color-neutral-800)] */\n --_connotation-color-contrast: var(--vvd-fab-accent-contrast, var(--vvd-color-neutral-800));\n /* @cssprop [--vvd-fab-accent-fierce=var(--vvd-color-neutral-700)] */\n --_connotation-color-fierce: var(--vvd-fab-accent-fierce, var(--vvd-color-neutral-700));\n /* @cssprop [--vvd-fab-accent-firm=var(--vvd-color-canvas-text)] */\n --_connotation-color-firm: var(--vvd-fab-accent-firm, var(--vvd-color-canvas-text));\n}\n.control.connotation-cta {\n /* @cssprop [--vvd-fab-cta-primary=var(--vvd-color-cta-500)] */\n --_connotation-color-primary: var(--vvd-fab-cta-primary, var(--vvd-color-cta-500));\n /* @cssprop [--vvd-fab-cta-primary-text=var(--vvd-color-canvas)] */\n --_connotation-color-primary-text: var(--vvd-fab-cta-primary-text, var(--vvd-color-canvas));\n /* @cssprop [--vvd-fab-cta-primary-increment=var(--vvd-color-cta-600)] */\n --_connotation-color-primary-increment: var(--vvd-fab-cta-primary-increment, var(--vvd-color-cta-600));\n /* @cssprop [--vvd-fab-cta-contrast=var(--vvd-color-cta-800)] */\n --_connotation-color-contrast: var(--vvd-fab-cta-contrast, var(--vvd-color-cta-800));\n /* @cssprop [--vvd-fab-cta-fierce=var(--vvd-color-cta-700)] */\n --_connotation-color-fierce: var(--vvd-fab-cta-fierce, var(--vvd-color-cta-700));\n /* @cssprop [--vvd-fab-cta-firm=var(--vvd-color-cta-600)] */\n --_connotation-color-firm: var(--vvd-fab-cta-firm, var(--vvd-color-cta-600));\n}\n.control {\n --_appearance-color-text: var(--_connotation-color-primary-text);\n --_appearance-color-fill: var(--_connotation-color-primary);\n --_appearance-color-outline: transparent;\n}\n.control:where(:hover, .hover):where(:not(:disabled, .disabled, .readonly)) {\n --_appearance-color-text: var(--_connotation-color-primary-text);\n --_appearance-color-fill: var(--_connotation-color-primary-increment);\n --_appearance-color-outline: transparent;\n}\n.control:where(:disabled, .disabled) {\n --_appearance-color-text: var(--vvd-color-neutral-300);\n --_appearance-color-fill: var(--vvd-color-neutral-100);\n --_appearance-color-outline: transparent;\n}\n.control:where(:active, .active):where(:not(:disabled, .disabled)) {\n --_appearance-color-text: var(--_connotation-color-primary-text);\n --_appearance-color-fill: var(--_connotation-color-fierce);\n --_appearance-color-outline: transparent;\n}\n@supports selector(:focus-visible) {\n .control:focus-visible {\n outline: none;\n }\n}\n@supports (user-select: none) {\n .control {\n user-select: none;\n }\n}\n.control.size-expanded {\n --_fab-border-radius: 30px;\n --_fab-block-size: calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density, 0), 2) + 16));\n}\n.control:not(.size-expanded) {\n --_fab-border-radius: 24px;\n --_fab-block-size: calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density, 0), 2)));\n}\n.control.icon-only {\n border-radius: 50%;\n padding-inline: 0;\n place-content: center;\n}\n@supports (aspect-ratio: 1) {\n .control.icon-only {\n aspect-ratio: 1;\n }\n}\n@supports not (aspect-ratio: 1) {\n .control.icon-only {\n inline-size: var(--_fab-block-size);\n }\n}\n.control:not(.icon-only) {\n --fab-icon-gap: 10px;\n padding-inline: 20px;\n}\n.control:disabled {\n --_elevation-fill: var(--vvd-color-surface-0dp);\n --_elevation-shadow: var(--vvd-shadow-surface-0dp);\n cursor: not-allowed;\n}\n.control:not(:disabled) {\n --_elevation-fill: var(--vvd-color-surface-4dp);\n --_elevation-shadow: var(--vvd-shadow-surface-4dp);\n cursor: pointer;\n}\n.control:not(:disabled):hover {\n --_elevation-fill: var(--vvd-color-surface-12dp);\n --_elevation-shadow: var(--vvd-shadow-surface-12dp);\n}\n.control:not(:disabled):active {\n --_elevation-fill: var(--vvd-color-surface-24dp);\n --_elevation-shadow: var(--vvd-shadow-surface-24dp);\n}\n\n/* Icon */\n.icon {\n line-height: 1;\n}\n.icon-trailing .icon {\n order: 1;\n}\n.control.size-extended .icon {\n font-size: calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density, 0), 2) + 16)) / 2.3333);\n}\n.control:not(.size-extended) .icon {\n font-size: calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density, 0), 2))) / 2);\n}\n\n:not(:focus-visible) .focus-indicator {\n display: none;\n}\n.control:not(.connotation-accent, .connotation-cta) .focus-indicator {\n --focus-stroke-gap-color: transparent;\n}";
6
12
 
7
- class Header extends FoundationElement {
8
- constructor() {
9
- super(...arguments);
10
- this.elevationShadow = false;
11
- this.alternate = false;
12
- }
13
- }
14
- __decorate([attr({
15
- attribute: 'elevation-shadow',
16
- mode: 'boolean'
17
- }), __metadata("design:type", Object)], Header.prototype, "elevationShadow", void 0);
18
- __decorate([attr({
19
- mode: 'boolean'
20
- }), __metadata("design:type", Object)], Header.prototype, "alternate", void 0);
13
+ class Fab extends Button {}
14
+ __decorate([attr, __metadata("design:type", String)], Fab.prototype, "connotation", void 0);
15
+ __decorate([attr, __metadata("design:type", String)], Fab.prototype, "size", void 0);
16
+ __decorate([attr, __metadata("design:type", String)], Fab.prototype, "label", void 0);
17
+ applyMixins(Fab, AffixIconWithTrailing);
21
18
 
22
- const getPartAlternate = ({
23
- alternate
24
- }) => classNames(['vvd-theme-alternate', Boolean(alternate)]);
25
- const headerTemplate = context => {
26
- const elevationTag = context.tagFor(Elevation);
19
+ const getClasses = ({
20
+ connotation,
21
+ size,
22
+ icon,
23
+ label,
24
+ iconTrailing,
25
+ disabled
26
+ }) => classNames('control', [`connotation-${connotation}`, Boolean(connotation)], [`size-${size}`, Boolean(size)], ['icon-only', !label && !!icon], ['icon-trailing', iconTrailing], ['disabled', disabled]);
27
+ const FabTemplate = context => {
28
+ const affixIconTemplate = affixIconTemplateFactory(context);
29
+ const focusTemplate = focusTemplateFactory(context);
27
30
  return html`
28
- <${elevationTag} dp="4" ?no-shadow=${x => !x.elevationShadow}>
29
- <header class="base" part="base">
30
- <!-- a container is needed to distinguish the surface background color of the
31
- element from its shadow when applying elevation with alternate -->
32
- <div class="container" part="${getPartAlternate}">
33
- <section class="header-content">
34
- <slot></slot>
35
- </section>
36
- <section class="header-content">
37
- <slot name="action-items"></slot>
38
- </section>
39
- </div>
40
- </header>
41
- </${elevationTag}>
42
- <div class="app-content">
43
- <slot name="app-content"></slot>
44
- </div>
45
- `;
31
+ <button
32
+ class="${getClasses} "
33
+ ?autofocus="${x => x.autofocus}"
34
+ ?disabled="${x => x.disabled}"
35
+ form="${x => x.formId}"
36
+ formaction="${x => x.formaction}"
37
+ formenctype="${x => x.formenctype}"
38
+ formmethod="${x => x.formmethod}"
39
+ formnovalidate="${x => x.formnovalidate}"
40
+ formtarget="${x => x.formtarget}"
41
+ name="${x => x.name}"
42
+ type="${x => x.type}"
43
+ value="${x => x.value}"
44
+ aria-atomic="${x => x.ariaAtomic}"
45
+ aria-busy="${x => x.ariaBusy}"
46
+ aria-controls="${x => x.ariaControls}"
47
+ aria-current="${x => x.ariaCurrent}"
48
+ aria-describedby="${x => x.ariaDescribedby}"
49
+ aria-details="${x => x.ariaDetails}"
50
+ aria-disabled="${x => x.ariaDisabled}"
51
+ aria-errormessage="${x => x.ariaErrormessage}"
52
+ aria-expanded="${x => x.ariaExpanded}"
53
+ aria-flowto="${x => x.ariaFlowto}"
54
+ aria-haspopup="${x => x.ariaHaspopup}"
55
+ aria-hidden="${x => x.ariaHidden}"
56
+ aria-invalid="${x => x.ariaInvalid}"
57
+ aria-keyshortcuts="${x => x.ariaKeyshortcuts}"
58
+ aria-label="${x => x.ariaLabel}"
59
+ aria-labelledby="${x => x.ariaLabelledby}"
60
+ aria-live="${x => x.ariaLive}"
61
+ aria-owns="${x => x.ariaOwns}"
62
+ aria-pressed="${x => x.ariaPressed}"
63
+ aria-relevant="${x => x.ariaRelevant}"
64
+ aria-roledescription="${x => x.ariaRoledescription}"
65
+ ${ref('control')}
66
+ >
67
+ ${() => focusTemplate}
68
+ ${x => affixIconTemplate(x.icon)}
69
+ ${x => x.label}
70
+ </button>
71
+ `;
46
72
  };
47
73
 
48
- const headerDefinition = Header.compose({
49
- baseName: 'header',
50
- template: headerTemplate,
51
- styles: css_248z
74
+ const fabDefinition = Fab.compose({
75
+ baseName: 'fab',
76
+ template: FabTemplate,
77
+ styles: css_248z,
78
+ shadowOptions: {
79
+ delegatesFocus: true
80
+ }
52
81
  });
53
- const headerRegistries = [headerDefinition(), ...elevationRegistries];
54
- const registerHeader = registerFactory(headerRegistries);
82
+ const fabRegistries = [fabDefinition(), ...iconRegistries, ...focusRegistries];
83
+ const registerFab = registerFactory(fabRegistries);
55
84
 
56
- export { headerRegistries as a, headerDefinition as h, registerHeader as r };
85
+ export { fabRegistries as a, fabDefinition as f, registerFab as r };