@vonage/vivid 3.0.0-next.9 → 3.0.0-next.90

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 (190) hide show
  1. package/README.md +141 -4
  2. package/accordion/index.js +3 -12
  3. package/accordion-item/index.js +30 -38
  4. package/action-group/index.js +41 -0
  5. package/avatar/index.js +60 -0
  6. package/badge/index.js +16 -30
  7. package/banner/index.js +25 -111
  8. package/breadcrumb/index.js +21 -18
  9. package/breadcrumb-item/index.js +23 -20
  10. package/button/index.js +19 -757
  11. package/calendar/index.js +72 -67
  12. package/calendar-event/index.js +112 -0
  13. package/card/index.js +113 -0
  14. package/checkbox/index.js +176 -0
  15. package/dialog/index.js +229 -0
  16. package/divider/index.js +4 -0
  17. package/elevation/index.js +3 -31
  18. package/fab/index.js +99 -0
  19. package/focus/index.js +18 -3
  20. package/header/index.js +61 -0
  21. package/icon/index.js +10 -9
  22. package/index.js +57 -20
  23. package/layout/index.js +5 -15
  24. package/lib/accordion-item/accordion-item.d.ts +2 -2
  25. package/lib/accordion-item/index.d.ts +2 -1
  26. package/lib/action-group/action-group.d.ts +10 -0
  27. package/lib/{sidenav-item/sidenav-item.template.d.ts → action-group/action-group.template.d.ts} +2 -2
  28. package/lib/{sidenav-item → action-group}/index.d.ts +1 -2
  29. package/lib/avatar/avatar.d.ts +15 -0
  30. package/lib/avatar/avatar.template.d.ts +4 -0
  31. package/lib/avatar/index.d.ts +3 -0
  32. package/lib/badge/badge.d.ts +3 -5
  33. package/lib/badge/index.d.ts +1 -1
  34. package/lib/banner/banner.d.ts +1 -1
  35. package/lib/banner/banner.template.d.ts +0 -2
  36. package/lib/banner/index.d.ts +1 -0
  37. package/lib/breadcrumb/breadcrumb.template.d.ts +4 -0
  38. package/lib/breadcrumb-item/breadcrumb-item.d.ts +1 -1
  39. package/lib/breadcrumb-item/index.d.ts +1 -0
  40. package/lib/button/button.d.ts +6 -5
  41. package/lib/button/index.d.ts +2 -19
  42. package/lib/calendar/calendar.d.ts +3 -1
  43. package/lib/calendar/index.d.ts +0 -1
  44. package/lib/calendar-event/calendar-event.d.ts +14 -0
  45. package/lib/calendar-event/calendar-event.template.d.ts +4 -0
  46. package/lib/calendar-event/index.d.ts +2 -0
  47. package/lib/card/card.d.ts +10 -0
  48. package/lib/{text/text.template.d.ts → card/card.template.d.ts} +2 -2
  49. package/lib/card/index.d.ts +4 -0
  50. package/lib/checkbox/checkbox.d.ts +5 -0
  51. package/lib/checkbox/checkbox.template.d.ts +4 -0
  52. package/lib/checkbox/index.d.ts +4 -0
  53. package/lib/components.d.ts +29 -10
  54. package/lib/dialog/dialog.d.ts +20 -0
  55. package/lib/dialog/dialog.template.d.ts +4 -0
  56. package/lib/dialog/index.d.ts +5 -0
  57. package/lib/divider/divider.d.ts +3 -0
  58. package/lib/divider/divider.template.d.ts +4 -0
  59. package/lib/divider/index.d.ts +2 -0
  60. package/lib/elevation/elevation.d.ts +1 -0
  61. package/lib/elevation/index.d.ts +1 -1
  62. package/lib/enums.d.ts +11 -6
  63. package/lib/fab/fab.d.ts +13 -0
  64. package/lib/fab/fab.template.d.ts +4 -0
  65. package/lib/fab/index.d.ts +4 -0
  66. package/lib/focus/index.d.ts +1 -1
  67. package/lib/header/header.d.ts +5 -0
  68. package/lib/header/header.template.d.ts +4 -0
  69. package/lib/header/index.d.ts +3 -0
  70. package/lib/icon/icon.d.ts +4 -3
  71. package/lib/layout/index.d.ts +1 -1
  72. package/lib/layout/layout.d.ts +3 -3
  73. package/lib/listbox-option/index.d.ts +4 -0
  74. package/lib/listbox-option/listbox-option.d.ts +7 -0
  75. package/lib/listbox-option/listbox-option.template.d.ts +4 -0
  76. package/lib/menu/index.d.ts +12 -0
  77. package/lib/menu/menu.d.ts +10 -0
  78. package/lib/menu/menu.template.d.ts +3 -0
  79. package/lib/menu-item/index.d.ts +3 -0
  80. package/lib/menu-item/menu-item.d.ts +7 -0
  81. package/lib/menu-item/menu-item.template.d.ts +5 -0
  82. package/lib/nav/index.d.ts +2 -0
  83. package/lib/nav/nav.d.ts +3 -0
  84. package/lib/nav/nav.template.d.ts +4 -0
  85. package/lib/nav-disclosure/index.d.ts +4 -0
  86. package/lib/nav-disclosure/nav-disclosure.d.ts +10 -0
  87. package/lib/nav-disclosure/nav-disclosure.template.d.ts +4 -0
  88. package/lib/nav-item/index.d.ts +4 -0
  89. package/lib/{sidenav-item/sidenav-item.d.ts → nav-item/nav-item.d.ts} +2 -2
  90. package/lib/nav-item/nav-item.template.d.ts +4 -0
  91. package/lib/{text → note}/index.d.ts +1 -1
  92. package/lib/note/note.d.ts +10 -0
  93. package/lib/note/note.template.d.ts +5 -0
  94. package/lib/number-field/index.d.ts +4 -0
  95. package/lib/number-field/number-field.d.ts +14 -0
  96. package/lib/number-field/number-field.template.d.ts +4 -0
  97. package/lib/popup/index.d.ts +1 -1
  98. package/lib/popup/popup.d.ts +2 -1
  99. package/lib/progress/progress.d.ts +1 -1
  100. package/lib/progress-ring/progress-ring.d.ts +2 -1
  101. package/lib/radio/index.d.ts +3 -0
  102. package/lib/radio/radio.d.ts +4 -0
  103. package/lib/radio/radio.template.d.ts +4 -0
  104. package/lib/radio-group/index.d.ts +10 -0
  105. package/lib/radio-group/radio-group.d.ts +4 -0
  106. package/lib/radio-group/radio-group.template.d.ts +4 -0
  107. package/lib/side-drawer/index.d.ts +1 -1
  108. package/lib/side-drawer/side-drawer.d.ts +3 -2
  109. package/lib/text-anchor/text-anchor.d.ts +1 -1
  110. package/lib/text-area/index.d.ts +4 -0
  111. package/lib/text-area/text-area.d.ts +9 -0
  112. package/lib/text-area/text-area.template.d.ts +4 -0
  113. package/lib/text-field/index.d.ts +4 -0
  114. package/lib/text-field/text-field.d.ts +14 -0
  115. package/lib/text-field/text-field.template.d.ts +5 -0
  116. package/lib/tooltip/tooltip.d.ts +2 -2
  117. package/listbox-option/index.js +248 -0
  118. package/menu/index.js +376 -0
  119. package/menu-item/index.js +20 -0
  120. package/nav/index.js +17 -0
  121. package/nav-disclosure/index.js +81 -0
  122. package/nav-item/index.js +45 -0
  123. package/note/index.js +58 -0
  124. package/number-field/index.js +516 -0
  125. package/package.json +58 -10
  126. package/popup/index.js +22 -2061
  127. package/progress/index.js +35 -36
  128. package/progress-ring/index.js +11 -11
  129. package/radio/index.js +50 -0
  130. package/radio-group/index.js +435 -0
  131. package/shared/affix.js +1 -6
  132. package/shared/anchor.js +10 -2
  133. package/shared/apply-mixins.js +5 -4
  134. package/shared/aria-global.js +2 -86
  135. package/shared/aria.js +9 -0
  136. package/shared/base-progress.js +5 -0
  137. package/shared/breadcrumb-item.js +1 -1
  138. package/shared/button.js +200 -0
  139. package/shared/calendar-event.js +19 -0
  140. package/shared/dialog-polyfill.esm.js +858 -0
  141. package/shared/direction.js +20 -0
  142. package/shared/enums.js +62 -0
  143. package/shared/es.object.assign.js +3 -2
  144. package/shared/export.js +1017 -0
  145. package/shared/focus.js +5 -0
  146. package/shared/focus2.js +11 -0
  147. package/shared/form-associated.js +466 -0
  148. package/shared/form-elements.js +331 -0
  149. package/shared/icon.js +534 -531
  150. package/shared/index.js +108 -79
  151. package/shared/index2.js +100 -14
  152. package/shared/index3.js +31 -0
  153. package/shared/index4.js +77 -0
  154. package/shared/index5.js +1525 -0
  155. package/shared/index6.js +349 -0
  156. package/shared/iterators.js +61 -0
  157. package/shared/key-codes.js +96 -0
  158. package/shared/object-keys.js +13 -0
  159. package/shared/patterns/focus.d.ts +3 -0
  160. package/shared/patterns/form-elements/form-elements.d.ts +28 -0
  161. package/shared/patterns/form-elements/index.d.ts +1 -0
  162. package/shared/patterns/index.d.ts +2 -0
  163. package/shared/radio.js +127 -0
  164. package/shared/ref.js +41 -0
  165. package/shared/slotted.js +1 -1
  166. package/shared/start-end.js +50 -0
  167. package/shared/text-anchor.js +2 -13
  168. package/shared/text-anchor.template.js +6 -5
  169. package/shared/to-string.js +51 -0
  170. package/shared/web.dom-collections.iterator.js +74 -1081
  171. package/side-drawer/index.js +41 -33
  172. package/styles/core/all.css +75 -0
  173. package/styles/core/theme.css +11 -0
  174. package/styles/core/typography.css +69 -0
  175. package/styles/fonts/SpeziaCompleteVariableItalicWeb.woff2 +0 -0
  176. package/styles/fonts/SpeziaCompleteVariableUprightWeb.woff2 +0 -0
  177. package/styles/fonts/SpeziaMonoCompleteVariableWeb.woff2 +0 -0
  178. package/styles/fonts/spezia.css +9 -12
  179. package/styles/tokens/theme-dark.css +230 -0
  180. package/styles/tokens/theme-light.css +230 -0
  181. package/text-anchor/index.js +9 -1
  182. package/text-area/index.js +288 -0
  183. package/text-field/index.js +129 -0
  184. package/tooltip/index.js +23 -24
  185. package/lib/text/text.d.ts +0 -10
  186. package/shared/style-inject.es.js +0 -28
  187. package/sidenav-item/index.js +0 -38
  188. package/styles/themes/dark.css +0 -205
  189. package/styles/themes/light.css +0 -205
  190. package/text/index.js +0 -45
