@crowdstrike/glide-core 0.29.1 → 0.30.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 (124) hide show
  1. package/dist/accordion.js +240 -1
  2. package/dist/accordion.styles.js +13 -7
  3. package/dist/button-group.button.js +143 -1
  4. package/dist/button-group.button.styles.js +43 -15
  5. package/dist/button-group.js +249 -1
  6. package/dist/button-group.styles.js +10 -5
  7. package/dist/button.js +206 -1
  8. package/dist/button.styles.js +12 -7
  9. package/dist/checkbox-group.js +479 -14
  10. package/dist/checkbox-group.styles.js +5 -2
  11. package/dist/checkbox.js +519 -32
  12. package/dist/checkbox.styles.js +10 -5
  13. package/dist/drawer.js +168 -1
  14. package/dist/drawer.styles.js +5 -2
  15. package/dist/dropdown.js +2423 -123
  16. package/dist/dropdown.option.js +536 -1
  17. package/dist/dropdown.option.styles.js +5 -2
  18. package/dist/dropdown.styles.js +14 -7
  19. package/dist/form-controls-layout.js +102 -1
  20. package/dist/form-controls-layout.styles.js +5 -2
  21. package/dist/icon-button.js +139 -1
  22. package/dist/icon-button.styles.js +19 -7
  23. package/dist/icons/checked.js +28 -1
  24. package/dist/icons/chevron.js +21 -1
  25. package/dist/icons/magnifying-glass.js +23 -1
  26. package/dist/icons/pencil.js +21 -1
  27. package/dist/icons/severity-critical.js +20 -1
  28. package/dist/icons/severity-informational.js +20 -1
  29. package/dist/icons/severity-medium.js +20 -1
  30. package/dist/icons/x.js +21 -1
  31. package/dist/inline-alert.js +118 -1
  32. package/dist/inline-alert.styles.js +5 -2
  33. package/dist/input.d.ts +8 -2
  34. package/dist/input.js +505 -41
  35. package/dist/input.styles.js +25 -4
  36. package/dist/label.js +303 -1
  37. package/dist/label.styles.js +11 -5
  38. package/dist/library/assert-slot.js +136 -1
  39. package/dist/library/expect-unhandled-rejection.js +14 -1
  40. package/dist/library/expect-window-error.js +26 -1
  41. package/dist/library/final.js +18 -1
  42. package/dist/library/form-control.js +1 -1
  43. package/dist/library/localize.js +10 -1
  44. package/dist/library/mouse.js +35 -1
  45. package/dist/library/on-resize.js +24 -1
  46. package/dist/library/required.js +35 -1
  47. package/dist/library/shadow-root-mode.js +4 -1
  48. package/dist/library/unique-id.js +3 -1
  49. package/dist/link.js +92 -1
  50. package/dist/link.styles.js +10 -5
  51. package/dist/menu.d.ts +3 -2
  52. package/dist/menu.js +1259 -1
  53. package/dist/menu.styles.js +34 -17
  54. package/dist/modal.d.ts +4 -0
  55. package/dist/modal.icon-button.js +60 -1
  56. package/dist/modal.icon-button.styles.js +5 -2
  57. package/dist/modal.js +473 -1
  58. package/dist/modal.styles.js +71 -22
  59. package/dist/option.d.ts +74 -0
  60. package/dist/option.js +498 -0
  61. package/dist/option.styles.js +140 -0
  62. package/dist/{menu.options.d.ts → options.d.ts} +5 -6
  63. package/dist/options.js +130 -0
  64. package/dist/options.styles.js +21 -0
  65. package/dist/popover.js +620 -1
  66. package/dist/popover.styles.js +11 -5
  67. package/dist/radio-group.js +624 -17
  68. package/dist/radio-group.radio.js +211 -1
  69. package/dist/radio-group.radio.styles.js +9 -4
  70. package/dist/radio-group.styles.js +5 -2
  71. package/dist/slider.js +1040 -61
  72. package/dist/slider.styles.js +9 -4
  73. package/dist/spinner.js +60 -1
  74. package/dist/spinner.styles.js +5 -2
  75. package/dist/split-button.js +116 -1
  76. package/dist/split-button.primary-button.js +100 -1
  77. package/dist/split-button.primary-button.styles.js +13 -6
  78. package/dist/split-button.primary-link.js +102 -1
  79. package/dist/split-button.secondary-button.d.ts +2 -3
  80. package/dist/split-button.secondary-button.js +121 -1
  81. package/dist/split-button.secondary-button.styles.js +12 -7
  82. package/dist/split-button.styles.js +9 -4
  83. package/dist/styles/focus-outline.js +9 -3
  84. package/dist/styles/fonts.css +6 -1
  85. package/dist/styles/opacity-and-scale-animation.js +6 -3
  86. package/dist/styles/skeleton.js +6 -3
  87. package/dist/styles/variables.css +410 -1
  88. package/dist/styles/visually-hidden.js +6 -3
  89. package/dist/tab.group.js +386 -1
  90. package/dist/tab.group.styles.js +5 -2
  91. package/dist/tab.js +133 -1
  92. package/dist/tab.panel.js +93 -1
  93. package/dist/tab.panel.styles.js +11 -5
  94. package/dist/tab.styles.js +9 -4
  95. package/dist/tag.js +207 -1
  96. package/dist/tag.styles.js +10 -5
  97. package/dist/textarea.js +353 -19
  98. package/dist/textarea.styles.js +23 -4
  99. package/dist/toast.js +130 -1
  100. package/dist/toast.toasts.js +248 -25
  101. package/dist/toast.toasts.styles.js +9 -4
  102. package/dist/toggle.js +178 -1
  103. package/dist/toggle.styles.js +25 -5
  104. package/dist/tooltip.container.d.ts +2 -0
  105. package/dist/tooltip.container.js +130 -1
  106. package/dist/tooltip.container.styles.js +18 -4
  107. package/dist/tooltip.d.ts +6 -0
  108. package/dist/tooltip.js +484 -1
  109. package/dist/tooltip.styles.js +21 -5
  110. package/dist/translations/en.js +36 -1
  111. package/dist/translations/fr.js +37 -1
  112. package/dist/translations/ja.js +37 -1
  113. package/package.json +8 -12
  114. package/dist/menu.button.d.ts +0 -42
  115. package/dist/menu.button.js +0 -1
  116. package/dist/menu.button.styles.js +0 -32
  117. package/dist/menu.link.d.ts +0 -44
  118. package/dist/menu.link.js +0 -1
  119. package/dist/menu.link.styles.js +0 -35
  120. package/dist/menu.options.js +0 -1
  121. package/dist/menu.options.styles.d.ts +0 -2
  122. package/dist/menu.options.styles.js +0 -20
  123. /package/dist/{menu.button.styles.d.ts → option.styles.d.ts} +0 -0
  124. /package/dist/{menu.link.styles.d.ts → options.styles.d.ts} +0 -0
