draft-components 0.53.0 → 0.54.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 (46) hide show
  1. package/components/date-picker/calendar-day.d.ts +17 -0
  2. package/components/date-picker/calendar-day.js +19 -0
  3. package/components/date-picker/calendar-day.js.map +1 -0
  4. package/components/date-picker/calendar-header.d.ts +13 -0
  5. package/components/date-picker/calendar-header.js +19 -0
  6. package/components/date-picker/calendar-header.js.map +1 -0
  7. package/components/date-picker/calendar-row.d.ts +7 -0
  8. package/components/date-picker/calendar-row.js +10 -0
  9. package/components/date-picker/calendar-row.js.map +1 -0
  10. package/components/date-picker/calendar.d.ts +13 -0
  11. package/components/date-picker/calendar.js +63 -0
  12. package/components/date-picker/calendar.js.map +1 -0
  13. package/components/date-picker/date-picker.d.ts +11 -0
  14. package/components/date-picker/date-picker.js +49 -0
  15. package/components/date-picker/date-picker.js.map +1 -0
  16. package/components/date-picker/date-range-picker.d.ts +12 -0
  17. package/components/date-picker/date-range-picker.js +103 -0
  18. package/components/date-picker/date-range-picker.js.map +1 -0
  19. package/components/date-picker/index.d.ts +2 -0
  20. package/components/date-picker/index.js +15 -0
  21. package/components/date-picker/index.js.map +1 -0
  22. package/components/date-range-picker-popover/date-preset-list.d.ts +18 -0
  23. package/components/date-range-picker-popover/date-preset-list.js +21 -0
  24. package/components/date-range-picker-popover/date-preset-list.js.map +1 -0
  25. package/components/date-range-picker-popover/date-range-picker-popover.d.ts +20 -0
  26. package/components/date-range-picker-popover/date-range-picker-popover.js +78 -0
  27. package/components/date-range-picker-popover/date-range-picker-popover.js.map +1 -0
  28. package/components/date-range-picker-popover/index.d.ts +1 -0
  29. package/components/date-range-picker-popover/index.js +14 -0
  30. package/components/date-range-picker-popover/index.js.map +1 -0
  31. package/components/index.d.ts +3 -2
  32. package/components/index.js +3 -2
  33. package/components/index.js.map +1 -1
  34. package/css/draft-components.css +2 -2
  35. package/lib/date-helpers.d.ts +34 -0
  36. package/lib/date-helpers.js +102 -0
  37. package/lib/date-helpers.js.map +1 -0
  38. package/lib/index.d.ts +1 -0
  39. package/lib/index.js +2 -1
  40. package/lib/index.js.map +1 -1
  41. package/package.json +1 -1
  42. package/scss/components/_button.scss +14 -12
  43. package/scss/components/_date-picker.scss +178 -0
  44. package/scss/components/_date-range-picker-popover.scss +112 -0
  45. package/scss/components/_index.scss +2 -0
  46. package/scss/themes/_default-theme.scss +24 -0