package/README.md CHANGED
@@ -1,7 +1,144 @@
1
- # components
2
1
 
3
- This library was generated with [Nx](https://nx.dev).
2
+ # Vivid UI
4
3
 
5
- ## Running unit tests
4
+ Essential UI **web components** for building modern web applications, bound to provide a **safe**, **simple** and **intuitive** interface.
6
5
 
7
- Run `nx test components` to execute the unit tests via [Jest](https://jestjs.io).
6
+ ![image](https://user-images.githubusercontent.com/10883919/189522882-968358df-ee7c-4256-b61b-550cf369a087.png)
7
+
8
+ ## Installation
9
+
10
+ To integrate Vivid components into your project, run:
11
+
12
+ ```bash
13
+ npm install @vonage/vivid # or yarn add @vonage/vivid
14
+ ```
15
+
16
+ ## Usage
17
+
18
+ Import components in your project via [side effect imports](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/import#import_a_module_for_its_side_effects_only):
19
+
20
+ ```js
21
+ import '@vonage/vivid/button';
22
+ ```
23
+
24
+ And include in HTML:
25
+
26
+ ```html
27
+ <vwc-button label="Click me"></vwc-button>
28
+ ```
29
+
30
+ For a full list of components and API, explore the [components docs](https://vivid.deno.dev/components/accordion/) 📚.
31
+
32
+ ### Tokens (Prerequisite)
33
+
34
+ The Vivid components library rely on a set of **design tokens** (in the form of css custom properties).
35
+
36
+ Tokens should not affect the look of the application rather just provide a common set of identities (such as colors, typography, spacing etc') to be used by the components to look as intended.
37
+
38
+ As the task of loading css is not trivial, and may vary from project to project, this library does not provide any way to load the css. It is up to the author to load the css in the most appropriate manner for their project.
39
+
40
+ To **include the tokens**, its css files must be loaded into the project from the `node_modules/@vonage/vivid/styles/tokens` folder and *require a `vvd-root` class* selector to be present on a wrapping element (advisably the `:root`).
41
+
42
+ Tokens folder contains the following files:
43
+
44
+ - `theme-light.css` - Light theme
45
+
46
+ - `theme-dark.css` - Dark theme
47
+
48
+ Only one theme is required to be loaded.
49
+
50
+ ### Fonts (Prerequisite)
51
+
52
+ - `node_modules/@vonage/vivid/styles/fonts/spezia.css` - Loads the *Spezia* variable font and defines its font face values. *Spezia* is Vonage's branded font and is required by most Vivid components. folder also contains the font files.
53
+
54
+ Note that font files are not included within the css file, and must be copied to application assets separately (within the same parsed css folder). This is to allow the author to choose the most appropriate way to load the font files based on their project.
55
+
56
+ ### Core (Optional)
57
+
58
+ In Addition, this library provides a set of styles (combined with the tokens and fonts) that can be used to embody the Vivid design system into an application.
59
+
60
+ These styles are not required by vivid components directly. however, native HTML tags do.
61
+
62
+ These **core styles** rely on the tokens and fonts 👆 to be loaded.
63
+
64
+ To **include the core styles**, its css files must be loaded into the project from the `node_modules/@vonage/vivid/styles/core` folder and *require a `vvd-root` class* selector to be present on a wrapping element (advisably the `:root`).
65
+
66
+ - `theme.css` - Sets theme related styles
67
+
68
+ - `typography.css` - Sets typography related styles
69
+
70
+ - `all.css` - Sets all the above styles
71
+
72
+ Note: scss users can simply [forward](https://sass-lang.com/documentation/at-rules/forward) the styles to their scss project:
73
+
74
+ ```css
75
+ @forward 'node_modules/@vonage/vivid/styles/[path to file].css';
76
+ ```
77
+
78
+ ## Support
79
+
80
+ This library is open source, developed and maintained by the [Vonage Vivid team](Vonage/vivid).
81
+
82
+ For any questions, please open a [bug report](https://github.com/Vonage/vivid-3/issues/new?assignees=&labels=&template=bug_report.md&title=) or [feature request](https://github.com/Vonage/vivid-3/issues/new?assignees=&labels=&template=feature_request.md&title=).
83
+
84
+ ## Roadmap
85
+
86
+ - View [components status](https://github.com/orgs/Vonage/projects/6)
87
+
88
+ - [What's on our plate](https://github.com/orgs/Vonage/projects/3/views/7)
89
+
90
+ - See the [open issues](https://github.com/vonage/vivid-3/issues) for a full list of proposed features (and known issues).
91
+
92
+ We publish a *next* release on every successful merge to main, so you never need to wait for a new stable version to make use of any updates.
93
+
94
+ ## Contributing
95
+
96
+ Please read [CONTRIBUTING.md](.github/CONTRIBUTING.md) for details on our code of conduct, and the process for submitting pull requests to us.
97
+
98
+ ## Versioning
99
+
100
+ We use [SemVer](http://semver.org/) for versioning. For the versions available, see the [npm page](https://www.npmjs.com/package/@vonage/vivid).
101
+
102
+ ## Authors
103
+
104
+ See also the list of [contributors](https://github.com/your/project/contributors) who participated in this project.
105
+
106
+ ## License
107
+
108
+ This project is licensed under the Apache 2.0 License - see the [LICENSE.md](LICENSE.md) file for details
109
+
110
+ <!-- ## Acknowledgments
111
+
112
+ - Hat tip to anyone whose code was used
113
+ - Inspiration
114
+ - etc -->
115
+
116
+ ## Built With
117
+
118
+ - [Fast](https://www.fast.design) - to extend element classes and compile code to native web components
119
+ - [Typescript](https://www.typescriptlang.org) - for ergonomic and type-safe code
120
+ - [Sass](https://sass-lang.com) - for styles authoring extensibility and consistency
121
+
122
+ ## Quickstart
123
+
124
+ Global content delivery networks can help quickly integrate content within html pages, fetching content from an URL, skipping local builds entirely.
125
+ Such practice is often used when working on POCs or reproduction environments.
126
+ Tools like [UNPKG](https://unpkg.com), [jsDeliver](https://www.jsdelivr.com), [Skypack](https://www.skypack.dev) etc' are bound to deliver any content registered in the npm registry.
127
+
128
+ The following snippet fully renders a Vivid button component
129
+
130
+ ```html
131
+ <!-- import spezia font -->
132
+ <link rel="stylesheet" href="https://unpkg.com/@vonage/vivid@next/styles/fonts/spezia.css">
133
+
134
+ <!-- import light theme style tokens -->
135
+ <link rel="stylesheet" href="https://unpkg.com/@vonage/vivid@next/styles/tokens/theme-light.css">
136
+
137
+ <!-- import Vivid button component -->
138
+ <script type="module" src="https://unpkg.com/@vonage/vivid@next/button/index.js"></script>
139
+
140
+ <!-- Part of the app (or a whole app) that contains vivid components -->
141
+ <div class="vvd-root">
142
+ <vwc-button label="Click me" appearance="filled" connotation="cta"></vwc-button>
143
+ </div>
144
+ ```
@@ -1,9 +1,7 @@
1
1
  import { F as FoundationElement, _ as __decorate, a as attr, b as __metadata, h as html, d as designSystem } from '../shared/index.js';
2
- import { s as styleInject } from '../shared/style-inject.es.js';
3
2
  import { c as classNames } from '../shared/class-names.js';
4
3
 
5
- var css_248z = ".control {\n display: flex;\n flex-direction: column;\n}\n\n::slotted(vwc-accordion-item:not(:only-of-type)) {\n border-bottom: 1px solid var(--vvd-color-neutral-30);\n}";
6
- styleInject(css_248z);
4
+ var css_248z = "/**\n * Do not edit directly\n * Generated on Thu, 03 Nov 2022 17:18:46 GMT\n */\n.base {\n display: flex;\n flex-direction: column;\n}\n\n::slotted(vwc-accordion-item:not(:only-of-type)) {\n border-bottom: 1px solid var(--vvd-color-neutral-200);\n}";
7
5
 
8
6
  class Accordion extends FoundationElement {
9
7
  constructor() {
@@ -12,12 +10,10 @@ class Accordion extends FoundationElement {
12
10
  this.multi = false;
13
11
  this.addEventListener('opened', this.handleOpened);
14
12
  }
15
-
16
13
  connectedCallback() {
17
14
  super.connectedCallback();
18
15
  this.accordionItems = this.children;
19
16
  }
20
-
21
17
  handleOpened(e) {
22
18
  if (!this.multi && this.accordionItems) {
23
19
  for (let i = 0; i < this.accordionItems.length; i++) {
@@ -27,7 +23,6 @@ class Accordion extends FoundationElement {
27
23
  }
28
24
  }
29
25
  }
30
-
31
26
  closeAll() {
32
27
  if (this.accordionItems) {
33
28
  for (let i = 0; i < this.accordionItems.length; i++) {
@@ -35,18 +30,14 @@ class Accordion extends FoundationElement {
35
30
  }
36
31
  }
37
32
  }
38
-
39
33
  }
40
-
41
34
  __decorate([attr({
42
35
  mode: 'boolean'
43
36
  }), __metadata("design:type", Object)], Accordion.prototype, "multi", void 0);
44
37
 
45
38
  let _2 = t => t,
46
- _t;
47
-
48
- const getClasses = _ => classNames('control');
49
-
39
+ _t;
40
+ const getClasses = _ => classNames('base');
50
41
  const AccordionTemplate = () => html(_t || (_t = _2`<div class="${0}">
51
42
  <slot></slot>
52
43
  </div>`), getClasses);
@@ -1,34 +1,34 @@
1
+ import '../icon/index.js';
2
+ import '../focus/index.js';
1
3
  import { F as FoundationElement, _ as __decorate, a as attr, b as __metadata, h as html, d as designSystem } from '../shared/index.js';
2
- import { s as styleInject } from '../shared/style-inject.es.js';
3
4
  import '../shared/web.dom-collections.iterator.js';
4
5
  import { A as AffixIconWithTrailing, a as affixIconTemplateFactory } from '../shared/affix.js';
5
6
  import { a as applyMixins } from '../shared/apply-mixins.js';
7
+ import { f as focusTemplateFactory } from '../shared/focus2.js';
6
8
  import { w as when } from '../shared/when.js';
7
9
  import { c as classNames } from '../shared/class-names.js';
8
- import '../icon/index.js';
9
10
  import '../shared/icon.js';
11
+ import '../shared/export.js';
12
+ import '../shared/iterators.js';
13
+ import '../shared/to-string.js';
10
14
  import '../shared/_has.js';
15
+ import '../shared/focus.js';
16
+ import '../shared/object-keys.js';
11
17
 
12
- var css_248z = "/*\n Do not edit directly\n Generated on Wed, 27 Apr 2022 11:58:36 GMT\n*/\n.body {\n font: 400 ultra-condensed 14px / 20px SpeziaWebVariable;\n letter-spacing: 0px;\n text-decoration: none;\n text-transform: none;\n padding: 8px 32px 24px 16px;\n}\n.icon:not(.icon-trailing) .body {\n padding-left: 48px;\n}\n\n.control {\n display: flex;\n flex-direction: column;\n}\n.control:not(.open) .toggle-close,\n.control:not(.open) .body {\n display: none;\n}\n.control.open .toggle-open {\n display: none;\n}\n.control.open .toggle-close {\n display: initial;\n}\n\n.header {\n padding: 0;\n margin: 0;\n}\n\n.button {\n font: 500 condensed 20px / 28px SpeziaWebVariable;\n letter-spacing: 0px;\n text-decoration: none;\n text-transform: none;\n position: relative;\n display: flex;\n width: 100%;\n align-items: center;\n padding: 16px;\n border: 0 none;\n background: transparent;\n cursor: pointer;\n}\n.button:hover {\n background: var(--vvd-color-neutral-10);\n}\n.button .heading-text {\n flex-grow: 1;\n margin-inline-end: auto;\n text-align: left;\n}\n.button .meta {\n font: 600 ultra-condensed 14px / 20px SpeziaWebVariable;\n letter-spacing: 0px;\n text-decoration: none;\n text-transform: none;\n overflow: hidden;\n max-width: 20%;\n flex-shrink: 0;\n color: var(--vvd-color-neutral-70);\n margin-inline-start: 1rem;\n text-align: end;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n.button .indicator {\n display: flex;\n}\n.button .indicator vwc-icon,\n.button .indicator slot[name=indicator i]::slotted(vwc-icon) {\n margin-inline-start: 16px;\n}\n.button .icon {\n margin-inline-end: 16px;\n}\n\n/* Icon */\n.icon-trailing .icon {\n order: 1;\n}";
13
- styleInject(css_248z);
18
+ var css_248z = "/**\n * Do not edit directly\n * Generated on Thu, 03 Nov 2022 17:18:46 GMT\n */\n.body {\n padding: 8px 32px 24px 16px;\n font: var(--vvd-typography-base);\n}\n.icon:not(.icon-trailing) .body {\n padding-left: 48px;\n}\n\n.base {\n display: flex;\n flex-direction: column;\n}\n.base:not(.open) .body {\n display: none;\n}\n\n.header {\n padding: 0;\n margin: 0;\n}\n\n.button {\n position: relative;\n display: flex;\n width: 100%;\n align-items: center;\n padding: 16px;\n border: 0 none;\n margin: 0;\n background-color: var(--_appearance-color-fill);\n box-shadow: inset 0 0 0 1px var(--_appearance-color-outline);\n color: var(--_appearance-color-text);\n cursor: pointer;\n font: var(--vvd-typography-heading-4);\n}\n.button {\n --_appearance-color-text: var(--_connotation-color-primary);\n --_appearance-color-fill: transparent;\n --_appearance-color-outline: transparent;\n}\n.button:where(:hover, .hover):where(:not(:disabled, .disabled)) {\n --_appearance-color-text: var(--_connotation-color-primary);\n --_appearance-color-fill: var(--_connotation-color-faint);\n --_appearance-color-outline: transparent;\n}\n.button:where(:active, .active):where(:not(:disabled, .disabled)) {\n --_appearance-color-text: var(--_connotation-color-primary);\n --_appearance-color-fill: var(--_connotation-color-soft);\n --_appearance-color-outline: transparent;\n}\n.button {\n --_connotation-color-primary: var(--vvd-color-canvas-text);\n --_connotation-color-faint: var(--vvd-color-neutral-50);\n --_connotation-color-soft: var(--vvd-color-neutral-100);\n}\n@supports selector(:focus-visible) {\n .button:focus {\n outline: none;\n }\n}\n@supports (user-select: none) {\n .button {\n user-select: none;\n }\n}\n.button .heading-text {\n flex-grow: 1;\n margin-inline-end: auto;\n text-align: left;\n}\n.button .meta {\n overflow: hidden;\n max-width: 20%;\n flex-shrink: 0;\n color: var(--vvd-color-neutral-600);\n font: var(--vvd-typography-base-bold);\n margin-inline-start: 16px;\n text-align: end;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n.button .indicator {\n display: flex;\n}\n.button .indicator vwc-icon,\n.button .indicator slot[name=indicator i]::slotted(vwc-icon) {\n margin-inline-start: 16px;\n}\n.button .icon {\n margin-inline-end: 16px;\n}\n\n/* Icon */\n.icon-trailing .icon {\n order: 1;\n}\n\n.button:not(:focus-visible) > .focus-indicator {\n display: none;\n}";
14
19
 
15
20
  class AccordionItem extends FoundationElement {
16
21
  constructor() {
17
22
  super(...arguments);
18
- this.heading = '';
19
23
  this.noIndicator = false;
20
- this.meta = '';
21
24
  this.open = false;
22
25
  }
23
-
24
26
  attributeChangedCallback(name, oldValue, newValue) {
25
27
  super.attributeChangedCallback(name, oldValue, newValue);
26
-
27
28
  if (name === 'open') {
28
29
  newValue === null ? this.emitEvent('closed') : this.emitEvent('opened');
29
30
  }
30
31
  }
31
-
32
32
  emitEvent(name) {
33
33
  const init = {
34
34
  bubbles: true,
@@ -37,47 +37,36 @@ class AccordionItem extends FoundationElement {
37
37
  const ev = new CustomEvent(name, init);
38
38
  this.dispatchEvent(ev);
39
39
  }
40
-
41
40
  }
42
-
43
- __decorate([attr({
44
- mode: 'fromView'
45
- }), __metadata("design:type", Object)], AccordionItem.prototype, "heading", void 0);
46
-
41
+ __decorate([attr, __metadata("design:type", String)], AccordionItem.prototype, "heading", void 0);
47
42
  __decorate([attr({
48
43
  attribute: 'heading-level'
49
44
  }), __metadata("design:type", Number)], AccordionItem.prototype, "headingLevel", void 0);
50
-
51
45
  __decorate([attr({
52
46
  mode: 'boolean',
53
47
  attribute: 'no-indicator'
54
48
  }), __metadata("design:type", Object)], AccordionItem.prototype, "noIndicator", void 0);
55
-
56
- __decorate([attr({
57
- mode: 'fromView'
58
- }), __metadata("design:type", Object)], AccordionItem.prototype, "meta", void 0);
59
-
49
+ __decorate([attr, __metadata("design:type", String)], AccordionItem.prototype, "meta", void 0);
60
50
  __decorate([attr({
61
51
  mode: 'boolean'
62
52
  }), __metadata("design:type", Object)], AccordionItem.prototype, "open", void 0);
63
-
64
53
  applyMixins(AccordionItem, AffixIconWithTrailing);
65
54
 
66
55
  let _ = t => t,
67
- _t,
68
- _t2,
69
- _t3,
70
- _t4,
71
- _t5;
56
+ _t,
57
+ _t2,
58
+ _t3,
59
+ _t4,
60
+ _t5,
61
+ _t6,
62
+ _t7;
72
63
  const PANEL = 'panel';
73
-
74
64
  const getClasses = ({
75
65
  open,
76
66
  iconTrailing,
77
67
  icon,
78
68
  noIndicator
79
- }) => classNames('control', ['open', open], ['icon', Boolean(icon)], ['icon-trailing', iconTrailing], ['no-indicator', noIndicator]);
80
-
69
+ }) => classNames('base', ['open', open], ['icon', Boolean(icon)], ['icon-trailing', iconTrailing], ['no-indicator', noIndicator]);
81
70
  const AccordionItemTemplate = context => html(_t || (_t = _`
82
71
  <div class="${0}">
83
72
  ${0}
@@ -86,7 +75,6 @@ const AccordionItemTemplate = context => html(_t || (_t = _`
86
75
  </div>
87
76
  </div>
88
77
  `), getClasses, x => renderPanelHeader(context, x.headingLevel), PANEL);
89
-
90
78
  const renderPanelHeader = (context, headingLevel) => {
91
79
  const header = headingLevel ? 'h' + headingLevel : 'h3';
92
80
  return html(_t2 || (_t2 = _`
@@ -95,13 +83,14 @@ const renderPanelHeader = (context, headingLevel) => {
95
83
  </${0}>
96
84
  `), header, renderHeaderButton(context), header);
97
85
  };
98
-
99
86
  const renderHeaderButton = context => {
100
87
  const affixIconTemplate = affixIconTemplateFactory(context);
88
+ const focusTemplate = focusTemplateFactory(context);
101
89
  return html(_t3 || (_t3 = _`
102
90
  <button class="button" id="header" @click=${0}
103
- ?aria-expanded=${0}
91
+ aria-expanded=${0}
104
92
  aria-controls="${0}">
93
+ ${0}
105
94
  ${0}
106
95
  <span class="heading-text">${0}</span>
107
96
  ${0}
@@ -109,16 +98,19 @@ const renderHeaderButton = context => {
109
98
  ${0}
110
99
  </span>
111
100
  </button>
112
- `), x => x.open = !x.open, x => x.open, PANEL, x => affixIconTemplate(x.icon), x => x.heading, when(x => x.meta, html(_t4 || (_t4 = _`<span class="meta">${0}</span>`), x => x.meta)), when(x => !x.noIndicator && !x.iconTrailing, html(_t5 || (_t5 = _`
113
- <vwc-icon class="toggle-open" type='chevron-down-solid'></vwc-icon>
114
- <vwc-icon class="toggle-close" type='chevron-up-solid'></vwc-icon>
115
- `))));
101
+ `), x => x.open = !x.open, x => x.open, PANEL, () => focusTemplate, x => affixIconTemplate(x.icon), x => x.heading, when(x => x.meta, html(_t4 || (_t4 = _`<span class="meta">${0}</span>`), x => x.meta)), when(x => !x.noIndicator && !x.iconTrailing, html(_t5 || (_t5 = _`
102
+ ${0}
103
+ ${0}
104
+ `), when(x => !x.open, html(_t6 || (_t6 = _`<vwc-icon type='chevron-down-solid'></vwc-icon>`))), when(x => x.open, html(_t7 || (_t7 = _`<vwc-icon type='chevron-up-solid'></vwc-icon>`))))));
116
105
  };
117
106
 
118
107
  const vividAccordionItem = AccordionItem.compose({
119
108
  baseName: 'accordion-item',
120
109
  template: AccordionItemTemplate,
121
- styles: css_248z
110
+ styles: css_248z,
111
+ shadowOptions: {
112
+ delegatesFocus: true
113
+ }
122
114
  });
123
115
  designSystem.register(vividAccordionItem());
124
116
 
@@ -0,0 +1,41 @@
1
+ import { F as FoundationElement, _ as __decorate, a as attr, b as __metadata, h as html, d as designSystem } from '../shared/index.js';
2
+ import '../shared/web.dom-collections.iterator.js';
3
+ import { c as classNames } from '../shared/class-names.js';
4
+ import '../shared/export.js';
5
+ import '../shared/object-keys.js';
6
+ import '../shared/iterators.js';
7
+
8
+ var css_248z = "/**\n * Do not edit directly\n * Generated on Thu, 03 Nov 2022 17:18:46 GMT\n */\n:host {\n display: inline-block;\n}\n\n.base {\n position: relative;\n display: flex;\n box-sizing: border-box;\n align-items: center;\n background-color: var(--_appearance-color-fill);\n color: var(--_appearance-color-text);\n inline-size: inherit;\n vertical-align: middle;\n}\n.base {\n --_appearance-color-text: var(--vvd-color-canvas-text);\n --_appearance-color-fill: var(--vvd-color-canvas);\n --_appearance-color-outline: var(--vvd-color-neutral-400);\n}\n.base.appearance-ghost {\n --_appearance-color-text: var(--_connotation-color-primary);\n --_appearance-color-fill: transparent;\n --_appearance-color-outline: transparent;\n}\n.base::before {\n position: absolute;\n z-index: 1;\n border-radius: inherit;\n box-shadow: inset 0 0 0 1px var(--_appearance-color-outline);\n content: \"\";\n inset: 0;\n pointer-events: none;\n}\n.base:not(.tight) {\n padding: 4px;\n column-gap: 4px;\n}\n\n/* Shape */\n.base:not(.shape-pill) {\n border-radius: 6px;\n}\n\n.base.shape-pill {\n border-radius: 24px;\n}\n\n/* Separator */\n::slotted(vwc-divider) {\n align-self: stretch;\n margin-block: 4px;\n}";
9
+
10
+ class ActionGroup extends FoundationElement {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.tight = false;
14
+ }
15
+ }
16
+ __decorate([attr, __metadata("design:type", String)], ActionGroup.prototype, "shape", void 0);
17
+ __decorate([attr, __metadata("design:type", String)], ActionGroup.prototype, "appearance", void 0);
18
+ __decorate([attr({
19
+ mode: 'boolean'
20
+ }), __metadata("design:type", Object)], ActionGroup.prototype, "tight", void 0);
21
+
22
+ let _ = t => t,
23
+ _t;
24
+ const getClasses = ({
25
+ appearance,
26
+ shape,
27
+ tight
28
+ }) => classNames('base', [`appearance-${appearance}`, Boolean(appearance)], [`shape-${shape}`, Boolean(shape)], ['tight', tight]);
29
+ const ActionGroupTemplate = () => html(_t || (_t = _`
30
+ <div class="${0}">
31
+ <slot></slot>
32
+ </div>`), getClasses);
33
+
34
+ const vividActionGroup = ActionGroup.compose({
35
+ baseName: 'action-group',
36
+ template: ActionGroupTemplate,
37
+ styles: css_248z
38
+ });
39
+ designSystem.register(vividActionGroup());
40
+
41
+ export { vividActionGroup };
@@ -0,0 +1,60 @@
1
+ import '../icon/index.js';
2
+ import { F as FoundationElement, _ as __decorate, a as attr, b as __metadata, h as html, d as designSystem } from '../shared/index.js';
3
+ import { w as when } from '../shared/when.js';
4
+ import { c as classNames } from '../shared/class-names.js';
5
+ import '../shared/icon.js';
6
+ import '../shared/export.js';
7
+ import '../shared/iterators.js';
8
+ import '../shared/to-string.js';
9
+ import '../shared/_has.js';
10
+
11
+ var css_248z = "/**\n * Do not edit directly\n * Generated on Thu, 03 Nov 2022 17:18:46 GMT\n */\n.base {\n display: inline-flex;\n overflow: hidden;\n align-items: center;\n justify-content: center;\n background-color: var(--_appearance-color-fill);\n block-size: var(--_density);\n box-shadow: inset 0 0 0 1px var(--_appearance-color-outline);\n color: var(--_appearance-color-text);\n inline-size: var(--_density);\n vertical-align: middle;\n}\n.base.connotation-cta {\n --_connotation-color-primary: var(--vvd-color-cta-500);\n --_connotation-color-primary-text: var(--vvd-color-canvas);\n --_connotation-color-firm: var(--vvd-color-cta-600);\n}\n.base:not(.connotation-cta) {\n --_connotation-color-primary: var(--vvd-color-canvas-text);\n --_connotation-color-primary-text: var(--vvd-color-canvas);\n --_connotation-color-firm: var(--vvd-color-canvas-text);\n}\n.base {\n --_appearance-color-text: var(--_connotation-color-primary-text);\n --_appearance-color-fill: var(--_connotation-color-primary);\n --_appearance-color-outline: transparent;\n}\n.base.appearance-outlined {\n --_appearance-color-text: var(--_connotation-color-firm);\n --_appearance-color-fill: transparent;\n --_appearance-color-outline: var(--_connotation-color-firm);\n}\n.base.appearance-ghost {\n --_appearance-color-text: var(--_connotation-color-primary);\n --_appearance-color-fill: transparent;\n --_appearance-color-outline: transparent;\n}\n.base.density-condensed {\n --_density: calc(1px * (40 + 8 * clamp(-1, var(--vvd-size-density, 0), 1) - 8));\n}\n.base.density-condensed .initials {\n font: var(--vvd-typography-base-condensed-bold);\n}\n.base.density-condensed .icon {\n font-size: calc(calc(1px * (40 + 8 * clamp(-1, var(--vvd-size-density, 0), 1) - 8)) / 2);\n}\n.base.density-extended {\n --_density: calc(1px * (40 + 8 * clamp(-1, var(--vvd-size-density, 0), 1) + 8));\n}\n.base.density-extended .initials {\n font: var(--vvd-typography-heading-4);\n}\n.base.density-extended .icon {\n font-size: calc(calc(1px * (40 + 8 * clamp(-1, var(--vvd-size-density, 0), 1) + 8)) / 2);\n}\n.base:not(.density-condensed, .density-extended) {\n --_density: calc(1px * (40 + 8 * clamp(-1, var(--vvd-size-density, 0), 1)));\n}\n.base:not(.density-condensed, .density-extended) .initials {\n font: var(--vvd-typography-base-extended-bold);\n}\n.base:not(.density-condensed, .density-extended) .icon {\n font-size: calc(calc(1px * (40 + 8 * clamp(-1, var(--vvd-size-density, 0), 1))) / 2);\n}\n.base:not(.shape-pill) {\n border-radius: 6px;\n}\n.base.shape-pill {\n border-radius: 50%;\n}\n.base .initials {\n text-transform: uppercase;\n}\n.base ::slotted(*) {\n block-size: 100%;\n inline-size: 100%;\n object-fit: cover;\n}";
12
+
13
+ class Avatar extends FoundationElement {}
14
+ __decorate([attr, __metadata("design:type", String)], Avatar.prototype, "connotation", void 0);
15
+ __decorate([attr, __metadata("design:type", String)], Avatar.prototype, "shape", void 0);
16
+ __decorate([attr, __metadata("design:type", String)], Avatar.prototype, "appearance", void 0);
17
+ __decorate([attr, __metadata("design:type", String)], Avatar.prototype, "density", void 0);
18
+ __decorate([attr, __metadata("design:type", String)], Avatar.prototype, "icon", void 0);
19
+ __decorate([attr, __metadata("design:type", String)], Avatar.prototype, "name", void 0);
20
+
21
+ let _ = t => t,
22
+ _t,
23
+ _t2,
24
+ _t3;
25
+ const getClasses = ({
26
+ appearance,
27
+ connotation,
28
+ shape,
29
+ density
30
+ }) => classNames('base', [`connotation-${connotation}`, Boolean(connotation)], [`appearance-${appearance}`, Boolean(appearance)], [`shape-${shape}`, Boolean(shape)], [`density-${density}`, Boolean(density)]);
31
+ function renderIcon() {
32
+ return html(_t || (_t = _`
33
+ <span class="icon">
34
+ <vwc-icon type="${0}"></vwc-icon>
35
+ </span>
36
+ `), x => x.icon ? `${x.icon}` : 'user-line');
37
+ }
38
+ function renderInitials() {
39
+ return html(_t2 || (_t2 = _`
40
+ <span class="initials">${0}</span>
41
+ `), ({
42
+ name
43
+ }) => name.substring(0, 2));
44
+ }
45
+ const AvatarTemplate = () => html(_t3 || (_t3 = _`
46
+ <span class="${0}">
47
+ <slot>
48
+ ${0}
49
+ ${0}
50
+ </slot>
51
+ </span>`), getClasses, when(x => x.name, renderInitials()), when(x => !x.name, renderIcon()));
52
+
53
+ const vividAvatar = Avatar.compose({
54
+ baseName: 'avatar',
55
+ template: AvatarTemplate,
56
+ styles: css_248z
57
+ });
58
+ designSystem.register(vividAvatar());
59
+
60
+ export { vividAvatar };
package/badge/index.js CHANGED
@@ -1,50 +1,36 @@
1
1
  import '../icon/index.js';
2
2
  import { F as FoundationElement, _ as __decorate, a as attr, b as __metadata, h as html, d as designSystem } from '../shared/index.js';
3
- import '../shared/web.dom-collections.iterator.js';
4
3
  import { A as AffixIconWithTrailing, a as affixIconTemplateFactory } from '../shared/affix.js';
5
4
  import { a as applyMixins } from '../shared/apply-mixins.js';
6
- import { s as styleInject } from '../shared/style-inject.es.js';
7
5
  import { c as classNames } from '../shared/class-names.js';
8
6
  import '../shared/icon.js';
7
+ import '../shared/export.js';
8
+ import '../shared/iterators.js';
9
+ import '../shared/to-string.js';
9
10
  import '../shared/_has.js';
10
11
  import '../shared/when.js';
12
+ import '../shared/web.dom-collections.iterator.js';
13
+ import '../shared/object-keys.js';
11
14
 
12
- class Badge extends FoundationElement {
13
- constructor() {
14
- super(...arguments);
15
- this.text = '';
16
- }
17
-
18
- }
19
-
15
+ class Badge extends FoundationElement {}
20
16
  __decorate([attr, __metadata("design:type", String)], Badge.prototype, "connotation", void 0);
21
-
22
17
  __decorate([attr, __metadata("design:type", String)], Badge.prototype, "shape", void 0);
23
-
24
18
  __decorate([attr, __metadata("design:type", String)], Badge.prototype, "appearance", void 0);
25
-
26
- __decorate([attr, __metadata("design:type", String)], Badge.prototype, "size", void 0);
27
-
28
- __decorate([attr({
29
- mode: 'fromView'
30
- }), __metadata("design:type", Object)], Badge.prototype, "text", void 0);
31
-
19
+ __decorate([attr, __metadata("design:type", String)], Badge.prototype, "text", void 0);
32
20
  applyMixins(Badge, AffixIconWithTrailing);
33
21
 
34
- var css_248z = "/*\n Do not edit directly\n Generated on Wed, 27 Apr 2022 11:58:36 GMT\n*/\n.control {\n font: 600 ultra-condensed 12px / 16px SpeziaWebVariable;\n letter-spacing: 0px;\n text-decoration: none;\n text-transform: none;\n display: inline-flex;\n box-sizing: border-box;\n align-items: center;\n background-color: var(--_appearance-color-fill);\n box-shadow: inset 0 0 0 1px var(--_appearance-color-outline);\n color: var(--_appearance-color-text);\n column-gap: 8px;\n vertical-align: middle;\n}\n.control:not(.connotation-cta):not(.connotation-success):not(.connotation-alert):not(.connotation-warning):not(.connotation-info) {\n --connotation: var(--vvd-color-primary);\n --on-connotation: var(--vvd-color-on-primary);\n --connotation-basis: var(--vvd-color-neutral);\n --connotation-soft: var(--vvd-color-neutral-20);\n --connotation-contrast: var(--vvd-color-neutral-90);\n}\n\n.control.connotation-cta {\n --connotation: var(--vvd-color-cta);\n --on-connotation: var(--vvd-color-on-cta);\n --connotation-basis: var(--vvd-color-cta);\n --connotation-soft: var(--vvd-color-cta-20);\n --connotation-contrast: var(--vvd-color-cta-90);\n}\n\n.control.connotation-success {\n --connotation: var(--vvd-color-success);\n --on-connotation: var(--vvd-color-on-success);\n --connotation-basis: var(--vvd-color-success);\n --connotation-soft: var(--vvd-color-success-20);\n --connotation-contrast: var(--vvd-color-success-90);\n}\n\n.control.connotation-alert {\n --connotation: var(--vvd-color-alert);\n --on-connotation: var(--vvd-color-on-alert);\n --connotation-basis: var(--vvd-color-alert);\n --connotation-soft: var(--vvd-color-alert-20);\n --connotation-contrast: var(--vvd-color-alert-90);\n}\n\n.control.connotation-warning {\n --connotation: var(--vvd-color-warning);\n --on-connotation: var(--vvd-color-on-warning);\n --connotation-basis: var(--vvd-color-warning);\n --connotation-soft: var(--vvd-color-warning-20);\n --connotation-contrast: var(--vvd-color-warning-90);\n}\n\n.control.connotation-info {\n --connotation: var(--vvd-color-info);\n --on-connotation: var(--vvd-color-on-info);\n --connotation-basis: var(--vvd-color-info);\n --connotation-soft: var(--vvd-color-info-20);\n --connotation-contrast: var(--vvd-color-info-90);\n}\n\n.control {\n --_appearance-color-text: var(--on-connotation);\n --_appearance-color-fill: var(--connotation);\n --_appearance-color-outline: transaprent;\n}\n.control.appearance-duotone {\n --_appearance-color-text: var(--connotation-contrast);\n --_appearance-color-fill: transaprent;\n --_appearance-color-outline: var(--connotation-basis);\n}\n.control.appearance-subtle {\n --_appearance-color-text: var(--connotation-contrast);\n --_appearance-color-fill: var(--connotation-soft);\n --_appearance-color-outline: transaprent;\n}\n\n/* Size */\n.control:not(.size-base-small):not(.size-base-large) {\n block-size: 24px;\n padding-inline: 10px;\n}\n\n.control.size-base-small {\n block-size: 20px;\n padding-inline: 8px;\n}\n\n.control.size-base-large {\n block-size: 28px;\n padding-inline: 12px;\n}\n\n/* Shape */\n.control:not(.shape-pill) {\n border-radius: 4px;\n}\n\n.control.shape-pill {\n border-radius: 14px;\n}\n\n/* Icon */\n.icon-trailing .icon {\n order: 1;\n}";
35
- styleInject(css_248z);
22
+ var css_248z = "/**\n * Do not edit directly\n * Generated on Thu, 03 Nov 2022 17:18:46 GMT\n */\n.base {\n --_badge-block-size: calc(1px * (40 + 8 * clamp(-1, var(--vvd-size-density, 0), 1) - 20));\n display: inline-flex;\n box-sizing: border-box;\n align-items: center;\n background-color: var(--_appearance-color-fill);\n block-size: var(--_badge-block-size);\n box-shadow: inset 0 0 0 1px var(--_appearance-color-outline);\n color: var(--_appearance-color-text);\n column-gap: 8px;\n font: var(--vvd-typography-base-condensed-bold);\n padding-inline: 8px;\n vertical-align: middle;\n}\n.base.connotation-cta {\n --_connotation-color-primary: var(--vvd-color-cta-500);\n --_connotation-color-primary-text: var(--vvd-color-canvas);\n --_connotation-color-intermediate: var(--vvd-color-cta-500);\n --_connotation-color-soft: var(--vvd-color-cta-100);\n --_connotation-color-contrast: var(--vvd-color-cta-800);\n}\n.base.connotation-success {\n --_connotation-color-primary: var(--vvd-color-success-500);\n --_connotation-color-primary-text: var(--vvd-color-canvas);\n --_connotation-color-intermediate: var(--vvd-color-success-500);\n --_connotation-color-soft: var(--vvd-color-success-100);\n --_connotation-color-contrast: var(--vvd-color-success-800);\n}\n.base.connotation-alert {\n --_connotation-color-primary: var(--vvd-color-alert-500);\n --_connotation-color-primary-text: var(--vvd-color-canvas);\n --_connotation-color-intermediate: var(--vvd-color-alert-500);\n --_connotation-color-soft: var(--vvd-color-alert-100);\n --_connotation-color-contrast: var(--vvd-color-alert-800);\n}\n.base.connotation-warning {\n --_connotation-color-primary: var(--vvd-color-warning-500);\n --_connotation-color-primary-text: var(--vvd-color-canvas);\n --_connotation-color-intermediate: var(--vvd-color-warning-500);\n --_connotation-color-soft: var(--vvd-color-warning-100);\n --_connotation-color-contrast: var(--vvd-color-warning-800);\n}\n.base.connotation-information {\n --_connotation-color-primary: var(--vvd-color-information-500);\n --_connotation-color-primary-text: var(--vvd-color-canvas);\n --_connotation-color-intermediate: var(--vvd-color-information-500);\n --_connotation-color-soft: var(--vvd-color-information-100);\n --_connotation-color-contrast: var(--vvd-color-information-800);\n}\n.base:not(.connotation-cta, .connotation-success, .connotation-alert, .connotation-warning, .connotation-information) {\n --_connotation-color-primary: var(--vvd-color-canvas-text);\n --_connotation-color-primary-text: var(--vvd-color-canvas);\n --_connotation-color-intermediate: var(--vvd-color-neutral-500);\n --_connotation-color-soft: var(--vvd-color-neutral-100);\n --_connotation-color-contrast: var(--vvd-color-neutral-800);\n}\n.base {\n --_appearance-color-text: var(--_connotation-color-primary-text);\n --_appearance-color-fill: var(--_connotation-color-primary);\n --_appearance-color-outline: transparent;\n}\n.base.appearance-duotone {\n --_appearance-color-text: var(--_connotation-color-contrast);\n --_appearance-color-fill: transparent;\n --_appearance-color-outline: var(--_connotation-color-intermediate);\n}\n.base.appearance-subtle {\n --_appearance-color-text: var(--_connotation-color-contrast);\n --_appearance-color-fill: var(--_connotation-color-soft);\n --_appearance-color-outline: transparent;\n}\n.base.icon-only {\n contain: size;\n padding-inline: 0;\n place-content: center;\n}\n@supports (aspect-ratio: 1) {\n .base.icon-only {\n aspect-ratio: 1;\n }\n}\n@supports not (aspect-ratio: 1) {\n .base.icon-only {\n inline-size: var(--_badge-block-size);\n }\n}\n\n/* Shape */\n.base:not(.shape-pill) {\n border-radius: 4px;\n}\n\n.base.shape-pill {\n border-radius: 14px;\n}\n\n/* Icon */\n.icon-trailing .icon {\n order: 1;\n}";
36
23
 
37
24
  let _ = t => t,
38
- _t;
39
-
25
+ _t;
40
26
  const getClasses = ({
41
27
  connotation,
42
28
  appearance,
43
29
  shape,
44
- size,
45
- iconTrailing
46
- }) => classNames('control', [`connotation-${connotation}`, Boolean(connotation)], [`appearance-${appearance}`, Boolean(appearance)], [`shape-${shape}`, Boolean(shape)], [`size-${size}`, Boolean(size)], ['icon-trailing', iconTrailing]);
47
-
30
+ iconTrailing,
31
+ text,
32
+ icon
33
+ }) => classNames('base', [`connotation-${connotation}`, Boolean(connotation)], [`appearance-${appearance}`, Boolean(appearance)], [`shape-${shape}`, Boolean(shape)], ['icon-trailing', iconTrailing], ['icon-only', !text && Boolean(icon)]);
48
34
  const badgeTemplate = context => {
49
35
  const affixIconTemplate = affixIconTemplateFactory(context);
50
36
  return html(_t || (_t = _`
@@ -54,11 +40,11 @@ const badgeTemplate = context => {
54
40
  </span>`), getClasses, x => affixIconTemplate(x.icon), x => x.text);
55
41
  };
56
42
 
57
- const VIVIDBadge = Badge.compose({
43
+ const vividBadge = Badge.compose({
58
44
  baseName: 'badge',
59
45
  template: badgeTemplate,
60
46
  styles: css_248z
61
47
  });
62
- designSystem.register(VIVIDBadge());
48
+ designSystem.register(vividBadge());
63
49
 
64
- export { VIVIDBadge };
50
+ export { vividBadge };