@steroidsjs/bootstrap 3.0.0-beta.6 → 3.0.0-beta.61

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 (279) hide show
  1. package/README.md +1 -2
  2. package/content/Accordion/AccordionItemView.d.ts +2 -0
  3. package/content/{Collapse/CollapseItemView.js → Accordion/AccordionItemView.js} +47 -22
  4. package/content/Accordion/AccordionItemView.scss +209 -0
  5. package/content/Accordion/AccordionView.d.ts +2 -0
  6. package/content/{Collapse/CollapseView.js → Accordion/AccordionView.js} +3 -3
  7. package/content/{Collapse/CollapseView.scss → Accordion/AccordionView.scss} +3 -4
  8. package/content/Alert/AlertView.js +3 -2
  9. package/content/Alert/AlertView.scss +19 -4
  10. package/content/Avatar/AvatarView.js +2 -3
  11. package/content/Avatar/AvatarView.scss +32 -39
  12. package/content/Badge/BadgeView.d.ts +3 -0
  13. package/content/Badge/BadgeView.js +25 -0
  14. package/content/Badge/BadgeView.scss +135 -0
  15. package/content/Calendar/CalendarView.js +1 -1
  16. package/content/Calendar/CalendarView.scss +240 -161
  17. package/content/Calendar/CaptionElement.js +23 -15
  18. package/content/Calendar/CaptionElement.scss +164 -106
  19. package/content/Card/CardView.js +37 -14
  20. package/content/Card/CardView.scss +139 -107
  21. package/content/CopyToClipboard/CopyToClipboardView.d.ts +3 -0
  22. package/content/CopyToClipboard/CopyToClipboardView.js +19 -0
  23. package/content/CopyToClipboard/CopyToClipboardView.scss +41 -0
  24. package/content/Detail/DetailView.scss +75 -52
  25. package/content/DropDown/DropDownView.d.ts +0 -1
  26. package/content/DropDown/DropDownView.js +6 -4
  27. package/content/DropDown/DropDownView.scss +196 -27
  28. package/content/Icon/IconView.d.ts +1 -2
  29. package/content/Icon/IconView.js +2 -2
  30. package/content/Icon/IconView.scss +1 -23
  31. package/content/Menu/MenuItemView.d.ts +2 -0
  32. package/content/Menu/MenuItemView.js +15 -0
  33. package/content/Menu/MenuItemView.scss +63 -0
  34. package/content/Menu/MenuView.d.ts +2 -0
  35. package/content/Menu/MenuView.js +30 -0
  36. package/content/Menu/MenuView.scss +43 -0
  37. package/form/AutoCompleteField/AutoCompleteFieldView.d.ts +1 -2
  38. package/form/AutoCompleteField/AutoCompleteFieldView.js +62 -8
  39. package/form/AutoCompleteField/AutoCompleteFieldView.scss +199 -142
  40. package/form/Button/ButtonView.d.ts +1 -2
  41. package/form/Button/ButtonView.js +13 -9
  42. package/form/Button/ButtonView.scss +168 -68
  43. package/form/CheckboxField/CheckboxFieldView.d.ts +1 -2
  44. package/form/CheckboxField/CheckboxFieldView.js +6 -4
  45. package/form/CheckboxField/CheckboxFieldView.scss +195 -36
  46. package/form/CheckboxListField/CheckboxListFieldView.d.ts +1 -2
  47. package/form/CheckboxListField/CheckboxListFieldView.js +18 -15
  48. package/form/CheckboxListField/CheckboxListFieldView.scss +7 -41
  49. package/form/DateField/DateFieldView.js +7 -6
  50. package/form/DateField/DateFieldView.scss +7 -74
  51. package/form/DateRangeField/DateRangeFieldView.js +10 -13
  52. package/form/DateRangeField/DateRangeFieldView.scss +29 -78
  53. package/form/DateTimeField/DateTimeFieldView.d.ts +1 -2
  54. package/form/DateTimeField/DateTimeFieldView.js +5 -5
  55. package/form/DateTimeField/DateTimeFieldView.scss +7 -109
  56. package/form/DateTimeRangeField/DateTimeRangeFieldView.js +9 -7
  57. package/form/DateTimeRangeField/DateTimeRangeFieldView.scss +25 -90
  58. package/form/DropDownField/DropDownFieldView.js +35 -47
  59. package/form/DropDownField/DropDownFieldView.scss +388 -182
  60. package/form/DropDownField/utils.d.ts +2 -0
  61. package/form/DropDownField/utils.js +15 -0
  62. package/form/DropDownFieldItem/DropDownFieldItemView.d.ts +2 -0
  63. package/form/DropDownFieldItem/DropDownFieldItemView.js +81 -0
  64. package/form/DropDownFieldItem/DropDownFieldItemView.scss +218 -0
  65. package/form/FieldLayout/FieldLayoutView.d.ts +1 -2
  66. package/form/FieldLayout/FieldLayoutView.js +13 -9
  67. package/form/FieldLayout/FieldLayoutView.scss +114 -19
  68. package/form/FieldList/FieldListItemView.js +6 -4
  69. package/form/FieldList/FieldListItemView.scss +17 -39
  70. package/form/FieldList/FieldListView.js +9 -8
  71. package/form/FieldList/FieldListView.scss +58 -18
  72. package/form/FieldSet/FieldSetView.js +4 -2
  73. package/form/FieldSet/FieldSetView.scss +39 -0
  74. package/form/FileField/FileFieldItemView.d.ts +1 -2
  75. package/form/FileField/FileFieldItemView.js +31 -6
  76. package/form/FileField/FileFieldItemView.scss +254 -13
  77. package/form/FileField/FileFieldView.d.ts +1 -2
  78. package/form/FileField/FileFieldView.js +6 -8
  79. package/form/FileField/FileFieldView.scss +34 -4
  80. package/form/Form/FormView.js +1 -4
  81. package/form/Form/FormView.scss +1 -14
  82. package/form/HtmlField/HtmlFieldView.d.ts +1 -2
  83. package/form/HtmlField/HtmlFieldView.scss +6 -3
  84. package/form/ImageField/ImageFieldView.js +1 -1
  85. package/form/InputField/InputFieldView.d.ts +1 -2
  86. package/form/InputField/InputFieldView.js +30 -13
  87. package/form/InputField/InputFieldView.scss +265 -99
  88. package/form/NumberField/NumberFieldView.d.ts +1 -2
  89. package/form/NumberField/NumberFieldView.js +19 -13
  90. package/form/NumberField/NumberFieldView.scss +195 -89
  91. package/form/PasswordField/PasswordFieldView.d.ts +1 -2
  92. package/form/PasswordField/PasswordFieldView.js +11 -9
  93. package/form/PasswordField/PasswordFieldView.scss +231 -63
  94. package/form/RadioField/RadioFieldView.d.ts +2 -0
  95. package/form/RadioField/RadioFieldView.js +57 -0
  96. package/form/RadioField/RadioFieldView.scss +226 -0
  97. package/form/RadioListField/RadioListFieldView.d.ts +1 -2
  98. package/form/RadioListField/RadioListFieldView.js +20 -16
  99. package/form/RadioListField/RadioListFieldView.scss +11 -1
  100. package/form/ReCaptchaField/ReCaptchaFieldView.d.ts +1 -2
  101. package/form/ReCaptchaField/ReCaptchaFieldView.js +2 -2
  102. package/form/SliderField/SliderFieldView.d.ts +1 -2
  103. package/form/SliderField/SliderFieldView.js +1 -1
  104. package/form/SliderField/SliderFieldView.scss +336 -299
  105. package/form/SwitcherField/SwitcherFieldView.d.ts +1 -2
  106. package/form/SwitcherField/SwitcherFieldView.js +12 -7
  107. package/form/SwitcherField/SwitcherFieldView.scss +188 -1
  108. package/form/TextField/TextFieldView.d.ts +1 -2
  109. package/form/TextField/TextFieldView.js +10 -2
  110. package/form/TextField/TextFieldView.scss +144 -2
  111. package/form/TimeField/TimeFieldView.d.ts +1 -2
  112. package/icons/index.d.ts +2 -0
  113. package/icons/index.js +103 -0
  114. package/icons/svgs/add.svg +4 -0
  115. package/icons/svgs/add_square.svg +5 -0
  116. package/icons/svgs/arrow_down_18x18.svg +4 -0
  117. package/icons/svgs/arrow_down_24x24.svg +4 -0
  118. package/icons/svgs/arrow_drop_down_10x10.svg +3 -0
  119. package/icons/svgs/arrow_left_18x18.svg +4 -0
  120. package/icons/svgs/arrow_left_24x24.svg +4 -0
  121. package/icons/svgs/arrow_right_18x18.svg +4 -0
  122. package/icons/svgs/arrow_right_24x24.svg +4 -0
  123. package/icons/svgs/arrow_up_18x18.svg +4 -0
  124. package/icons/svgs/arrow_up_24x24.svg +4 -0
  125. package/icons/svgs/blank.svg +4 -0
  126. package/icons/svgs/calendar_check.svg +5 -0
  127. package/icons/svgs/calendar_range.svg +8 -0
  128. package/icons/svgs/cancel_ellips.svg +4 -0
  129. package/icons/svgs/chart.svg +6 -0
  130. package/icons/svgs/checkmark_12x12.svg +4 -0
  131. package/icons/svgs/checkmark_8x8.svg +4 -0
  132. package/icons/svgs/circle_cross_12x12.svg +4 -0
  133. package/icons/svgs/circle_cross_16x16.svg +4 -0
  134. package/icons/svgs/circle_cross_18x18.svg +4 -0
  135. package/icons/svgs/clip.svg +3 -0
  136. package/icons/svgs/copy.svg +5 -0
  137. package/icons/svgs/cross_12x12.svg +4 -0
  138. package/icons/svgs/cross_4x4.svg +3 -0
  139. package/icons/svgs/cross_8x8.svg +4 -0
  140. package/icons/svgs/cut.svg +3 -0
  141. package/icons/svgs/date_range.svg +8 -0
  142. package/icons/svgs/default_16x16.svg +4 -0
  143. package/icons/svgs/default_24x24.svg +11 -0
  144. package/icons/svgs/double_arrow_down.svg +5 -0
  145. package/icons/svgs/double_arrow_left.svg +5 -0
  146. package/icons/svgs/double_arrow_right.svg +5 -0
  147. package/icons/svgs/double_arrow_up.svg +5 -0
  148. package/icons/svgs/doughnut_chart.svg +5 -0
  149. package/icons/svgs/edit.svg +4 -0
  150. package/icons/svgs/error_16x16.svg +5 -0
  151. package/icons/svgs/error_24x24.svg +12 -0
  152. package/icons/svgs/expand_down.svg +3 -0
  153. package/icons/svgs/expand_left.svg +3 -0
  154. package/icons/svgs/expand_left_double.svg +4 -0
  155. package/icons/svgs/expand_right.svg +3 -0
  156. package/icons/svgs/expand_right_double.svg +4 -0
  157. package/icons/svgs/expand_up.svg +3 -0
  158. package/icons/svgs/file_dock.svg +6 -0
  159. package/icons/svgs/filter.svg +3 -0
  160. package/icons/svgs/fluid.svg +4 -0
  161. package/icons/svgs/folder.svg +3 -0
  162. package/icons/svgs/group.svg +8 -0
  163. package/icons/svgs/home.svg +4 -0
  164. package/icons/svgs/img_box.svg +5 -0
  165. package/icons/svgs/import.svg +4 -0
  166. package/icons/svgs/info_16x16.svg +5 -0
  167. package/icons/svgs/info_24x24.svg +12 -0
  168. package/icons/svgs/left_12x12.svg +3 -0
  169. package/icons/svgs/loading_default.svg +3 -0
  170. package/icons/svgs/loading_icon_thick.svg +3 -0
  171. package/icons/svgs/loading_purple.svg +9 -0
  172. package/icons/svgs/map.svg +7 -0
  173. package/icons/svgs/menu_dots.svg +5 -0
  174. package/icons/svgs/menu_left.svg +5 -0
  175. package/icons/svgs/minis_sq.svg +4 -0
  176. package/icons/svgs/paste.svg +8 -0
  177. package/icons/svgs/pie_chart.svg +5 -0
  178. package/icons/svgs/pin.svg +4 -0
  179. package/icons/svgs/sad.svg +6 -0
  180. package/icons/svgs/search.svg +4 -0
  181. package/icons/svgs/setting_line.svg +3 -0
  182. package/icons/svgs/share.svg +7 -0
  183. package/icons/svgs/star.svg +3 -0
  184. package/icons/svgs/success_16x16.svg +4 -0
  185. package/icons/svgs/success_24x24.svg +11 -0
  186. package/icons/svgs/support.svg +3 -0
  187. package/icons/svgs/trash.svg +6 -0
  188. package/icons/svgs/upload.svg +4 -0
  189. package/icons/svgs/user.svg +4 -0
  190. package/icons/svgs/view.svg +4 -0
  191. package/icons/svgs/view_hide.svg +5 -0
  192. package/icons/svgs/warning_16x16.svg +5 -0
  193. package/icons/svgs/warning_24x24.svg +12 -0
  194. package/index.d.ts +26 -2
  195. package/index.js +28 -4
  196. package/index.scss +16 -3
  197. package/layout/Header/HeaderView.scss +3 -3
  198. package/layout/Loader/LoaderView.d.ts +2 -2
  199. package/layout/Loader/LoaderView.js +6 -2
  200. package/layout/Loader/LoaderView.scss +67 -22
  201. package/layout/Notifications/NotificationsItemView.d.ts +1 -2
  202. package/layout/Notifications/NotificationsView.d.ts +1 -2
  203. package/layout/ProgressBar/CircleProgressBarView.d.ts +1 -2
  204. package/layout/ProgressBar/LineProgressBarView.d.ts +1 -2
  205. package/layout/Tooltip/TooltipView.d.ts +1 -2
  206. package/layout/Tooltip/TooltipView.js +6 -6
  207. package/layout/Tooltip/TooltipView.scss +45 -37
  208. package/list/CheckboxColumn/CheckboxColumnView.d.ts +1 -2
  209. package/list/CheckboxColumn/CheckboxColumnView.js +2 -1
  210. package/list/ControlsColumnView/ControlsColumnView.d.ts +1 -2
  211. package/list/Grid/GridView.js +8 -4
  212. package/list/Grid/GridView.scss +148 -37
  213. package/list/Grid/views/ContentColumnView/ContentColumnView.d.ts +3 -0
  214. package/list/Grid/views/ContentColumnView/ContentColumnView.js +51 -0
  215. package/list/Grid/views/ContentColumnView/ContentColumnView.scss +88 -0
  216. package/list/Grid/views/ContentColumnView/index.d.ts +2 -0
  217. package/list/Grid/views/ContentColumnView/index.js +7 -0
  218. package/list/List/ListItemView.d.ts +1 -2
  219. package/list/List/ListView.js +5 -7
  220. package/list/List/ListView.scss +32 -1
  221. package/list/Pagination/PaginationButtonView.js +34 -5
  222. package/list/Pagination/PaginationButtonView.scss +265 -1
  223. package/list/Pagination/PaginationMoreView.js +1 -1
  224. package/list/Pagination/PaginationMoreView.scss +4 -1
  225. package/modal/Modal/ModalView.d.ts +1 -2
  226. package/modal/Modal/ModalView.js +4 -7
  227. package/modal/Modal/ModalView.scss +128 -93
  228. package/modal/TwoFactorModal/TwoFactorModalView.d.ts +1 -2
  229. package/nav/Breadcrubms/BreadcrumbsView.js +9 -1
  230. package/nav/Breadcrubms/BreadcrumbsView.scss +49 -0
  231. package/nav/ButtonGroup/ButtonGroupView.d.ts +2 -0
  232. package/nav/ButtonGroup/ButtonGroupView.js +32 -0
  233. package/nav/ButtonGroup/ButtonGroupView.scss +83 -0
  234. package/nav/Controls/ControlsView.d.ts +1 -2
  235. package/nav/Controls/ControlsView.scss +9 -3
  236. package/nav/Nav/NavBarView.d.ts +1 -2
  237. package/nav/Nav/NavButtonView.d.ts +1 -2
  238. package/nav/Nav/NavIconView.d.ts +1 -2
  239. package/nav/Nav/NavIconView.js +1 -1
  240. package/nav/Nav/NavLinkView.d.ts +1 -2
  241. package/nav/Nav/NavListView.d.ts +1 -2
  242. package/nav/Nav/NavListView.js +1 -1
  243. package/nav/Nav/NavTabsView.d.ts +1 -2
  244. package/nav/Nav/NavTabsView.js +1 -1
  245. package/nav/Tree/TreeView.d.ts +1 -2
  246. package/nav/Tree/TreeView.scss +14 -11
  247. package/package.json +56 -56
  248. package/scss/animations/index.scss +1 -0
  249. package/scss/animations/loading.scss +13 -0
  250. package/scss/fonts.scss +6 -0
  251. package/scss/mixins/button.scss +80 -24
  252. package/scss/mixins/customMixins.scss +5 -0
  253. package/scss/mixins/date.scss +397 -0
  254. package/scss/mixins/index.scss +4 -1
  255. package/scss/mixins/scroll.scss +31 -0
  256. package/scss/mixins/typography.scss +26 -0
  257. package/scss/variables/common/colors.scss +119 -69
  258. package/scss/variables/common/media.scss +2 -0
  259. package/scss/variables/common/typography.scss +96 -28
  260. package/scss/variables/common/variables.scss +1 -0
  261. package/scss/variables/components/input.scss +7 -6
  262. package/scss/variables/index.scss +3 -2
  263. package/scss/variables/normalize.scss +25 -0
  264. package/typography/Text/TextView.d.ts +3 -0
  265. package/typography/Text/TextView.js +46 -0
  266. package/typography/Text/TextView.scss +16 -0
  267. package/typography/Title/TitleView.d.ts +3 -0
  268. package/typography/Title/TitleView.js +50 -0
  269. package/typography/Title/TitleView.scss +16 -0
  270. package/utils/renderIcon.d.ts +9 -0
  271. package/utils/renderIcon.js +27 -0
  272. package/content/Collapse/CollapseItemView.d.ts +0 -2
  273. package/content/Collapse/CollapseItemView.scss +0 -88
  274. package/content/Collapse/CollapseView.d.ts +0 -2
  275. package/icons/fontawesome.d.ts +0 -2
  276. package/icons/fontawesome.js +0 -254
  277. package/list/List/ListItemView.scss +0 -3
  278. package/scss/mixins/card.scss +0 -26
  279. package/scss/variables/components/card.scss +0 -20
