@statistikzh/leu 0.10.0 → 0.11.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (151) hide show
  1. package/.github/workflows/deploy-github-pages.yaml +2 -2
  2. package/.github/workflows/release-please.yml +1 -1
  3. package/CHANGELOG.md +15 -0
  4. package/dist/Accordion.d.ts +1 -1
  5. package/dist/Accordion.d.ts.map +1 -1
  6. package/dist/Accordion.js +22 -30
  7. package/dist/Breadcrumb.d.ts +1 -1
  8. package/dist/Breadcrumb.d.ts.map +1 -1
  9. package/dist/Breadcrumb.js +3 -8
  10. package/dist/Button.d.ts +1 -1
  11. package/dist/Button.js +3 -3
  12. package/dist/ButtonGroup.d.ts +1 -1
  13. package/dist/ButtonGroup.d.ts.map +1 -1
  14. package/dist/ButtonGroup.js +3 -8
  15. package/dist/Checkbox.d.ts +1 -1
  16. package/dist/Checkbox.js +2 -2
  17. package/dist/CheckboxGroup.d.ts +1 -1
  18. package/dist/CheckboxGroup.js +2 -2
  19. package/dist/Chip.d.ts +1 -1
  20. package/dist/Chip.d.ts.map +1 -1
  21. package/dist/Chip.js +3 -5
  22. package/dist/ChipGroup.d.ts +1 -1
  23. package/dist/ChipGroup.js +2 -2
  24. package/dist/ChipLink.js +1 -1
  25. package/dist/ChipRemovable.js +1 -1
  26. package/dist/ChipSelectable.js +1 -1
  27. package/dist/Dialog.d.ts +1 -1
  28. package/dist/Dialog.d.ts.map +1 -1
  29. package/dist/Dialog.js +3 -7
  30. package/dist/Dropdown.d.ts +1 -1
  31. package/dist/Dropdown.d.ts.map +1 -1
  32. package/dist/Dropdown.js +4 -9
  33. package/dist/Icon.d.ts +1 -1
  34. package/dist/Icon.js +2 -2
  35. package/dist/Input.d.ts +1 -1
  36. package/dist/Input.d.ts.map +1 -1
  37. package/dist/Input.js +3 -8
  38. package/dist/{LeuElement-6fbc0dee.d.ts → LeuElement-e092765a.d.ts} +1 -1
  39. package/dist/LeuElement-e092765a.d.ts.map +1 -0
  40. package/dist/{LeuElement-6fbc0dee.js → LeuElement-e092765a.js} +10 -2
  41. package/dist/Menu.d.ts +1 -1
  42. package/dist/Menu.d.ts.map +1 -1
  43. package/dist/Menu.js +3 -8
  44. package/dist/MenuItem.d.ts +1 -1
  45. package/dist/MenuItem.d.ts.map +1 -1
  46. package/dist/MenuItem.js +3 -8
  47. package/dist/Pagination.d.ts +1 -1
  48. package/dist/Pagination.js +3 -3
  49. package/dist/Popup.d.ts +1 -1
  50. package/dist/Popup.d.ts.map +1 -1
  51. package/dist/Popup.js +3 -8
  52. package/dist/Radio.d.ts +1 -1
  53. package/dist/Radio.js +2 -2
  54. package/dist/RadioGroup.d.ts +1 -1
  55. package/dist/RadioGroup.js +2 -2
  56. package/dist/Range.d.ts +60 -0
  57. package/dist/Range.d.ts.map +1 -0
  58. package/dist/Range.js +413 -0
  59. package/dist/ScrollTop.d.ts +1 -1
  60. package/dist/ScrollTop.js +3 -3
  61. package/dist/Select.d.ts +1 -1
  62. package/dist/Select.d.ts.map +1 -1
  63. package/dist/Select.js +4 -9
  64. package/dist/Spinner.d.ts +1 -1
  65. package/dist/Spinner.js +2 -2
  66. package/dist/Table.d.ts +1 -1
  67. package/dist/Table.js +3 -3
  68. package/dist/VisuallyHidden.d.ts +1 -1
  69. package/dist/VisuallyHidden.js +2 -2
  70. package/dist/{hasSlotController-04d0dfa2.d.ts → hasSlotController-d1f26756.d.ts} +1 -1
  71. package/dist/{hasSlotController-04d0dfa2.d.ts.map → hasSlotController-d1f26756.d.ts.map} +1 -1
  72. package/dist/{hasSlotController-04d0dfa2.js → hasSlotController-d1f26756.js} +1 -1
  73. package/dist/index.js +2 -2
  74. package/dist/leu-accordion.js +1 -1
  75. package/dist/leu-breadcrumb.js +1 -1
  76. package/dist/leu-button-group.js +1 -1
  77. package/dist/leu-button.js +2 -2
  78. package/dist/leu-checkbox-group.js +1 -1
  79. package/dist/leu-checkbox.js +1 -1
  80. package/dist/leu-chip-group.js +1 -1
  81. package/dist/leu-chip-link.js +1 -1
  82. package/dist/leu-chip-removable.js +1 -1
  83. package/dist/leu-chip-selectable.js +1 -1
  84. package/dist/leu-dialog.js +2 -2
  85. package/dist/leu-dropdown.js +2 -2
  86. package/dist/leu-icon.js +1 -1
  87. package/dist/leu-input.js +1 -1
  88. package/dist/leu-menu-item.js +1 -1
  89. package/dist/leu-menu.js +1 -1
  90. package/dist/leu-pagination.js +2 -2
  91. package/dist/leu-popup.js +1 -1
  92. package/dist/leu-radio-group.js +1 -1
  93. package/dist/leu-radio.js +1 -1
  94. package/dist/leu-range.d.ts +3 -0
  95. package/dist/leu-range.d.ts.map +1 -0
  96. package/dist/leu-range.js +7 -0
  97. package/dist/leu-scroll-top.js +2 -2
  98. package/dist/leu-select.js +2 -2
  99. package/dist/leu-spinner.js +1 -1
  100. package/dist/leu-table.js +2 -2
  101. package/dist/leu-visually-hidden.js +1 -1
  102. package/dist/vscode.html-custom-data.json +130 -110
  103. package/dist/vue/index.d.ts +194 -153
  104. package/dist/web-types.json +243 -199
  105. package/package.json +1 -1
  106. package/scripts/generate-component/templates/[Name].js +1 -1
  107. package/scripts/generate-component/templates/[name].css +0 -5
  108. package/src/components/accordion/Accordion.js +10 -6
  109. package/src/components/accordion/accordion.css +9 -22
  110. package/src/components/breadcrumb/Breadcrumb.js +1 -1
  111. package/src/components/breadcrumb/breadcrumb.css +0 -5
  112. package/src/components/button/Button.js +1 -1
  113. package/src/components/button-group/ButtonGroup.js +1 -1
  114. package/src/components/button-group/button-group.css +0 -5
  115. package/src/components/checkbox/Checkbox.js +1 -1
  116. package/src/components/checkbox/CheckboxGroup.js +1 -1
  117. package/src/components/chip/Chip.js +1 -1
  118. package/src/components/chip/ChipGroup.js +1 -1
  119. package/src/components/chip/chip.css +0 -2
  120. package/src/components/dialog/Dialog.js +1 -1
  121. package/src/components/dialog/dialog.css +0 -5
  122. package/src/components/dropdown/Dropdown.js +1 -1
  123. package/src/components/dropdown/dropdown.css +0 -5
  124. package/src/components/icon/Icon.js +1 -1
  125. package/src/components/input/Input.js +1 -1
  126. package/src/components/input/input.css +0 -5
  127. package/src/components/menu/Menu.js +1 -1
  128. package/src/components/menu/MenuItem.js +1 -1
  129. package/src/components/menu/menu-item.css +0 -5
  130. package/src/components/menu/menu.css +0 -5
  131. package/src/components/pagination/Pagination.js +1 -1
  132. package/src/components/popup/Popup.js +1 -1
  133. package/src/components/popup/popup.css +0 -5
  134. package/src/components/radio/Radio.js +1 -1
  135. package/src/components/radio/RadioGroup.js +1 -1
  136. package/src/components/range/Range.js +237 -0
  137. package/src/components/range/leu-range.js +5 -0
  138. package/src/components/range/range.css +180 -0
  139. package/src/components/range/stories/range-slider.stories.js +142 -0
  140. package/src/components/range/test/range-test.js +24 -0
  141. package/src/components/scroll-top/ScrollTop.js +1 -1
  142. package/src/components/select/Select.js +1 -1
  143. package/src/components/select/select.css +0 -5
  144. package/src/components/spinner/Spinner.js +1 -1
  145. package/src/components/table/Table.js +1 -1
  146. package/src/components/visually-hidden/VisuallyHidden.js +1 -1
  147. package/src/lib/LeuElement.js +3 -0
  148. package/src/styles/common-styles.css +5 -0
  149. package/src/styles/style.stories.js +1 -0
  150. package/web-dev-server.config.mjs +1 -0
  151. package/dist/LeuElement-6fbc0dee.d.ts.map +0 -1
