draft-components 2.11.0 → 3.0.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 (81) hide show
  1. package/css/draft-components-utilities.css +6 -7
  2. package/css/draft-components-variables.css +437 -0
  3. package/css/draft-components.css +1199 -617
  4. package/dist/components/alert/alert.css +163 -0
  5. package/dist/components/avatar/avatar.css +91 -0
  6. package/dist/components/avatar/avatar.js +3 -1
  7. package/dist/components/badge/badge.css +28 -0
  8. package/dist/components/breadcrumbs/breadcrumbs.css +72 -0
  9. package/dist/components/button/button.css +241 -0
  10. package/dist/components/button/button.js +3 -1
  11. package/dist/components/button/icon-button.js +1 -1
  12. package/dist/components/button-group/button-group.css +27 -0
  13. package/dist/components/caption/caption.css +36 -0
  14. package/dist/components/checkbox/checkbox.css +90 -0
  15. package/dist/components/checkbox/checkbox.js +3 -1
  16. package/dist/components/color-picker/color-picker.css +86 -0
  17. package/dist/components/date-picker/calendar-grid.js +2 -2
  18. package/dist/components/date-picker/date-helpers.js +3 -3
  19. package/dist/components/date-picker/date-picker.css +203 -0
  20. package/dist/components/date-picker/date-range.js +2 -2
  21. package/dist/components/date-picker/parse-min-max-props.js +3 -3
  22. package/dist/components/date-picker-popover/date-picker-popover.css +8 -0
  23. package/dist/components/date-range-picker-popover/date-range-picker-popover.css +73 -0
  24. package/dist/components/date-range-picker-popover/helpers.js +2 -2
  25. package/dist/components/dialog/dialog.css +173 -0
  26. package/dist/components/empty-state/empty-state.css +52 -0
  27. package/dist/components/file-picker/file-picker.css +74 -0
  28. package/dist/components/filter-buttons/filter-buttons.css +60 -0
  29. package/dist/components/filter-buttons/filter-buttons.js +2 -2
  30. package/dist/components/filtered-search/filter-item.css +30 -0
  31. package/dist/components/filtered-search/filter-operator-select.css +6 -0
  32. package/dist/components/filtered-search/filter-token.css +63 -0
  33. package/dist/components/filtered-search/filter-value-list.css +17 -0
  34. package/dist/components/filtered-search/filtered-search.css +284 -0
  35. package/dist/components/filtered-search/string-filter-input.css +12 -0
  36. package/dist/components/filtered-search/string-filter-item.js +4 -2
  37. package/dist/components/filtered-search/string-set-filter-item.js +3 -1
  38. package/dist/components/form-field/form-field.css +21 -0
  39. package/dist/components/form-field/form-field.js +3 -1
  40. package/dist/components/label/label.css +23 -0
  41. package/dist/components/menu/menu.css +87 -0
  42. package/dist/components/menu/menu.d.ts +4 -4
  43. package/dist/components/menu/menu.js +4 -4
  44. package/dist/components/nav-list/nav-list-item.js +1 -1
  45. package/dist/components/nav-list/nav-list.css +89 -0
  46. package/dist/components/password-input/password-input.css +49 -0
  47. package/dist/components/popover/popover.css +98 -0
  48. package/dist/components/popover/popover.js +3 -3
  49. package/dist/components/positioner/calc-position.js +4 -4
  50. package/dist/components/radio/radio.css +88 -0
  51. package/dist/components/segmented-control/segmented-control.css +113 -0
  52. package/dist/components/select/select.css +121 -0
  53. package/dist/components/selection-control/selection-control.css +36 -0
  54. package/dist/components/selection-control/selection-control.js +3 -1
  55. package/dist/components/slide-over/slide-over-body.css +7 -0
  56. package/dist/components/slide-over/slide-over-header.css +29 -0
  57. package/dist/components/slide-over/slide-over-header.js +5 -1
  58. package/dist/components/slide-over/slide-over.css +85 -0
  59. package/dist/components/slider/get-offset-relative-to-thumb.js +5 -5
  60. package/dist/components/slider/range-slider.d.ts +20 -20
  61. package/dist/components/slider/slider-thumb.d.ts +14 -14
  62. package/dist/components/slider/slider-track.js +7 -7
  63. package/dist/components/slider/slider.css +261 -0
  64. package/dist/components/slider/slider.d.ts +16 -16
  65. package/dist/components/spinner/spinner.css +42 -0
  66. package/dist/components/spinner/spinner.js +1 -1
  67. package/dist/components/switch/switch.css +123 -0
  68. package/dist/components/table/table-head-cell.js +1 -1
  69. package/dist/components/table/table.css +176 -0
  70. package/dist/components/tabs/tab.js +1 -1
  71. package/dist/components/tabs/tabs.css +94 -0
  72. package/dist/components/tag/tag.css +390 -0
  73. package/dist/components/text-input/text-input.css +146 -0
  74. package/dist/components/textarea/textarea.css +82 -0
  75. package/dist/components/toast/toast.css +154 -0
  76. package/dist/components/toaster/toaster.css +95 -0
  77. package/dist/components/toaster/toaster.js +3 -3
  78. package/dist/components/tooltip/tooltip.css +34 -0
  79. package/dist/hooks/use-mount-transition.js +2 -2
  80. package/package.json +16 -11
  81. package/css/draft-components.dark.css +0 -609