@@ -0,0 +1,178 @@
1
+ @use 'sass:math' as math;
2
+
3
+ $_calendar-cell-gap: $gap-2x;
4
+ $_calendar-cell-size: px-to-rem(30px);
5
+ $_calendar-day-border: 1px dashed var(--dc-calendar-border-color);
6
+
7
+ .dc-date-picker,
8
+ .dc-date-range-picker {
9
+ display: inline-block;
10
+ }
11
+
12
+ .dc-calendar {
13
+ font-family: var(--dc-font-base);
14
+ }
15
+
16
+ .dc-calendar-header {
17
+ display: flex;
18
+ align-items: center;
19
+ }
20
+
21
+ .dc-calendar-header > * + * {
22
+ margin-left: $gap-1x;
23
+ }
24
+
25
+ .dc-calendar-header__title {
26
+ font-size: $font-size-sm;
27
+ font-weight: $font-weight-normal;
28
+ flex: auto;
29
+ text-align: center;
30
+ color: var(--dc-calendar-text-color);
31
+ }
32
+
33
+ .dc-calendar-header__title::first-letter {
34
+ text-transform: uppercase;
35
+ }
36
+
37
+ .dc-calendar-header__btn {
38
+ color: var(--dc-calendar-arrow-color);
39
+ }
40
+
41
+ .dc-calendar__row-group > * + * {
42
+ margin-top: $_calendar-cell-gap;
43
+ }
44
+
45
+ .dc-calendar__row-group > *:first-child {
46
+ justify-content: flex-end;
47
+ }
48
+
49
+ .dc-calendar-row {
50
+ display: flex;
51
+ }
52
+
53
+ .dc-calendar-row_head {
54
+ margin-bottom: $gap-2x;
55
+ padding: $gap-2x 0;
56
+ border-bottom: 1px solid var(--dc-calendar-border-secondary-color);
57
+ }
58
+
59
+ .dc-calendar-row_head > * {
60
+ font-size: $font-size-xs;
61
+ flex: auto;
62
+ text-align: center;
63
+ color: var(--dc-calendar-text-secondary-color);
64
+ }
65
+
66
+ .dc-calendar-row_head > * + * {
67
+ margin-left: $_calendar-cell-gap;
68
+ }
69
+
70
+ .dc-calendar-day {
71
+ position: relative;
72
+ flex: 0 0 $_calendar-cell-size;
73
+ height: $_calendar-cell-size;
74
+ color: var(--dc-calendar-text-color);
75
+ }
76
+
77
+ .dc-calendar-day::before {
78
+ position: absolute;
79
+ top: 0;
80
+ right: 0;
81
+ bottom: 0;
82
+ left: 0;
83
+ content: '';
84
+ border-radius: inherit;
85
+ }
86
+
87
+ .dc-calendar-day__btn {
88
+ font-size: $font-size-sm;
89
+ line-height: 1;
90
+ position: relative;
91
+ display: inline-block;
92
+ box-sizing: border-box;
93
+ width: $_calendar-cell-size;
94
+ height: $_calendar-cell-size;
95
+ margin: 0;
96
+ padding: 0;
97
+ text-align: center;
98
+ color: inherit;
99
+ border: 1px solid transparent;
100
+ border-radius: 50%;
101
+ background: none;
102
+ appearance: none;
103
+ }
104
+
105
+ .dc-calendar-day__btn:hover {
106
+ z-index: 1;
107
+ border-color: var(--dc-calendar-border-color);
108
+ }
109
+
110
+ .dc-calendar-day__btn:focus {
111
+ z-index: 1;
112
+ outline: none;
113
+ @include focus-ring;
114
+ }
115
+
116
+ .dc-calendar-day_range-preview-start:not(.dc-calendar-day_selected) .dc-calendar-day__btn,
117
+ .dc-calendar-day_range-preview-end:not(.dc-calendar-day_selected) .dc-calendar-day__btn {
118
+ border-color: var(--dc-calendar-border-color);
119
+ }
120
+
121
+ .dc-calendar-day + .dc-calendar-day {
122
+ padding-left: $_calendar-cell-gap;
123
+ }
124
+
125
+ .dc-calendar-day + .dc-calendar-day_range-start,
126
+ .dc-calendar-day + .dc-calendar-day_range-preview-start {
127
+ margin-left: $_calendar-cell-gap;
128
+ padding-left: 0;
129
+ }
130
+
131
+ .dc-calendar-day_in-range::before {
132
+ background: $blue-100;
133
+ }
134
+
135
+ .dc-calendar-day_in-range-preview::before {
136
+ border-top: $_calendar-day-border;
137
+ border-bottom: $_calendar-day-border;
138
+ }
139
+
140
+ .dc-calendar-day_in-range-preview:first-child::before,
141
+ .dc-calendar-day_in-range-preview.dc-calendar-day_range-preview-start::before {
142
+ border-left: $_calendar-day-border;
143
+ }
144
+
145
+ .dc-calendar-day_in-range-preview:last-child::before,
146
+ .dc-calendar-day_in-range-preview.dc-calendar-day_range-preview-end::before {
147
+ border-right: $_calendar-day-border;
148
+ }
149
+
150
+ .dc-calendar-day_range-start,
151
+ .dc-calendar-day_range-preview-start,
152
+ .dc-calendar-day:first-child {
153
+ border-top-left-radius: math.div($_calendar-cell-size, 2);
154
+ border-bottom-left-radius: math.div($_calendar-cell-size, 2);
155
+ }
156
+
157
+ .dc-calendar-day_range-end,
158
+ .dc-calendar-day_range-preview-end,
159
+ .dc-calendar-day:last-child {
160
+ border-top-right-radius: math.div($_calendar-cell-size, 2);
161
+ border-bottom-right-radius: math.div($_calendar-cell-size, 2);
162
+ }
163
+
164
+ .dc-calendar-day_current {
165
+ color: var(--dc-calendar-current-day-text-color);
166
+ }
167
+
168
+ .dc-calendar-day_selected {
169
+ color: var(--dc-calendar-selected-day-text-color);
170
+ }
171
+
172
+ .dc-calendar-day_selected .dc-calendar-day__btn {
173
+ background: var(--dc-calendar-selected-day-bg-color);
174
+ }
175
+
176
+ .dc-calendar-day_selected .dc-calendar-day__btn:hover {
177
+ border-color: var(--dc-calendar-selected-day-bg-color);
178
+ }
@@ -0,0 +1,112 @@
1
+ .dc-date-range-picker-popover {
2
+ max-height: initial !important;
3
+ }
4
+
5
+ .dc-date-range-picker-popover__content {
6
+ }
7
+
8
+ .dc-date-range-picker-popover__content > * + * {
9
+ margin-top: $gap-4x;
10
+ }
11
+
12
+ .dc-date-range-picker-popover__content-body {
13
+ display: flex;
14
+ }
15
+
16
+ .dc-date-range-picker-popover__content-body > * + * {
17
+ margin-left: $gap-4x;
18
+ }
19
+
20
+ .dc-date-range-picker-popover__content-footer {
21
+ display: flex;
22
+ align-items: center;
23
+ justify-content: flex-end;
24
+ width: 100%;
25
+ }
26
+
27
+ .dc-date-range-picker-popover__content-footer > * + * {
28
+ margin-left: $gap-2x;
29
+ }
30
+
31
+ .dc-date-preset-list {
32
+ margin: 0;
33
+ padding: 0;
34
+ list-style: none;
35
+ }
36
+
37
+ .dc-date-preset-list > * + * {
38
+ margin-top: $gap-1x;
39
+ }
40
+
41
+ .dc-date-preset-list-item {
42
+ width: 100%;
43
+ }
44
+
45
+ .dc-date-preset-list-item__btn {
46
+ font-size: $font-size-sm;
47
+ width: 100%;
48
+ padding: $gap-2x $gap-3x;
49
+ cursor: pointer;
50
+ text-align: left;
51
+ color: var(--dc-date-preset-btn-text-color);
52
+ border: none;
53
+ border-radius: $border-radius-md;
54
+ background: var(--dc-date-preset-btn-bg);
55
+ appearance: none;
56
+ }
57
+
58
+ .dc-date-preset-list-item__btn:focus {
59
+ outline: none;
60
+ box-shadow: inset 0 0 0 px-to-rem(2px) var(--dc-focus-border-color);
61
+ }
62
+
63
+ .dc-date-preset-list-item__btn:hover {
64
+ color: var(--dc-date-preset-hover-btn-text-color);
65
+ background: var(--dc-date-preset-hover-btn-bg);
66
+ }
67
+
68
+ .dc-date-preset-list-item__btn_selected,
69
+ .dc-date-preset-list-item__btn_selected:hover {
70
+ color: var(--dc-date-preset-selected-btn-text-color);
71
+ background: var(--dc-date-preset-selected-btn-bg);
72
+ }
73
+
74
+ @media screen and (max-width: 599px) {
75
+ .dc-date-range-picker-popover__content-body {
76
+ display: block;
77
+ }
78
+
79
+ .dc-date-range-picker-popover__content-body > * + * {
80
+ margin-top: $gap-1x;
81
+ margin-left: 0;
82
+ }
83
+
84
+ .dc-date-preset-list {
85
+ display: flex;
86
+ overflow-y: auto;
87
+ max-width: px-to-rem(258px);
88
+ padding-bottom: $gap-3x;
89
+ }
90
+
91
+ .dc-date-preset-list > * + * {
92
+ margin-top: 0;
93
+ margin-left: $gap-2x;
94
+ }
95
+
96
+ .dc-date-preset-list-item {
97
+ white-space: nowrap;
98
+ }
99
+
100
+ .dc-date-preset-list-item__btn {
101
+ border-radius: $border-radius-lg;
102
+ }
103
+
104
+ .dc-date-preset-list-item__btn:not(.dc-date-preset-list-item__btn_selected) {
105
+ color: var(--dc-date-preset-btn-text-color);
106
+ background: var(--dc-date-preset-btn-bg);
107
+ }
108
+
109
+ .dc-date-range-picker-popover__content-footer > * {
110
+ flex: auto;
111
+ }
112
+ }
@@ -10,6 +10,8 @@
10
10
  @import 'number-input';