@@ -0,0 +1,135 @@
1
+ @import "../../scss/variables";
2
+
3
+ :root {
4
+ --counter-background-color: #ffffff;
5
+ }
6
+
7
+ html[data-theme="dark"] {
8
+ --counter-background-color: #414141;
9
+ }
10
+
11
+ $counter-background-color: var(--counter-background-color);
12
+
13
+ .BadgeView {
14
+ $root: &;
15
+
16
+ display: inline-block;
17
+ position: relative;
18
+ width: fit-content;
19
+
20
+ font-family: $font-family-nunito;
21
+ color: $white;
22
+ font-size: $font-size-xs;
23
+ line-height: 16px;
24
+
25
+ &__content {
26
+ width: 100%;
27
+ height: 100%;
28
+ display: flex;
29
+ flex-flow: row nowrap;
30
+ justify-content: center;
31
+ }
32
+
33
+ &__close {
34
+ width: 16px;
35
+ height: 16px;
36
+ cursor: pointer;
37
+ }
38
+
39
+ $badge-types: (
40
+ "primary": $primary,
41
+ "secondary": $secondary,
42
+ "success": $success,
43
+ "danger": $danger,
44
+ "warning": $warning,
45
+ "info": $info,
46
+ );
47
+
48
+ @each $type, $color in $badge-types {
49
+ &_#{$type} {
50
+ background-color: $color;
51
+
52
+ @if ($type == "warning" or $type == "info") {
53
+ color: $text-color;
54
+
55
+ #{$root}__close {
56
+ svg {
57
+ path {
58
+ stroke: #000;
59
+ }
60
+ }
61
+ }
62
+ }
63
+ }
64
+ }
65
+
66
+ &_size {
67
+ &_lg {
68
+ padding: 4px 8px;
69
+ }
70
+ &_md {
71
+ padding: 3px 8px;
72
+ }
73
+ &_sm {
74
+ padding: 1px 8px;
75
+ }
76
+ }
77
+
78
+ &_squarer {
79
+ border-radius: $radius-small;
80
+ }
81
+
82
+ &_rounder {
83
+ border-radius: $radius-xlarge;
84
+ }
85
+
86
+ &_hasClose {
87
+ #{$root}__message {
88
+ margin-right: 4px;
89
+ }
90
+ }
91
+
92
+ &_has-counter {
93
+ border: 1px solid #e9e9e9;
94
+ border-radius: 100px;
95
+
96
+ background: $light-gray;
97
+ color: $text-color;
98
+ padding: 3px 12px;
99
+
100
+ #{$root}__content {
101
+ height: 100%;
102
+ padding: 0;
103
+ }
104
+
105
+ #{$root}__message {
106
+ margin-right: 8px;
107
+ }
108
+
109
+ #{$root}__counter {
110
+ display: flex;
111
+ justify-content: center;
112
+ align-items: center;
113
+
114
+ margin-right: 4px;
115
+ padding: 0 5.4px;
116
+ background-color: $white;
117
+
118
+ border-radius: $radius-circle;
119
+ background-color: $counter-background-color;
120
+ }
121
+
122
+ #{$root}__counter-content {
123
+ font-weight: $font-weight-sm;
124
+ font-size: $font-size-xs;
125
+ line-height: 16px;
126
+ color: $text-color;
127
+ }
128
+
129
+ #{$root}__close {
130
+ path {
131
+ stroke: #000;
132
+ }
133
+ }
134
+ }
135
+ }
@@ -46,7 +46,7 @@ var CaptionElement_1 = __importDefault(require("./CaptionElement"));
46
46
  function CalendarView(props) {
47
47
  var bem = (0, hooks_1.useBem)('CalendarView');
48
48
  var month = props.month, toYear = props.toYear, fromYear = props.fromYear, showFooter = props.showFooter, onDaySelect = props.onDaySelect, selectedDates = props.selectedDates, onMonthSelect = props.onMonthSelect, numberOfMonths = props.numberOfMonths, toggleCaptionPanel = props.toggleCaptionPanel, isCaptionPanelVisible = props.isCaptionPanelVisible;
49
- var isRange = !!selectedDates[1];
49
+ var isRange = !!selectedDates[0] && !!selectedDates[1];
50
50
  var _a = (0, react_1.useMemo)(function () {
51
51
  var from = selectedDates[0];
52
52
  var to = selectedDates[1];
@@ -1,198 +1,277 @@
1
- .CalendarView {
2
- $root: &;
3
-
4
- position: relative;
5
- color: $calendar-text-color;
6
- font-weight: $calendar-font-weight;
7
- user-select: none;
8
-
9
- .DayPicker-wrapper {
10
- padding-bottom: 0;
11
- }
12
- .DayPicker-Months {
13
- display: flex;
14
- flex-wrap: wrap;
15
- justify-content: center;
16
- }
17
- .DayPicker-Month {
18
- display: table;
19
- border-collapse: separate;
20
- border-spacing: 10px;
21
- margin: 0;
22
- }
23
-
24
- // Body
25
-
26
- .DayPicker-Weekdays {
27
- display: table-header-group;
28
- margin-top: 1em;
29
- }
30
- .DayPicker-WeekdaysRow {
31
- display: table-row;
32
- }
33
- .DayPicker-Weekday {
34
- display: table-cell;
35
- width: 30px;
36
- height: 30px;
37
- padding: 0;
38
- color: inherit;
39
- text-align: center;
40
- font-size: 0.875em;
41
- }
42
- .DayPicker-Weekday abbr[title] {
43
- border-bottom: none;
44
- text-decoration: none;
45
- }
46
-
47
- .DayPicker-Body {
48
- display: table-row-group;
49
- }
50
- .DayPicker-Week {
51
- display: table-row;
52
-
53
- &--disabled {
54
- pointer-events: none;
55
- opacity: .5;
56
- }
57
- }
58
- .DayPicker-Day {
59
- position: relative;
60
- display: table-cell;
1
+ :root {
2
+ --day-background-color-hover: rgba(0, 0, 0, 0.1);
3
+ --calendar-border-color: #f1f5f7;
4
+ }
61
5
 
62
- padding: 0;
63
- border-radius: $calendar-day-border-radius;
6
+ html[data-theme="dark"] {
7
+ --day-background-color-hover: rgba(255, 255, 255, 0.1);
8
+ --calendar-border-color: #5b5c6b;
9
+ }
64
10
 
65
- vertical-align: middle;
66
- text-align: center;
11
+ $day-background-color-hover: var(--day-background-color-hover);
12
+ $calendar-border-color: var(--calendar-border-color);
13
+
14
+ @mixin calendar-button () {
15
+ padding: 5px 12.5px;
16
+ border-radius: $radius-small;
17
+ border: 1px solid $gray;
18
+ background-color: transparent;
19
+ background-image: none;
20
+ box-shadow: none;
67
21
  cursor: pointer;
22
+ color: $text-color;
23
+ font-size: $font-size-sm;
24
+ line-height: $line-height-lg;
25
+ }
68
26
 
69
- transition-property: background-color, box-shadow, color;
70
- transition-duration: .1s;
27
+ .CalendarView {
28
+ $root: &;
29
+ position: relative;
30
+ color: $text-color;
31
+ font-weight: $font-weight-md;
32
+ user-select: none;
33
+ padding: 12px;
71
34
 
72
- &::before {
73
- content: '';
74
- height: 30px;
75
- left: 0;
76
- position: absolute;
77
- right: 0;
78
- top: 50%;
79
- transform: translate(-5px, -50%);
80
- width: 40px;
81
- z-index: 1;
35
+ .DayPicker-wrapper {
36
+ padding-bottom: 0;
82
37
  }
83
38
 
84
- &--outside {
85
- color: $calendar-secondary-color;
39
+ .DayPicker-Months {
40
+ display: flex;
41
+ flex-wrap: wrap;
42
+ justify-content: center;
43
+ row-gap: 12px;
86
44
  }
87
45
 
88
- &--today {
89
- #{$root}__day {
90
- box-shadow: $calendar-today-shadow;
91
- }
46
+ .DayPicker-Month {
47
+ margin: 0;
92
48
  }
93
49
 
94
- &--disabled {
95
- pointer-events: none;
96
- opacity: .5;
50
+ // Body
51
+ .DayPicker-Weekdays {
52
+ margin-top: 0;
97
53
  }
98
- }
99
54
 
100
- // Footer
55
+ .DayPicker-WeekdaysRow {
56
+ display: inline-flex;
57
+ column-gap: 16px;
58
+ }
101
59
 
102
- .DayPicker-Footer {
103
- height: 50px;
60
+ .DayPicker-Weekday {
61
+ display: inline-flex;
62
+ justify-content: center;
63
+ align-items: center;
64
+ width: 34px;
65
+ height: 34px;
66
+ padding: 0;
67
+ color: inherit;
68
+ text-align: center;
69
+ vertical-align: middle;
70
+ font-size: $font-size-base;
71
+ line-height: $line-height-base;
72
+ font-weight: $font-weight-lg;
73
+ text-transform: capitalize;
74
+ }
104
75
 
105
- display: flex;
106
- flex-flow: row nowrap;
107
- align-items: center;
108
- justify-content: center;
109
- padding: 0 10px;
76
+ .DayPicker-Weekday abbr[title] {
77
+ border-bottom: none;
78
+ text-decoration: none;
79
+ }
110
80
 
111
- border-top: 1px solid $calendar-secondary-color;
112
- }
113
- .DayPicker-TodayButton {
114
- border: none;
115
- background-color: transparent;
116
- background-image: none;
117
- box-shadow: none;
118
- font-size: 0.875em;
119
- cursor: pointer;
120
- color: $calendar-primary-color;
121
- font-weight: $calendar-font-weight;
122
- }
123
-
124
- // Days selection
125
-
126
- // Selected day
127
- .DayPicker-Day--selected:not(.DayPicker-Day--inRange) {
128
- color: $calendar-selected-text-color;
129
- border-radius: $calendar-day-border-radius;
130
- background-color: $calendar-primary-color;
131
- box-shadow: $calendar-selected-shadow;
132
- }
133
-
134
- // Hover
135
- .DayPicker-Day:not(.DayPicker-Day--disabled):not(.DayPicker-Day--selected):not(.DayPicker-Day--outside):hover {
136
- background-color: $calendar-secondary-light-color !important;
137
- box-shadow: $calendar-hover-shadow;
138
- }
139
-
140
- &__day {
141
- position: relative;
142
- z-index: 1;
143
- width: 30px;
144
- height: 30px;
145
- line-height: 30px;
146
- border-radius: $calendar-day-border-radius;
147
- }
81
+ .DayPicker-Body {
82
+ display: flex;
83
+ flex-flow: column nowrap;
84
+ row-gap: 12px;
85
+ }
86
+
87
+ .DayPicker-Week {
88
+ display: flex;
89
+ width: 100%;
90
+ column-gap: 16px;
148
91
 
149
- &_ranged {
92
+ &--disabled {
93
+ pointer-events: none;
94
+ opacity: 0.5;
95
+ }
96
+ }
150
97
 
151
98
  .DayPicker-Day {
152
- &--start {
153
- color: $white;
99
+ position: relative;
100
+ padding: 0;
101
+ border-radius: $radius-large;
154
102
 
155
- #{$root}__day {
156
- background-color: $calendar-primary-color;
157
- box-shadow: $calendar-selected-shadow;
158
- }
103
+ vertical-align: middle;
104
+ text-align: center;
105
+ cursor: pointer;
106
+
107
+ transition-property: background-color, box-shadow, color;
108
+ transition-duration: 0.1s;
159
109
 
160
110
  &::before {
161
- background-color: $calendar-primary-light-color;
162
- width: 10px;
163
- transform: translate(25px, -50%);
111
+ content: "";
112
+ height: 30px;
113
+ left: 0;
114
+ position: absolute;
115
+ right: 0;
116
+ top: 50%;
117
+ transform: translate(-5px, -50%);
118
+ width: 40px;
119
+ z-index: 1;
164
120
  }
165
- }
166
121
 
167
- &--end {
168
- color: #fff;
122
+ &::after {
123
+ position: absolute;
124
+ content: "";
125
+ display: block;
126
+ width: 100%;
127
+ height: 100%;
128
+ top: 0;
129
+ left: 0;
130
+ right: 0;
131
+ bottom: 0;
132
+ border-width: 4px;
133
+ border-style: solid;
134
+ border-radius: 16px;
135
+ border-color: $day-background-color-hover;
136
+ transform: translate(-4px, -4px);
137
+ opacity: 0;
138
+ transition: opacity 150ms ease-in-out;
139
+ z-index: 9;
140
+ }
169
141
 
170
- #{$root}__day {
171
- background-color: $calendar-primary-color;
172
- box-shadow: $calendar-selected-shadow;
142
+ &:focus {
143
+ outline: none;
144
+ }
145
+
146
+ &:focus:not(:active)::after {
147
+ opacity: 1;
173
148
  }
174
149
 
175
- &::before {
176
- background-color: $calendar-primary-light-color;
177
- width: 10px;
150
+ &--outside {
151
+ color: $placeholder-color;
152
+
178
153
  }
179
- }
180
154
 
155
+ &--today {
156
+ #{$root}__day {
157
+ border: 1px solid $primary;
158
+ color: $primary;
159
+ }
160
+ }
181
161
 
182
- &--inRange {
183
- &::before {
184
- background-color: $calendar-primary-light-color;
162
+ &--disabled {
163
+ pointer-events: none;
164
+ opacity: 0.5;
185
165
  }
186
- }
166
+ }
187
167
 
188
- &--outRange {
189
- pointer-events: none;
190
- &::before {
191
- background-color: $calendar-primary-light-color;
168
+ // Footer
169
+ .DayPicker-Footer {
170
+ margin-top: 8px;
171
+ display: flex;
172
+ flex-flow: row nowrap;
173
+ align-items: center;
174
+ justify-content: flex-start;
175
+ }
176
+
177
+ .DayPicker-TodayButton {
178
+ @include calendar-button();
179
+ }
180
+
181
+ // Days selection
182
+ // Selected day
183
+ .DayPicker-Day--selected:not(.DayPicker-Day--inRange) {
184
+ color: $white;
185
+ background-color: $primary;
186
+ }
187
+
188
+ .DayPicker-Day--selected.DayPicker-Day--today .CalendarView__day {
189
+ color: $white;
190
+ }
191
+
192
+ // Hover
193
+ .DayPicker-Day:not(.DayPicker-Day--disabled):not(.DayPicker-Day--selected):not(.DayPicker-Day--outside):not(
194
+ .DayPicker-Day--today
195
+ ):hover {
196
+ background-color: $day-background-color-hover;
197
+ }
198
+
199
+ .DayPicker-Day--today:hover {
200
+ background-color: transparent;
201
+
202
+ .CalendarView__day {
203
+ transition: background-color 150ms ease-in-out;
192
204
  }
193
- }
205
+ }
194
206
 
207
+ &__day {
208
+ position: relative;
209
+ z-index: 1;
210
+ width: 34px;
211
+ height: 34px;
212
+ line-height: 30px;
213
+ border-radius: $radius-large;
214
+ display: flex;
215
+ justify-content: center;
216
+ align-items: center;
195
217
  }
196
218
 
197
- }
219
+ &_ranged {
220
+ .DayPicker-Day {
221
+ &--start {
222
+ color: $white;
223
+
224
+ #{$root}__day {
225
+ background-color: $primary;
226
+ }
227
+
228
+ &::before {
229
+ width: 50px;
230
+ height: 42px;
231
+ background-color: $primary-light;
232
+ border-radius: 16px 0px 0px 16px;
233
+ }
234
+ }
235
+
236
+ &--end {
237
+ color: #fff;
238
+
239
+ #{$root}__day {
240
+ background-color: $calendar-primary-color;
241
+ }
242
+
243
+ &::before {
244
+ width: 46px;
245
+ height: 42px;
246
+ background-color: $primary-light;
247
+ border-radius: 0px 16px 16px 0px;
248
+ }
249
+ }
250
+
251
+ &--inRange {
252
+ &::before {
253
+ background-color: $primary-light;
254
+ width: 50px;
255
+ height: 42px;
256
+ }
257
+ }
258
+
259
+ //Today in range
260
+ &--inRange.DayPicker-Day--selected.DayPicker-Day--today .CalendarView__day {
261
+ color: $primary;
262
+ }
263
+
264
+ &--inRange:hover .CalendarView__day {
265
+ transition: background-color 150ms ease-in-out;
266
+ background-color: $day-background-color-hover;
267
+ }
268
+
269
+ &--outRange {
270
+ pointer-events: none;
271
+ &::before {
272
+ background-color: $calendar-primary-light-color;
273
+ }
274
+ }
275
+ }
276
+ }
198
277
  }
@@ -57,16 +57,28 @@ function CaptionElement(props) {
57
57
  }
58
58
  return result;
59
59
  }, [fromYear, toYear]);
60
+ var icons = (0, react_1.useMemo)(function () { return [
61
+ {
62
+ name: 'double_arrow_left',
63
+ onClick: function () { return handleYearChange(currentYear - 1); }
64
+ },
65
+ {
66
+ name: 'arrow_left_24x24',
67
+ externalClass: 'one-arrow',
68
+ onClick: function () { return handleMonthChange(currentMonth - 1); }
69
+ },
70
+ {
71
+ name: 'arrow_right_24x24',
72
+ externalClass: 'one-arrow',
73
+ onClick: function () { return handleMonthChange(currentMonth + 1); }
74
+ },
75
+ {
76
+ name: 'double_arrow_right',
77
+ onClick: function () { return handleYearChange(currentYear + 1); }
78
+ },
79
+ ]; }, [currentYear, handleYearChange, currentMonth, handleMonthChange]);
60
80
  return (React.createElement("div", { className: bem(bem.block()) },
61
81
  React.createElement("div", { className: bem.element('container') },
62
- React.createElement(Icon_1["default"], { className: bem.element('button'), onClick: function (e) {
63
- e.preventDefault();
64
- handleYearChange(currentYear - 1);
65
- }, name: 'angle-double-left' }),
66
- React.createElement(Icon_1["default"], { className: bem.element('button', 'one-arrow'), onClick: function (e) {
67
- e.preventDefault();
68
- handleMonthChange(currentMonth - 1);
69
- }, name: 'angle-left' }),
70
82
  React.createElement("div", { className: bem.element('content-container'), onKeyPress: function (e) {
71
83
  e.preventDefault();
72
84
  toggleCaptionPanel();
@@ -76,14 +88,10 @@ function CaptionElement(props) {
76
88
  }, role: 'button', tabIndex: 0 },
77
89
  React.createElement("span", { className: bem.element('selected-month') }, months.find(function (month) { return month.id === currentMonth; }).label),
78
90
  React.createElement("span", { className: bem.element('selected-year') }, years.find(function (year) { return year === currentYear; }))),
79
- React.createElement(Icon_1["default"], { className: bem.element('button', 'one-arrow'), onClick: function (e) {
80
- e.preventDefault();
81
- handleMonthChange(currentMonth + 1);
82
- }, name: 'angle-right' }),
83
- React.createElement(Icon_1["default"], { className: bem.element('button'), onClick: function (e) {
91
+ React.createElement("div", { className: bem.element('container-icons') }, icons.map(function (icon, iconIndex) { return (React.createElement(Icon_1["default"], { key: iconIndex, name: icon.name, onClick: function (e) {
84
92
  e.preventDefault();
85
- handleYearChange(currentYear + 1);
86
- }, name: 'angle-double-right' })),
93
+ icon.onClick();
94
+ }, className: bem.element('button', icon.externalClass) })); }))),
87
95
  isCaptionPanelVisible && (React.createElement("div", { className: bem.element('panel', { 'full-height': !props.showCalendarFooter }) },
88
96
  React.createElement("div", { className: bem.element('panel-header', 'months') }, __('Месяц')),
89
97
  React.createElement("div", { className: bem.element('panel-header', 'years') }, __('Год')),