@@ -0,0 +1,98 @@
1
+ .dc-popover {
2
+ --dc-popover-text-color: var(--dc-primary-text-color);
3
+ --dc-popover-transition-duration: 100ms;
4
+ --dc-popover-bg: white;
5
+ --dc-popover-shadow:
6
+ 0 0 0 1px rgb(var(--dc-black-rgb) / 7.5%),
7
+ 0 -1px 0 0 rgb(var(--dc-black-rgb) / 5%),
8
+ var(--dc-shadow-lg);
9
+
10
+ top: 0;
11
+ left: 0;
12
+ z-index: var(--dc-overlay-z-index);
13
+ box-sizing: border-box;
14
+ padding: 1px;
15
+ color-scheme: light;
16
+ }
17
+
18
+ .dc-popover-modal {
19
+ box-sizing: border-box;
20
+ max-width: 448px;
21
+ padding: 12px 16px;
22
+ font: var(--dc-text-sm);
23
+ color: var(--dc-popover-text-color);
24
+ background: var(--dc-popover-bg);
25
+ border-radius: 8px;
26
+ box-shadow: var(--dc-popover-shadow);
27
+ }
28
+
29
+ .dc-popover_closed .dc-popover-modal {
30
+ opacity: 0;
31
+ transition: var(--dc-popover-transition-duration) ease;
32
+ transition-property: opacity, transform;
33
+ transform: scale(0.95);
34
+ }
35
+
36
+ .dc-popover_opened .dc-popover-modal {
37
+ opacity: 1;
38
+ transform: scale(1);
39
+ }
40
+
41
+ .dc-popover[data-position="top-start"] .dc-popover-modal {
42
+ transform-origin: bottom left;
43
+ }
44
+
45
+ .dc-popover[data-position="top-center"] .dc-popover-modal {
46
+ transform-origin: bottom center;
47
+ }
48
+
49
+ .dc-popover[data-position="top-right"] .dc-popover-modal {
50
+ transform-origin: bottom left;
51
+ }
52
+
53
+ .dc-popover[data-position="right-start"] .dc-popover-modal {
54
+ transform-origin: left top;
55
+ }
56
+
57
+ .dc-popover[data-position="right-center"] .dc-popover-modal {
58
+ transform-origin: left center;
59
+ }
60
+
61
+ .dc-popover[data-position="right-right"] .dc-popover-modal {
62
+ transform-origin: left bottom;
63
+ }
64
+
65
+ .dc-popover[data-position="bottom-start"] .dc-popover-modal {
66
+ transform-origin: top left;
67
+ }
68
+
69
+ .dc-popover[data-position="bottom-center"] .dc-popover-modal {
70
+ transform-origin: top center;
71
+ }
72
+
73
+ .dc-popover[data-position="bottom-right"] .dc-popover-modal {
74
+ transform-origin: top left;
75
+ }
76
+
77
+ .dc-popover[data-position="left-start"] .dc-popover-modal {
78
+ transform-origin: right top;
79
+ }
80
+
81
+ .dc-popover[data-position="left-center"] .dc-popover-modal {
82
+ transform-origin: right center;
83
+ }
84
+
85
+ .dc-popover[data-position="left-right"] .dc-popover-modal {
86
+ transform-origin: right bottom;
87
+ }
88
+
89
+ .dark .dc-popover,
90
+ .dark.dc-popover {
91
+ --dc-popover-border-color: var(--dc-gray-700);
92
+ --dc-popover-bg: var(--dc-gray-800);
93
+ --dc-popover-shadow:
94
+ 0 0 0 1px var(--dc-gray-700),
95
+ var(--dc-shadow-lg);
96
+
97
+ color-scheme: dark;
98
+ }
@@ -42,9 +42,9 @@ export const Popover = forwardRef(function Popover({ shouldTrapFocus = true, sho
42
42
  const target = event.target;
43
43
  const anchor = anchorRef.current;
44
44
  const content = contentRef.current;
45
- if (target instanceof Node &&
46
- !anchor?.contains(target) &&
47
- !content?.contains(target)) {
45
+ if (target instanceof Node
46
+ && !anchor?.contains(target)
47
+ && !content?.contains(target)) {
48
48
  closePopover();
49
49
  }
50
50
  }, { isEnabled: isOpen });
@@ -1,8 +1,8 @@
1
1
  export function calcPosition({ placement, alignment, anchorRect, contentRect, viewportWidth, viewportHeight, scrollX, scrollY, anchorGap, viewportGap, }) {
2
2
  const maxWidth = viewportWidth - (2 * viewportGap);
3
3
  const maxSideWidth = Math.max(anchorRect.left - anchorGap - viewportGap, viewportWidth - anchorRect.right - anchorGap - viewportGap);
4
- if ((placement === 'left' || placement === 'right') &&
5
- contentRect.width >= maxSideWidth) {
4
+ if ((placement === 'left' || placement === 'right')
5
+ && contentRect.width >= maxSideWidth) {
6
6
  placement = 'bottom';
7
7
  }
8
8
  let x;
@@ -102,8 +102,8 @@ export function getYAxisOffset({ placement, anchorGap, scrollY, anchorY, viewpor
102
102
  }
103
103
  else {
104
104
  y = bottom;
105
- if (y + contentHeight > scrollY + viewportHeight &&
106
- anchorY > anchorBottom) {
105
+ if (y + contentHeight > scrollY + viewportHeight
106
+ && anchorY > anchorBottom) {
107
107
  y = top;
108
108
  placement = placement === 'bottom' ? 'top' : 'left';
109
109
  }
@@ -0,0 +1,88 @@
1
+ .dc-radio {
2
+ --dc-radio-size: 20px;
3
+ --dc-radio-color-bg: var(--dc-control-bg);
4
+ --dc-radio-color-bg-checked: var(--dc-control-primary-color);
5
+ --dc-radio-color-border: var(--dc-control-border-color);
6
+ --dc-radio-color-border-checked: var(--dc-control-primary-color);
7
+ --dc-radio-color-icon: var(--dc-control-on-primary-color);
8
+ --dc-radio-color-focus-ring: var(--dc-focus-ring-color);
9
+
10
+ position: relative;
11
+ display: inline-block;
12
+ flex-shrink: 0;
13
+ width: var(--dc-radio-size);
14
+ height: var(--dc-radio-size);
15
+ text-align: left;
16
+ color-scheme: light;
17
+ }
18
+
19
+ .dc-radio__input {
20
+ position: absolute;
21
+ width: 1px;
22
+ height: 1px;
23
+ padding: 0;
24
+ margin: -1px;
25
+ overflow: hidden;
26
+ clip: rect(0, 0, 0, 0);
27
+ white-space: nowrap;
28
+ border: 0;
29
+ }
30
+
31
+ .dc-radio__check {
32
+ position: absolute;
33
+ top: 0;
34
+ left: 0;
35
+ box-sizing: border-box;
36
+ display: inline-block;
37
+ width: var(--dc-radio-size);
38
+ height: var(--dc-radio-size);
39
+ vertical-align: middle;
40
+ cursor: pointer;
41
+ background: var(--dc-radio-color-bg);
42
+ border: 1px solid var(--dc-radio-color-border);
43
+ border-radius: 50%;
44
+ transition: opacity 0.2s;
45
+ }
46
+
47
+ .dc-radio__icon {
48
+ display: none;
49
+ width: 100%;
50
+ height: 100%;
51
+ color: var(--dc-radio-color-icon);
52
+ }
53
+
54
+ .dc-radio__input:checked + .dc-radio__check {
55
+ background: var(--dc-radio-color-bg-checked);
56
+ border-color: var(--dc-radio-color-border-checked);
57
+ }
58
+
59
+ .dc-radio__input:checked + .dc-radio__check .dc-radio__icon {
60
+ display: initial;
61
+ }
62
+
63
+ .dc-radio__input:disabled + .dc-radio__check {
64
+ cursor: default;
65
+ opacity: var(--dc-disabled-state-opacity);
66
+ }
67
+
68
+ .dc-radio__input:focus {
69
+ outline: none;
70
+ }
71
+
72
+ .dc-radio__input:focus + .dc-radio__check::after {
73
+ position: absolute;
74
+ inset: -3px;
75
+ pointer-events: none;
76
+ content: "";
77
+ border-radius: 50%;
78
+ box-shadow: 0 0 0 3px var(--dc-radio-color-focus-ring);
79
+ }
80
+
81
+ .dc-radio__input:focus:not(:focus-visible) + .dc-radio__check::after {
82
+ content: none;
83
+ }
84
+
85
+ .dark .dc-radio,
86
+ .dark.dc-radio {
87
+ color-scheme: dark;
88
+ }
@@ -0,0 +1,113 @@
1
+ .dc-segmented {
2
+ --dc-segmented-border-color: var(--dc-control-border-color);
3
+ --dc-segmented-bg: var(--dc-bg-transparent-1);
4
+ --dc-segmented-delimiter-color: var(--dc-border-color-transparent-3);
5
+ --dc-segmented-button-height: 36px;
6
+ --dc-segmented-button-padding-x: 16px;
7
+ --dc-segmented-button-radius: 9px;
8
+ --dc-segmented-button-text-color: var(--dc-primary-text-color);
9
+ --dc-segmented-button-border-color: transparent;
10
+ --dc-segmented-button-border-color-focus: var(--dc-blue-600);
11
+ --dc-segmented-button-border-color-selected: var(--dc-gray-500);
12
+ --dc-segmented-button-bg: none;
13
+ --dc-segmented-button-bg-selected: var(--dc-white);
14
+ --dc-segmented-button-focus-ring-color: var(--dc-focus-ring-color);
15
+
16
+ display: inline-flex;
17
+ flex-shrink: 0;
18
+ padding: 0;
19
+ margin: 0;
20
+ font: 14px/1 var(--dc-primary-font);
21
+ list-style: none;
22
+ color-scheme: light;
23
+ background: var(--dc-segmented-bg);
24
+ border-radius: var(--dc-segmented-button-radius);
25
+ box-shadow: inset 0 0 0 1px var(--dc-segmented-border-color);
26
+ }
27
+
28
+ .dc-segmented_disabled {
29
+ pointer-events: none;
30
+ opacity: var(--dc-disabled-state-opacity);
31
+ }
32
+
33
+ .dc-segmented_size_sm {
34
+ --dc-segmented-button-height: 32px;
35
+ --dc-segmented-button-padding-x: 12px;
36
+ --dc-segmented-button-radius: 8px;
37
+
38
+ font-size: 13px;
39
+ }
40
+
41
+ .dc-segmented_size_lg {
42
+ --dc-segmented-button-height: 40px;
43
+ --dc-segmented-button-padding-x: 18px;
44
+ --dc-segmented-button-radius: 10px;
45
+
46
+ font-size: 15px;
47
+ }
48
+
49
+ .dc-segmented__item + .dc-segmented__item::before {
50
+ display: inline-block;
51
+ float: left;
52
+ width: 1px;
53
+ height: calc(var(--dc-segmented-button-height) - var(--dc-segmented-button-radius) * 2);
54
+ content: "";
55
+ background: var(--dc-segmented-delimiter-color);
56
+ transform: translateY(var(--dc-segmented-button-radius));
57
+ }
58
+
59
+ .dc-segmented__item_selected::before,
60
+ .dc-segmented__item_selected + .dc-segmented__item::before {
61
+ visibility: hidden;
62
+ }
63
+
64
+ .dc-segmented-button {
65
+ position: relative;
66
+ box-sizing: border-box;
67
+ display: flex;
68
+ flex: auto;
69
+ gap: calc(var(--dc-segmented-button-padding-x) / 2);
70
+ align-items: center;
71
+ justify-content: center;
72
+ height: var(--dc-segmented-button-height);
73
+ padding: 0 var(--dc-segmented-button-padding-x);
74
+ font: inherit;
75
+ color: var(--dc-segmented-button-text-color);
76
+ -webkit-appearance: none;
77
+ -moz-appearance: none;
78
+ appearance: none;
79
+ cursor: pointer;
80
+ -webkit-user-select: none;
81
+ -moz-user-select: none;
82
+ user-select: none;
83
+ background: var(--dc-segmented-button-bg);
84
+ border: 1px solid var(--dc-segmented-button-border-color);
85
+ border-radius: var(--dc-segmented-button-radius);
86
+ }
87
+
88
+ .dc-segmented-button[aria-current="true"] {
89
+ --dc-segmented-button-border-color: var(--dc-segmented-button-border-color-selected);
90
+ --dc-segmented-button-bg: var(--dc-segmented-button-bg-selected);
91
+
92
+ cursor: default;
93
+ }
94
+
95
+ .dc-segmented-button:focus {
96
+ border-color: var(--dc-segmented-button-border-color-focus);
97
+ outline: none;
98
+ box-shadow: 0 0 0 3px var(--dc-segmented-button-focus-ring-color);
99
+ }
100
+
101
+ .dc-segmented-button:focus:not(:focus-visible) {
102
+ border-color: var(--dc-segmented-button-border-color);
103
+ box-shadow: none;
104
+ }
105
+
106
+ .dark .dc-segmented,
107
+ .dark.dc-segmented {
108
+ --dc-segmented-btn-bg-checked: var(--dc-gray-600);
109
+ --dc-segmented-btn-border-color-focus: var(--dc-blue-400);
110
+ --dc-segmented-btn-border-color-checked: var(--dc-gray-400);
111
+
112
+ color-scheme: dark;
113
+ }
@@ -0,0 +1,121 @@
1
+ .dc-select {
2
+ --dc-select-font-size: 14px;
3
+ --dc-select-text-color: var(--dc-control-primary-text-color);
4
+ --dc-select-height: 36px;
5
+ --dc-select-padding-x: 12px;
6
+ --dc-select-radius: 7px;
7
+ --dc-select-border-color: var(--dc-control-border-color);
8
+ --dc-select-border-color-error: var(--dc-control-error-color);
9
+ --dc-select-bg: var(--dc-control-bg);
10
+ --dc-select-focus-ring-color: var(--dc-control-primary-color);
11
+
12
+ position: relative;
13
+ box-sizing: border-box;
14
+ display: inline-flex;
15
+ align-items: stretch;
16
+ max-width: 100%;
17
+ height: var(--dc-select-height);
18
+ font-family: var(--dc-primary-font);
19
+ font-size: var(--dc-select-font-size);
20
+ font-weight: 400;
21
+ line-height: 1.25;
22
+ color: var(--dc-select-text-color);
23
+ vertical-align: middle;
24
+ color-scheme: light;
25
+ background: var(--dc-select-bg);
26
+ border: 1px solid var(--dc-select-border-color);
27
+ border-radius: var(--dc-select-radius);
28
+ }
29
+
30
+ .dc-select:focus-within {
31
+ border-color: var(--dc-select-focus-ring-color);
32
+ box-shadow: 0 0 0 1px var(--dc-select-focus-ring-color);
33
+ }
34
+
35
+ .dc-select_multiple {
36
+ height: initial;
37
+ overflow: hidden;
38
+ }
39
+
40
+ .dc-select_disabled {
41
+ opacity: var(--dc-disabled-state-opacity);
42
+ }
43
+
44
+ .dc-select_invalid {
45
+ border-color: var(--dc-select-border-color-error);
46
+ }
47
+
48
+ .dc-select_full-width {
49
+ display: flex;
50
+ width: 100%;
51
+ }
52
+
53
+ .dc-select_sm {
54
+ --dc-select-font-size: 13px;
55
+ --dc-select-height: 32px;
56
+ --dc-select-padding-x: 8px;
57
+ --dc-select-radius: 6px;
58
+ }
59
+
60
+ .dc-select_lg {
61
+ --dc-select-font-size: 15px;
62
+ --dc-select-height: 40px;
63
+ --dc-select-padding-x: 16px;
64
+ --dc-select-radius: 8px;
65
+ }
66
+
67
+ .dc-select__native {
68
+ width: 100%;
69
+ padding-right: calc(var(--dc-select-height) + 0.5em);
70
+ padding-left: var(--dc-select-padding-x);
71
+ font: inherit;
72
+ color: inherit;
73
+ text-transform: none;
74
+ -webkit-appearance: none;
75
+ -moz-appearance: none;
76
+ appearance: none;
77
+ cursor: pointer;
78
+ background: none;
79
+ border: none;
80
+ }
81
+
82
+ .dc-select__native:focus {
83
+ outline: none;
84
+ }
85
+
86
+ .dc-select__native:disabled {
87
+ cursor: default;
88
+ opacity: 1;
89
+ }
90
+
91
+ .dc-select__native:disabled > option {
92
+ color: inherit;
93
+ }
94
+
95
+ .dc-select_multiple .dc-select__native {
96
+ padding: 0;
97
+ margin-top: var(--dc-select-radius);
98
+ margin-bottom: var(--dc-select-radius);
99
+ }
100
+
101
+ .dc-select__slot-left {
102
+ position: absolute;
103
+ top: -1px;
104
+ right: -1px;
105
+ display: inline-flex;
106
+ align-items: center;
107
+ justify-content: center;
108
+ width: var(--dc-select-height);
109
+ height: var(--dc-select-height);
110
+ pointer-events: none;
111
+ background: none;
112
+ }
113
+
114
+ .dc-select_multiple .dc-select__slot-left {
115
+ display: none;
116
+ }
117
+
118
+ .dark .dc-select,
119
+ .dark.dc-select {
120
+ color-scheme: dark;
121
+ }
@@ -0,0 +1,36 @@
1
+ .dc-selection-control {
2
+ display: grid;
3
+ grid-template-areas: "input label";
4
+ grid-template-columns: auto 1fr;
5
+ grid-gap: 2px 12px;
6
+ justify-items: start;
7
+ color-scheme: light;
8
+ }
9
+
10
+ .dc-selection-control__with_caption {
11
+ grid-template-areas:
12
+ "input label"
13
+ ". caption";
14
+ }
15
+
16
+ .dc-selection-control__input {
17
+ display: inline-flex;
18
+ grid-area: input;
19
+ }
20
+
21
+ .dc-selection-control__label {
22
+ grid-area: label;
23
+ align-self: center;
24
+ -webkit-user-select: none;
25
+ -moz-user-select: none;
26
+ user-select: none;
27
+ }
28
+
29
+ .dc-selection-control__caption {
30
+ grid-area: caption;
31
+ }
32
+
33
+ .dark .dc-selection-control,
34
+ .dark.dc-selection-control {
35
+ color-scheme: dark;
36
+ }
@@ -11,5 +11,7 @@ export function SelectionControl({ label, labelFor, caption, className, children
11
11
  'dc-selection-control__with_caption': caption,
12
12
  }), children: [_jsx("div", { className: "dc-selection-control__input", children: typeof children === 'function'
13
13
  ? children({ id: controlId })
14
- : cloneElement(children, { id: children.props.id || controlId }) }), _jsx(Label, { className: "dc-selection-control__label", htmlFor: controlId, children: label }), caption ? (_jsx(Caption, { className: "dc-selection-control__caption", children: caption })) : null] }));
14
+ : cloneElement(children, { id: children.props.id || controlId }) }), _jsx(Label, { className: "dc-selection-control__label", htmlFor: controlId, children: label }), caption
15
+ ? (_jsx(Caption, { className: "dc-selection-control__caption", children: caption }))
16
+ : null] }));
15
17
  }