11
11
  @import 'password-input';
12
12
  @import 'datetime-input';
13
+ @import 'date-picker';
14
+ @import 'date-range-picker-popover';
13
15
  @import 'slider';
14
16
  @import 'textarea';
15
17
  @import 'select';
@@ -153,6 +153,30 @@
153
153
  --dc-slider-track-bg: #{$gray-400};
154
154
  --dc-slider-fill-track-bg: #{$blue-500};
155
155
 
156
+ /*------------------------------------*\
157
+ #DATE PICKER
158
+ \*------------------------------------*/
159
+ --dc-calendar-text-color: #{$gray-800};
160
+ --dc-calendar-text-secondary-color: #{$gray-500};
161
+ --dc-calendar-border-color: #{$gray-500};
162
+ --dc-calendar-border-secondary-color: #{$gray-200};
163
+ --dc-calendar-arrow-color: #{$blue-600};
164
+ --dc-calendar-current-day-text-color: #{$orange-600};
165
+ --dc-calendar-selected-day-text-color: #{$white};
166
+ --dc-calendar-selected-day-bg-color: #{$blue-500};
167
+
168
+ /*------------------------------------*\
169
+ #DATE RANGE PICKER POPOVER
170
+ \*------------------------------------*/
171
+ --dc-date-preset-btn-text-color: #{$gray-500};
172
+ --dc-date-preset-btn-bg: none;
173
+ --dc-date-preset-phone-btn-text-color: #{$gray-800};
174
+ --dc-date-preset-phone-btn-bg: #{$gray-100};
175
+ --dc-date-preset-hover-btn-text-color: #{$gray-800};
176
+ --dc-date-preset-hover-btn-bg: #{$gray-100};
177
+ --dc-date-preset-selected-btn-text-color: #{$blue-700};
178
+ --dc-date-preset-selected-btn-bg: #{$blue-100};
179
+
156
180
  /*------------------------------------*\
157
181
  #ACTIONS GROUP
158
182
  \*------------------------------------*/