@@ -1,6 +1,10 @@
1
- import{css}from"lit";import focusOutline from"./styles/focus-outline.js";export default[css`
2
- ${focusOutline(".component:focus-visible")}
3
- `,css`
1
+ import { css } from 'lit';
2
+ import focusOutline from './styles/focus-outline.js';
3
+ export default [
4
+ css `
5
+ ${focusOutline('.component:focus-visible')}
6
+ `,
7
+ css `
4
8
  /* When browser support improves, we can have nicer animations with https://caniuse.com/mdn-css_at-rules_starting-style */
5
9
  @keyframes backdrop-fade-in {
6
10
  from {
@@ -44,6 +48,22 @@ import{css}from"lit";import focusOutline from"./styles/focus-outline.js";export
44
48
  }
45
49
  }
46
50
 
51
+ &.small {
52
+ inline-size: 25rem;
53
+ }
54
+
55
+ &.medium {
56
+ inline-size: 37.5rem;
57
+ }
58
+
59
+ &.large {
60
+ inline-size: 56.25rem;
61
+ }
62
+
63
+ &.xlarge {
64
+ inline-size: 71.875rem;
65
+ }
66
+
47
67
  &:focus {
48
68
  outline: none;
49
69
  }
@@ -66,33 +86,43 @@ import{css}from"lit";import focusOutline from"./styles/focus-outline.js";export
66
86
  }
67
87
 
68
88
  .container {
89
+ display: grid;
90
+ grid-template-rows: auto minmax(0, 1fr) auto;
69
91
  max-block-size: 75vh;
70
- max-inline-size: 80vw;
71
- padding: var(--glide-core-spacing-base-md);
72
-
73
- &.small {
74
- inline-size: 22.5rem;
75
- }
92
+ }
76
93
 