@@ -0,0 +1,7 @@
1
+ .dc-slide-over-body {
2
+ box-sizing: border-box;
3
+ flex-grow: 1;
4
+ padding: 0 16px;
5
+ overflow: auto;
6
+ color: var(--dc-slide-over-text-color);
7
+ }
@@ -0,0 +1,29 @@
1
+ .dc-slide-over-header {
2
+ box-sizing: border-box;
3
+ padding: 16px;
4
+ color: var(--dc-slide-over-text-color);
5
+ }
6
+
7
+ .dc-slide-over-header__title {
8
+ display: flex;
9
+ align-items: center;
10
+ }
11
+
12
+ .dc-slide-over-header__title > h2 {
13
+ flex-grow: 1;
14
+ margin: 0;
15
+ font: 700 var(--dc-text-md);
16
+ color: inherit;
17
+ }
18
+
19
+ .dc-slide-over-header__description {
20
+ margin-top: 4px;
21
+ font: var(--dc-text-sm);
22
+ color: var(--dc-slide-over-secondary-text-color);
23
+ }
24
+
25
+ .dc-slide-over-header__content {
26
+ margin-top: 8px;
27
+ font: var(--dc-text-md);
28
+ color: var(--dc-slide-over-text-color);
29
+ }
@@ -9,5 +9,9 @@ export function SlideOverHeader({ className, htmlTitle, title, children, descrip
9
9
  closePanel('close-button');
10
10
  onClickCloseButton?.(ev);
11
11
  };
12
- return (_jsxs("div", { className: classNames('dc-slide-over-header', className), title: htmlTitle, ...props, children: [_jsxs("div", { className: "dc-slide-over-header__title", children: [_jsx("h2", { id: titleId, children: title }), _jsx(IconButton, { buttonStyle: "tinted", size: "xs", "aria-label": closeButtonAccessibleName, onClick: onCloseButtonClicked, children: _jsx(XMarkIcon, { width: 20, height: 20 }) })] }), description ? (_jsx("div", { id: descriptionId, className: "dc-slide-over-header__description", children: description })) : null, children ? (_jsx("div", { className: "dc-slide-over-header__content", children: children })) : null] }));
12
+ return (_jsxs("div", { className: classNames('dc-slide-over-header', className), title: htmlTitle, ...props, children: [_jsxs("div", { className: "dc-slide-over-header__title", children: [_jsx("h2", { id: titleId, children: title }), _jsx(IconButton, { buttonStyle: "tinted", size: "xs", "aria-label": closeButtonAccessibleName, onClick: onCloseButtonClicked, children: _jsx(XMarkIcon, { width: 20, height: 20 }) })] }), description
13
+ ? (_jsx("div", { id: descriptionId, className: "dc-slide-over-header__description", children: description }))
14
+ : null, children
15
+ ? (_jsx("div", { className: "dc-slide-over-header__content", children: children }))
16
+ : null] }));
13
17
  }