@@ -0,0 +1,180 @@
1
+ :host {
2
+ --range-color: var(--leu-color-black-40);
3
+ --range-color-disabled: var(--leu-color-black-20);
4
+ --range-color-focus: var(--leu-color-func-cyan);
5
+
6
+ --range-track-background-color: var(--leu-color-black-10);
7
+ --range-track-height: 4px;
8
+ --range-track-radius: var(--range-track-height);
9
+
10
+ --range-track-value-color: var(--leu-color-func-cyan);
11
+ --range-track-value-width: 0;
12
+ --range-track-value-min: 0;
13
+
14
+ --range-thumb-color: var(--leu-color-black-0);
15
+ --range-thumb-border-color: var(--range-color);
16
+ --range-thumb-hover-border-color: var(--leu-color-black-100);
17
+ --range-thumb-diameter: 32px;
18
+
19
+ --range-value-color: var(--leu-color-black-100);
20
+ --range-value-color-disabled: var(--range-color-disabled);
21
+
22
+ --range-font-regular: var(--leu-font-family-regular);
23
+ --range-font-black: var(--leu-font-family-black);
24
+
25
+ display: block;
26
+
27
+ font-family: var(--range-font-regular);
28
+ }
29
+
30
+ :host([disabled]) {
31
+ --range-track-background: var(--range-color-disabled);
32
+ --range-track-value-color: var(--range-color-disabled);
33
+ --range-thumb-border-color: var(--range-color-disabled);
34
+ --range-thumb-hover-border-color: var(--range-color-disabled);
35
+ --range-value-color: var(--range-value-color-disabled);
36
+ }
37
+
38
+ /*************************** */
39
+
40
+ .label {
41
+ display: inline-block;
42
+ margin-block-end: 0.5rem;
43
+ color: var(--leu-color-black-100);
44
+ font: var(--leu-t-regular-regular-font);
45
+ }
46
+
47
+ .outputs {
48
+ position: relative;
49
+ height: 1.5rem;
50
+ margin-block-end: 0.25rem;
51
+ }
52
+
53
+ .output {
54
+ position: absolute;
55
+
56
+ text-align: center;
57
+ font: var(--leu-t-tiny-black-font);
58
+ color: var(--range-value-color);
59
+
60
+ min-width: var(--range-thumb-diameter);
61
+
62
+ --_stop: calc(100% - var(--range-thumb-diameter));
63
+ --_start: 0%;
64
+
65
+ left: calc(var(--value) * (var(--_stop) - var(--_start)) + var(--_start));
66
+ transform: translateX(calc(-50% + var(--range-thumb-diameter) / 2));
67
+ }
68
+
69
+ .inputs {
70
+ position: relative;
71
+ }
72
+
73
+ .range {
74
+ appearance: none;
75
+ width: 100%;
76
+ height: var(--range-thumb-diameter);
77
+ padding: 0;
78
+ margin: 0;
79
+ background: transparent;
80
+
81
+ --_track-background: linear-gradient(
82
+ to right,
83
+ var(--range-track-background-color) calc(var(--low) * 100%),
84
+ var(--range-track-value-color) 0,
85
+ var(--range-track-value-color) calc(var(--high) * 100%),
86
+ var(--range-track-background-color) 0
87
+ );
88
+ }
89
+
90
+ .range--ghost {
91
+ position: absolute;
92
+ top: 0;
93
+ left: 0;
94
+ z-index: 1;
95
+ pointer-events: none;
96
+ }
97
+
98
+ .range:focus {
99
+ outline: none;
100
+ }
101
+
102
+ /* Thumb */
103
+
104
+ .range::-moz-range-thumb {
105
+ cursor: pointer;
106
+ background: var(--range-thumb-color);
107
+
108
+ border: 2px var(--range-thumb-border-color) solid;
109
+ border-radius: 50%;
110
+
111
+ height: var(--range-thumb-diameter);
112
+ width: var(--range-thumb-diameter);
113
+
114
+ pointer-events: all;
115
+ }
116
+
117
+ .range:disabled::-moz-range-thumb {
118
+ cursor: not-allowed;
119
+ }
120
+
121
+ .range:focus-visible::-moz-range-thumb {
122
+ outline: 2px solid var(--range-color-focus);
123
+ outline-offset: 2px;
124
+ }
125
+
126
+ .range::-moz-range-thumb:hover,
127
+ .range:focus-visible::-moz-range-thumb {
128
+ border-color: var(--range-thumb-hover-border-color);
129
+ }
130
+
131
+ .range::-webkit-slider-thumb {
132
+ appearance: none;
133
+ cursor: pointer;
134
+ background: var(--range-thumb-color);
135
+
136
+ border: 2px var(--range-thumb-border-color) solid;
137
+ border-radius: 50%;
138
+
139
+ height: var(--range-thumb-diameter);
140
+ width: var(--range-thumb-diameter);
141
+ margin-top: calc(var(--range-thumb-diameter) / -2 + 2px);
142
+
143
+ pointer-events: all;
144
+ }
145
+
146
+ .range:disabled::-webkit-slider-thumb {
147
+ cursor: not-allowed;
148
+ }
149
+
150
+ .range:focus::-webkit-slider-thumb {
151
+ outline: 2px solid var(--range-color-focus);
152
+ outline-offset: 2px;
153
+ }
154
+
155
+ .range:focus::-webkit-slider-thumb,
156
+ .range::-webkit-slider-thumb:hover {
157
+ border-color: var(--range-thumb-hover-border-color);
158
+ }
159
+
160
+ /* Track */
161
+
162
+ .range::-moz-range-track {
163
+ background: var(--_track-background);
164
+ border-radius: var(--range-track-radius);
165
+ height: var(--range-track-height);
166
+ }
167
+
168
+ .range--ghost::-moz-range-track {
169
+ background: transparent;
170
+ }
171
+
172
+ .range::-webkit-slider-runnable-track {
173
+ background: var(--_track-background);
174
+ border-radius: var(--range-track-radius);
175
+ height: var(--range-track-height);
176
+ }
177
+
178
+ .range--ghost::-webkit-slider-runnable-track {
179
+ background: transparent;
180
+ }
@@ -0,0 +1,142 @@
1
+ import { html } from "lit"
2
+ import { ifDefined } from "lit/directives/if-defined.js"
3
+
4
+ import "../leu-range.js"
5
+ import "../../input/leu-input.js"
6
+
7
+ /**
8
+ * @type {import("@storybook/web-components").Meta}
9
+ */
10
+ export default {
11
+ title: "Range",
12
+ component: "leu-range",
13
+ parameters: {
14
+ design: {
15
+ type: "figma",
16
+ url: "https://www.figma.com/file/d6Pv21UVUbnBs3AdcZijHmbN/KTZH-Design-System?type=design&node-id=17340-81936&mode=design",
17
+ },
18
+ },
19
+ args: {
20
+ label: "Bereich",
21
+ },
22
+ }
23
+
24
+ function Template({ label, disabled, value, min, max, step, multiple }) {
25
+ return html`
26
+ <leu-range
27
+ label=${label}
28
+ ?disabled=${disabled}
29
+ ?multiple=${multiple}
30
+ min=${ifDefined(min)}
31
+ max=${ifDefined(max)}
32
+ value=${ifDefined(value)}
33
+ step=${ifDefined(step)}
34
+ >
35
+ </leu-range>
36
+ `
37
+ }
38
+
39
+ export const Regular = Template.bind({})
40
+ Regular.args = {
41
+ min: 0,
42
+ max: 100,
43
+ value: "15",
44
+ }
45
+
46
+ export const Multiple = Template.bind({})
47
+ Multiple.args = {
48
+ min: 1965,
49
+ max: 2022,
50
+ value: "1965, 2022",
51
+ multiple: true,
52
+ }
53
+
54
+ export const Labeled = Template.bind({})
55
+ Labeled.args = {
56
+ label: "Wert auswählen",
57
+ min: 100000,
58
+ max: 200000,
59
+ }
60
+
61
+ export const Disabled = Template.bind({})
62
+ Disabled.args = {
63
+ label: "Wert auswählen",
64
+ min: 0,
65
+ max: 100,
66
+ disabled: true,
67
+ }
68
+
69
+ export const Step = Template.bind({})
70
+ Step.args = {
71
+ min: 5,
72
+ max: 123,
73
+ step: 13,
74
+ }
75
+
76
+ function CombinedTemplate({
77
+ label,
78
+ disabled,
79
+ value = "",
80
+ min,
81
+ max,
82
+ step,
83
+ multiple,
84
+ }) {
85
+ const values = value.split(",").map((v) => Number(v.trim()))
86
+ function handleInputInput() {
87
+ const inputs = document.querySelectorAll("leu-input")
88
+ const range = document.querySelector("leu-range")
89
+ range.value = [inputs[0].value, inputs[1].value]
90
+ }
91
+ return html`
92
+ <leu-range
93
+ label=${label}
94
+ ?disabled=${disabled}
95
+ ?multiple=${multiple}
96
+ min=${ifDefined(min)}
97
+ max=${ifDefined(max)}
98
+ value=${ifDefined(value)}
99
+ step=${ifDefined(step)}
100
+ @input=${(e) => {
101
+ const inputs = document.querySelectorAll("leu-input")
102
+ const valueList = e.target.valueAsArray
103
+
104
+ inputs[0].value = valueList[0]
105
+ inputs[1].value = valueList[1]
106
+ }}
107
+ >
108
+ </leu-range>
109
+ <div style="display: flex; gap: 1rem;">
110
+ <leu-input
111
+ label="Von"
112
+ ?disabled=${disabled}
113
+ type="number"
114
+ min=${ifDefined(min)}
115
+ max=${ifDefined(max)}
116
+ value=${ifDefined(values[0])}
117
+ step=${ifDefined(step)}
118
+ size="small"
119
+ @input=${handleInputInput}
120
+ ></leu-input>
121
+ <leu-input
122
+ label="Von"
123
+ ?disabled=${disabled}
124
+ type="number"
125
+ min=${ifDefined(min)}
126
+ max=${ifDefined(max)}
127
+ value=${ifDefined(values[1])}
128
+ step=${ifDefined(step)}
129
+ size="small"
130
+ @input=${handleInputInput}
131
+ ></leu-input>
132
+ </div>
133
+ `
134
+ }
135
+
136
+ export const Combined = CombinedTemplate.bind({})
137
+ Combined.args = {
138
+ min: 1965,
139
+ max: 2022,
140
+ value: "1965, 2022",
141
+ multiple: true,
142
+ }
@@ -0,0 +1,24 @@
1
+ import { html } from "lit"
2
+ import { fixture, expect } from "@open-wc/testing"
3
+
4
+ import "../leu-range.js"
5
+
6
+ async function defaultFixture() {
7
+ return fixture(html`
8
+ <leu-range label="Test Label" min="0" max="100"> </leu-range>
9
+ `)
10
+ }
11
+
12
+ describe("LeuRange", () => {
13
+ it("is a defined element", async () => {
14
+ const el = await customElements.get("leu-range")
15
+
16
+ await expect(el).not.to.be.undefined
17
+ })
18
+
19
+ it("passes the a11y audit", async () => {
20
+ const el = await defaultFixture()
21
+
22
+ await expect(el).shadowDom.to.be.accessible()
23
+ })
24
+ })
@@ -19,7 +19,7 @@ export class LeuScrollTop extends LeuElement {
19
19
  "leu-icon": LeuIcon,
20
20
  }