77
- &.medium {
78
- inline-size: 35rem;
79
- }
94
+ .header {
95
+ background-color: var(
96
+ --glide-core-private-color-dialog-and-modal-surface-container
97
+ );
98
+ padding-block: var(--glide-core-spacing-base-md)
99
+ var(--glide-core-spacing-base-xs);
100
+ padding-inline: var(--glide-core-spacing-base-md);
101
+ transition: box-shadow var(--glide-core-duration-slow-01)
102
+ var(--glide-core-animation-linear);
80
103
 
81
- &.large {
82
- inline-size: 53.75rem;
83
- }
104
+ /* So the box shadow isn't covered up by the body content. */
105
+ z-index: 1;
84
106
 
85
- &.xlarge {
86
- inline-size: 69.375rem;
107
+ &.shadow {
108
+ box-shadow: 0 10px 8px -8px
109
+ var(--glide-core-color-effect-color-scroll-shadow);
87
110
  }
88
111
  }
89
112
 
90
- .header {
113
+ .label-and-actions {
91
114
  align-items: center;
92
115
  display: flex;
93
116
  justify-content: space-between;
94
117
  }
95
118
 
119
+ .description {
120
+ color: var(--glide-core-color-static-text-default);
121
+ font-size: var(--glide-core-typography-size-body-default);
122
+ font-weight: var(--glide-core-typography-weight-regular);
123
+ margin-block: 0;
124
+ }
125
+
96
126
  .label {
97
127
  align-items: center;
98
128
  color: var(--glide-core-color-static-text-default);
@@ -160,15 +190,33 @@ import{css}from"lit";import focusOutline from"./styles/focus-outline.js";export
160
190
  }
161
191
 
162
192
  .body {
163
- overflow: auto;
164
- padding-block: var(--glide-core-spacing-base-xs);
165
- padding-block-end: var(--glide-core-spacing-base-md);
193
+ overflow-y: auto;
194
+ padding-inline: var(--glide-core-spacing-base-md);
166
195
 
167
196
  &:focus {
168
197
  outline: none;
169
198
  }
170
199
  }
171
200
 
201
+ .footer {
202
+ background-color: var(
203
+ --glide-core-private-color-dialog-and-modal-surface-container
204
+ );
205
+ padding-block: var(--glide-core-spacing-base-xs)
206
+ var(--glide-core-spacing-base-md);
207
+ padding-inline: var(--glide-core-spacing-base-md);
208
+ transition: box-shadow var(--glide-core-duration-slow-01)
209
+ var(--glide-core-animation-linear);
210
+
211
+ /* So the box shadow isn't covered up by the body content. */
212
+ z-index: 1;
213
+
214
+ &.shadow {
215
+ box-shadow: 0 -10px 8px -8px
216
+ var(--glide-core-color-effect-color-scroll-shadow);
217
+ }
218
+ }
219
+
172
220
  .actions {
173
221
  align-items: center;
174
222
  display: flex;
@@ -189,4 +237,5 @@ import{css}from"lit";import focusOutline from"./styles/focus-outline.js";export
189
237
  display: flex;
190
238
  gap: var(--glide-core-spacing-base-xxs);
191
239
  }
192
- `];
240
+ `,
241
+ ];
@@ -0,0 +1,74 @@
1
+ import { LitElement } from 'lit';
2
+ import './options.js';
3
+ declare global {
4
+ interface HTMLElementTagNameMap {
5
+ 'glide-core-option': Option;
6
+ }
7
+ }
8
+ /**
9
+ * @attr {string} label
10
+ * @attr {string} [description]
11
+ * @attr {boolean} [disabled=false]
12
+ * @attr {string} [href]
13
+ *
14
+ * @readonly
15
+ * @attr {string} [id]
16
+ *
17
+ * @attr {'menuitem'|'option'} [role='menuitem']
18
+ * @attr {boolean} [selected=false]
19
+ *
20
+ * @readonly
21
+ * @attr {number} [tabindex=-1]
22
+ *
23
+ * @attr {string} [value='']
24
+ *
25
+ * @readonly
26
+ * @attr {string} [version]
27
+ *
28
+ * @slot {Element | Text} [content] - This is the unhappy path. It's the escape hatch where you can render arbitrary content and lay it out however you need to. If you go this route, `slot="icon"` and `slot="submenu"` will become unavailable. And the `label` and `description` attributes won't be rendered. The `label` attribute is still required. We'll show it in a tooltip when your content overflows. If you need a second line of text in the tooltip, provide you can provide it via the `description` attribute.
29
+ * @slot {Element} [icon]
30
+ * @slot {Menu} [submenu]
31
+ */
32
+ export default class Option extends LitElement {
33
+ #private;
34
+ static shadowRootOptions: ShadowRootInit;
35
+ static styles: import("lit").CSSResult[];
36
+ /**
37
+ * @default undefined
38
+ */
39
+ get label(): string | undefined;
40
+ set label(label: string);
41
+ /**
42
+ * @default undefined
43
+ */
44
+ get description(): string | undefined;
45
+ set description(description: string);
46
+ /**
47
+ * @default false
48
+ */
49
+ get disabled(): boolean;
50
+ set disabled(isDisabled: boolean);
51
+ href?: string;
52
+ readonly id: string;
53
+ get privateActive(): boolean;
54
+ set privateActive(isActive: boolean);
55
+ privateTooltipOpen: boolean;
56
+ role: 'menuitem' | 'option';
57
+ /**
58
+ * @default false
59
+ */
60
+ get selected(): boolean;
61
+ set selected(isSelected: boolean);
62
+ readonly tabIndex = -1;
63
+ value: string;
64
+ readonly version: string;
65
+ click(): void;
66
+ connectedCallback(): void;
67
+ render(): import("lit").TemplateResult;
68
+ updated(): void;
69
+ private hasContentSlot;
70
+ private hasIconSlot;
71
+ private hasSubMenuSlot;
72
+ private isContentSlotOverflow;
73
+ private isSubmenuOpen;
74
+ }