@@ -0,0 +1,85 @@
1
+ .dc-slide-over-header {
2
+ box-sizing: border-box;
3
+ padding: 16px;
4
+ color: var(--dc-slide-over-text-color);
5
+ }
6
+
7
+ .dc-slide-over-header__title {
8
+ display: flex;
9
+ align-items: center;
10
+ }
11
+
12
+ .dc-slide-over-header__title > h2 {
13
+ flex-grow: 1;
14
+ margin: 0;
15
+ font: 700 var(--dc-text-md);
16
+ color: inherit;
17
+ }
18
+
19
+ .dc-slide-over-header__description {
20
+ margin-top: 4px;
21
+ font: var(--dc-text-sm);
22
+ color: var(--dc-slide-over-secondary-text-color);
23
+ }
24
+
25
+ .dc-slide-over-header__content {
26
+ margin-top: 8px;
27
+ font: var(--dc-text-md);
28
+ color: var(--dc-slide-over-text-color);
29
+ }
30
+
31
+ .dc-slide-over-body {
32
+ box-sizing: border-box;
33
+ flex-grow: 1;
34
+ padding: 0 16px;
35
+ overflow: auto;
36
+ color: var(--dc-slide-over-text-color);
37
+ }
38
+
39
+ .dc-slide-over {
40
+ --dc-slide-over-text-color: var(--dc-primary-text-color);
41
+ --dc-slide-over-secondary-text-color: var(--dc-secondary-text-color);
42
+ --dc-slide-over-panel-max-width: 512px;
43
+ --dc-slide-over-panel-bg: var(--dc-primary-bg);
44
+ --dc-slide-over-backdrop-color: rgb(var(--dc-gray-900-rgb) / 40%);
45
+
46
+ position: relative;
47
+ z-index: var(--dc-overlay-z-index);
48
+ color-scheme: light;
49
+ }
50
+
51
+ .dc-slide-over__backdrop,
52
+ .dc-slide-over__panel {
53
+ position: fixed;
54
+ top: 0;
55
+ height: 100%;
56
+ }
57
+
58
+ .dc-slide-over__backdrop {
59
+ left: 0;
60
+ width: 100%;
61
+ background: var(--dc-slide-over-backdrop-color);
62
+ }
63
+
64
+ .dc-slide-over__panel {
65
+ right: 0;
66
+ box-sizing: border-box;
67
+ display: flex;
68
+ flex-direction: column;
69
+ width: 100%;
70
+ max-width: var(--dc-slide-over-panel-max-width);
71
+ color: var(--dc-primary-text-color);
72
+ background: var(--dc-slide-over-panel-bg);
73
+ box-shadow: var(--dc-shadow-md);
74
+ }
75
+
76
+ .dark .dc-slide-over,
77
+ .dark.dc-slide-over {
78
+ --dc-slide-over-panel-bg: var(--dc-gray-800);
79
+
80
+ color-scheme: dark;
81
+ }
82
+
83
+ .dark .dc-slide-over__panel {
84
+ box-shadow: 0 0 0 1px var(--dc-border-color-transparent-1), var(--dc-shadow-md);
85
+ }
@@ -1,8 +1,8 @@
1
1
  import { formatNumber, formatPercent } from '../../lib/index.js';
2
2
  export function getOffsetRelativeToThumb(position) {
3
- return 'calc(' +
4
- `${formatPercent(position)} - ` +
5
- `var(--dc-slider-thumb-width) * ${formatNumber(position / 2)} + ` +
6
- `var(--dc-slider-thumb-width) * ${formatNumber((1 - position) / 2)}` +
7
- ')';
3
+ return 'calc('
4
+ + `${formatPercent(position)} - `
5
+ + `var(--dc-slider-thumb-width) * ${formatNumber(position / 2)} + `
6
+ + `var(--dc-slider-thumb-width) * ${formatNumber((1 - position) / 2)}`
7
+ + ')';
8
8
  }