21
21
 
22
- static styles = styles
22
+ static styles = [LeuElement.styles, styles]
23
23
 
24
24
  static properties = {
25
25
  _showButton: { state: true },
@@ -40,7 +40,7 @@ export class LeuSelect extends LeuElement {
40
40
  "leu-popup": LeuPopup,
41
41
  }
42
42
 
43
- static styles = styles
43
+ static styles = [LeuElement.styles, styles]
44
44
 
45
45
  static get properties() {
46
46
  return {
@@ -1,8 +1,3 @@
1
- :host,
2
- :host * {
3
- box-sizing: border-box;
4
- }
5
-
6
1
  :host {
7
2
  --select-color: var(--leu-color-black-100);
8
3
  --select-color-disabled: var(--leu-color-black-20);
@@ -9,7 +9,7 @@ import styles from "./spinner.css"
9
9
  * @cssprop --leu-spinner-size - The size of the spinner.
10
10
  */
11
11
  export class LeuSpinner extends LeuElement {
12
- static styles = styles
12
+ static styles = [LeuElement.styles, styles]
13
13
 
14
14
  render() {
15
15
  return html`
@@ -19,7 +19,7 @@ export class LeuTable extends LeuElement {
19
19
  "leu-pagination": LeuPagination,
20
20
  }
21
21
 
22
- static styles = styles
22
+ static styles = [LeuElement.styles, styles]
23
23
 
24
24
  static properties = {
25
25
  columns: { type: Array },
@@ -9,7 +9,7 @@ import styles from "./visually-hidden.css"
9
9
  * @tagname leu-visually-hidden
10
10
  */
11
11
  export class LeuVisuallyHidden extends LeuElement {
12
- static styles = styles
12
+ static styles = [LeuElement.styles, styles]
13
13
 
14
14
  render() {
15
15
  return html`<slot></slot>`
@@ -1,10 +1,13 @@
1
1
  import { LitElement } from "lit"
2
+ import commonStyles from "../styles/common-styles.css"
2
3
 
3
4
  export class LeuElement extends LitElement {
4
5
  static version = __LEU_VERSION__
5
6
 
6
7
  static dependencies = {}
7
8
 
9
+ static styles = commonStyles
10
+
8
11
  static define(name, constructor = this, options = {}) {
9
12
  Object.entries(this.dependencies).forEach(([n, c]) => c.define(n))
10
13
 
@@ -0,0 +1,5 @@
1
+ :host,
2
+ :host * {
3
+ box-sizing: border-box;
4
+ font-feature-settings: var(--leu-t-font-feature-settings);
5
+ }
@@ -17,6 +17,7 @@ function Template() {
17
17
 
18
18
  background-color: var(--leu-color-black-5);
19
19
  font-family: var(--leu-font-family-regular);
20
+ font-feature-settings: var(--leu-t-font-feature-settings);
20
21
  }
21
22
 
22
23
  .container div {
@@ -13,6 +13,7 @@ export default /** @type {import('@web/dev-server').DevServerConfig} */ ({
13
13
  mimeTypes: {
14
14
  "**/custom-elements.json": "js",
15
15
  "src/components/**/*.css": "js",
16
+ "src/styles/common-styles.css": "js",
16
17
  },
17
18
  plugins: [...plugins, json()],
18
19
  })
@@ -1 +0,0 @@
1
- {"version":3,"file":"LeuElement-6fbc0dee.d.ts","sourceRoot":"","sources":["LeuElement-6fbc0dee.js"],"names":[],"mappings":"AA+BA;IACE,8EAcC;CACF;AA7CD,sEAaC;2BAf0B,KAAK"}