@steroidsjs/bootstrap 3.0.0-beta.5 → 3.0.0-beta.50

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 (263) 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.scss +209 -176
  16. package/content/Calendar/CaptionElement.js +23 -15
  17. package/content/Calendar/CaptionElement.scss +124 -103
  18. package/content/Card/CardView.js +36 -14
  19. package/content/Card/CardView.scss +139 -107
  20. package/content/Detail/DetailView.scss +75 -52
  21. package/content/DropDown/DropDownView.d.ts +0 -1
  22. package/content/DropDown/DropDownView.js +6 -4
  23. package/content/DropDown/DropDownView.scss +196 -27
  24. package/content/Icon/IconView.d.ts +1 -2
  25. package/content/Icon/IconView.js +2 -2
  26. package/content/Icon/IconView.scss +1 -23
  27. package/content/Menu/MenuItemView.d.ts +2 -0
  28. package/content/Menu/MenuItemView.js +15 -0
  29. package/content/Menu/MenuItemView.scss +63 -0
  30. package/content/Menu/MenuView.d.ts +2 -0
  31. package/content/Menu/MenuView.js +30 -0
  32. package/content/Menu/MenuView.scss +43 -0
  33. package/form/AutoCompleteField/AutoCompleteFieldView.d.ts +1 -2
  34. package/form/AutoCompleteField/AutoCompleteFieldView.js +62 -8
  35. package/form/AutoCompleteField/AutoCompleteFieldView.scss +199 -142
  36. package/form/Button/ButtonView.d.ts +1 -2
  37. package/form/Button/ButtonView.js +13 -9
  38. package/form/Button/ButtonView.scss +168 -68
  39. package/form/CheckboxField/CheckboxFieldView.d.ts +1 -2
  40. package/form/CheckboxField/CheckboxFieldView.js +6 -4
  41. package/form/CheckboxField/CheckboxFieldView.scss +195 -36
  42. package/form/CheckboxListField/CheckboxListFieldView.d.ts +1 -2
  43. package/form/CheckboxListField/CheckboxListFieldView.js +18 -15
  44. package/form/CheckboxListField/CheckboxListFieldView.scss +7 -41
  45. package/form/DateField/DateFieldView.js +5 -5
  46. package/form/DateField/DateFieldView.scss +155 -71
  47. package/form/DateTimeField/DateTimeFieldView.d.ts +1 -2
  48. package/form/DropDownField/DropDownFieldView.js +31 -47
  49. package/form/DropDownField/DropDownFieldView.scss +388 -182
  50. package/form/DropDownField/utils.d.ts +2 -0
  51. package/form/DropDownField/utils.js +15 -0
  52. package/form/DropDownFieldItem/DropDownFieldItemView.d.ts +2 -0
  53. package/form/DropDownFieldItem/DropDownFieldItemView.js +78 -0
  54. package/form/DropDownFieldItem/DropDownFieldItemView.scss +218 -0
  55. package/form/FieldLayout/FieldLayoutView.d.ts +1 -2
  56. package/form/FieldLayout/FieldLayoutView.js +13 -9
  57. package/form/FieldLayout/FieldLayoutView.scss +119 -19
  58. package/form/FieldList/FieldListItemView.js +6 -4
  59. package/form/FieldList/FieldListItemView.scss +17 -39
  60. package/form/FieldList/FieldListView.js +9 -8
  61. package/form/FieldList/FieldListView.scss +58 -18
  62. package/form/FieldSet/FieldSetView.js +4 -2
  63. package/form/FieldSet/FieldSetView.scss +39 -0
  64. package/form/FileField/FileFieldItemView.d.ts +1 -2
  65. package/form/FileField/FileFieldItemView.js +31 -6
  66. package/form/FileField/FileFieldItemView.scss +254 -13
  67. package/form/FileField/FileFieldView.d.ts +1 -2
  68. package/form/FileField/FileFieldView.js +6 -8
  69. package/form/FileField/FileFieldView.scss +33 -4
  70. package/form/Form/FormView.js +1 -4
  71. package/form/Form/FormView.scss +1 -14
  72. package/form/HtmlField/HtmlFieldView.d.ts +1 -2
  73. package/form/HtmlField/HtmlFieldView.scss +6 -3
  74. package/form/ImageField/ImageFieldView.js +1 -1
  75. package/form/InputField/InputFieldView.d.ts +1 -2
  76. package/form/InputField/InputFieldView.js +30 -13
  77. package/form/InputField/InputFieldView.scss +265 -99
  78. package/form/NumberField/NumberFieldView.d.ts +1 -2
  79. package/form/NumberField/NumberFieldView.js +19 -13
  80. package/form/NumberField/NumberFieldView.scss +195 -89
  81. package/form/PasswordField/PasswordFieldView.d.ts +1 -2
  82. package/form/PasswordField/PasswordFieldView.js +11 -9
  83. package/form/PasswordField/PasswordFieldView.scss +231 -63
  84. package/form/RadioField/RadioFieldView.d.ts +2 -0
  85. package/form/RadioField/RadioFieldView.js +57 -0
  86. package/form/RadioField/RadioFieldView.scss +226 -0
  87. package/form/RadioListField/RadioListFieldView.d.ts +1 -2
  88. package/form/RadioListField/RadioListFieldView.js +20 -16
  89. package/form/RadioListField/RadioListFieldView.scss +11 -1
  90. package/form/ReCaptchaField/ReCaptchaFieldView.d.ts +1 -2
  91. package/form/ReCaptchaField/ReCaptchaFieldView.js +2 -2
  92. package/form/SliderField/SliderFieldView.d.ts +1 -2
  93. package/form/SwitcherField/SwitcherFieldView.d.ts +1 -2
  94. package/form/SwitcherField/SwitcherFieldView.js +12 -7
  95. package/form/SwitcherField/SwitcherFieldView.scss +188 -1
  96. package/form/TextField/TextFieldView.d.ts +1 -2
  97. package/form/TextField/TextFieldView.js +10 -2
  98. package/form/TextField/TextFieldView.scss +144 -2
  99. package/form/TimeField/TimeFieldView.d.ts +1 -2
  100. package/icons/index.d.ts +2 -0
  101. package/icons/index.js +103 -0
  102. package/icons/svgs/add.svg +4 -0
  103. package/icons/svgs/add_square.svg +5 -0
  104. package/icons/svgs/arrow_down_18x18.svg +4 -0
  105. package/icons/svgs/arrow_down_24x24.svg +4 -0
  106. package/icons/svgs/arrow_drop_down_10x10.svg +3 -0
  107. package/icons/svgs/arrow_left_18x18.svg +4 -0
  108. package/icons/svgs/arrow_left_24x24.svg +4 -0
  109. package/icons/svgs/arrow_right_18x18.svg +4 -0
  110. package/icons/svgs/arrow_right_24x24.svg +4 -0
  111. package/icons/svgs/arrow_up_18x18.svg +4 -0
  112. package/icons/svgs/arrow_up_24x24.svg +4 -0
  113. package/icons/svgs/blank.svg +4 -0
  114. package/icons/svgs/calendar_check.svg +5 -0
  115. package/icons/svgs/calendar_range.svg +8 -0
  116. package/icons/svgs/cancel_ellips.svg +4 -0
  117. package/icons/svgs/chart.svg +6 -0
  118. package/icons/svgs/checkmark_12x12.svg +4 -0
  119. package/icons/svgs/checkmark_8x8.svg +4 -0
  120. package/icons/svgs/circle_cross_12x12.svg +4 -0
  121. package/icons/svgs/circle_cross_16x16.svg +4 -0
  122. package/icons/svgs/circle_cross_18x18.svg +4 -0
  123. package/icons/svgs/clip.svg +3 -0
  124. package/icons/svgs/copy.svg +5 -0
  125. package/icons/svgs/cross_12x12.svg +4 -0
  126. package/icons/svgs/cross_4x4.svg +3 -0
  127. package/icons/svgs/cross_8x8.svg +4 -0
  128. package/icons/svgs/cut.svg +3 -0
  129. package/icons/svgs/date_range.svg +8 -0
  130. package/icons/svgs/default_16x16.svg +4 -0
  131. package/icons/svgs/default_24x24.svg +11 -0
  132. package/icons/svgs/double_arrow_down.svg +5 -0
  133. package/icons/svgs/double_arrow_left.svg +5 -0
  134. package/icons/svgs/double_arrow_right.svg +5 -0
  135. package/icons/svgs/double_arrow_up.svg +5 -0
  136. package/icons/svgs/doughnut_chart.svg +5 -0
  137. package/icons/svgs/edit.svg +4 -0
  138. package/icons/svgs/error_16x16.svg +5 -0
  139. package/icons/svgs/error_24x24.svg +12 -0
  140. package/icons/svgs/expand_down.svg +3 -0
  141. package/icons/svgs/expand_left.svg +3 -0
  142. package/icons/svgs/expand_left_double.svg +4 -0
  143. package/icons/svgs/expand_right.svg +3 -0
  144. package/icons/svgs/expand_right_double.svg +4 -0
  145. package/icons/svgs/expand_up.svg +3 -0
  146. package/icons/svgs/file_dock.svg +6 -0
  147. package/icons/svgs/filter.svg +3 -0
  148. package/icons/svgs/fluid.svg +4 -0
  149. package/icons/svgs/folder.svg +3 -0
  150. package/icons/svgs/group.svg +8 -0
  151. package/icons/svgs/home.svg +4 -0
  152. package/icons/svgs/img_box.svg +5 -0
  153. package/icons/svgs/import.svg +4 -0
  154. package/icons/svgs/info_16x16.svg +5 -0
  155. package/icons/svgs/info_24x24.svg +12 -0
  156. package/icons/svgs/left_12x12.svg +3 -0
  157. package/icons/svgs/loading_default.svg +3 -0
  158. package/icons/svgs/loading_icon_thick.svg +3 -0
  159. package/icons/svgs/loading_purple.svg +9 -0
  160. package/icons/svgs/map.svg +7 -0
  161. package/icons/svgs/menu_dots.svg +5 -0
  162. package/icons/svgs/menu_left.svg +5 -0
  163. package/icons/svgs/minis_sq.svg +4 -0
  164. package/icons/svgs/paste.svg +8 -0
  165. package/icons/svgs/pie_chart.svg +5 -0
  166. package/icons/svgs/pin.svg +4 -0
  167. package/icons/svgs/sad.svg +6 -0
  168. package/icons/svgs/search.svg +4 -0
  169. package/icons/svgs/setting_line.svg +3 -0
  170. package/icons/svgs/share.svg +7 -0
  171. package/icons/svgs/star.svg +3 -0
  172. package/icons/svgs/success_16x16.svg +4 -0
  173. package/icons/svgs/success_24x24.svg +11 -0
  174. package/icons/svgs/support.svg +3 -0
  175. package/icons/svgs/trash.svg +6 -0
  176. package/icons/svgs/upload.svg +4 -0
  177. package/icons/svgs/user.svg +4 -0
  178. package/icons/svgs/view.svg +4 -0
  179. package/icons/svgs/view_hide.svg +5 -0
  180. package/icons/svgs/warning_16x16.svg +5 -0
  181. package/icons/svgs/warning_24x24.svg +12 -0
  182. package/index.d.ts +20 -2
  183. package/index.js +22 -4
  184. package/index.scss +14 -3
  185. package/layout/Header/HeaderView.scss +3 -3
  186. package/layout/Loader/LoaderView.d.ts +2 -2
  187. package/layout/Loader/LoaderView.js +6 -2
  188. package/layout/Loader/LoaderView.scss +67 -22
  189. package/layout/Notifications/NotificationsItemView.d.ts +1 -2
  190. package/layout/Notifications/NotificationsView.d.ts +1 -2
  191. package/layout/ProgressBar/CircleProgressBarView.d.ts +1 -2
  192. package/layout/ProgressBar/LineProgressBarView.d.ts +1 -2
  193. package/layout/Tooltip/TooltipView.d.ts +1 -2
  194. package/layout/Tooltip/TooltipView.js +6 -6
  195. package/layout/Tooltip/TooltipView.scss +45 -37
  196. package/list/CheckboxColumn/CheckboxColumnView.d.ts +1 -2
  197. package/list/CheckboxColumn/CheckboxColumnView.js +2 -1
  198. package/list/ControlsColumnView/ControlsColumnView.d.ts +1 -2
  199. package/list/Grid/GridView.js +8 -4
  200. package/list/Grid/GridView.scss +148 -37
  201. package/list/Grid/views/ContentColumnView/ContentColumnView.d.ts +3 -0
  202. package/list/Grid/views/ContentColumnView/ContentColumnView.js +51 -0
  203. package/list/Grid/views/ContentColumnView/ContentColumnView.scss +88 -0
  204. package/list/Grid/views/ContentColumnView/index.d.ts +2 -0
  205. package/list/Grid/views/ContentColumnView/index.js +7 -0
  206. package/list/List/ListItemView.d.ts +1 -2
  207. package/list/List/ListView.js +5 -7
  208. package/list/List/ListView.scss +32 -1
  209. package/list/Pagination/PaginationButtonView.js +34 -5
  210. package/list/Pagination/PaginationButtonView.scss +265 -1
  211. package/list/Pagination/PaginationMoreView.js +1 -1
  212. package/list/Pagination/PaginationMoreView.scss +4 -1
  213. package/modal/Modal/ModalView.d.ts +1 -2
  214. package/modal/Modal/ModalView.js +4 -7
  215. package/modal/Modal/ModalView.scss +129 -93
  216. package/modal/TwoFactorModal/TwoFactorModalView.d.ts +1 -2
  217. package/nav/Breadcrubms/BreadcrumbsView.js +9 -1
  218. package/nav/Breadcrubms/BreadcrumbsView.scss +49 -0
  219. package/nav/Controls/ControlsView.d.ts +1 -2
  220. package/nav/Controls/ControlsView.scss +9 -3
  221. package/nav/Nav/NavBarView.d.ts +1 -2
  222. package/nav/Nav/NavButtonView.d.ts +1 -2
  223. package/nav/Nav/NavIconView.d.ts +1 -2
  224. package/nav/Nav/NavIconView.js +1 -1
  225. package/nav/Nav/NavLinkView.d.ts +1 -2
  226. package/nav/Nav/NavListView.d.ts +1 -2
  227. package/nav/Nav/NavListView.js +1 -1
  228. package/nav/Nav/NavTabsView.d.ts +1 -2
  229. package/nav/Nav/NavTabsView.js +1 -1
  230. package/nav/Tree/TreeView.d.ts +1 -2
  231. package/nav/Tree/TreeView.scss +14 -11
  232. package/package.json +56 -56
  233. package/scss/animations/index.scss +1 -0
  234. package/scss/animations/loading.scss +13 -0
  235. package/scss/fonts.scss +6 -0
  236. package/scss/mixins/button.scss +80 -24
  237. package/scss/mixins/customMixins.scss +5 -0
  238. package/scss/mixins/index.scss +3 -1
  239. package/scss/mixins/scroll.scss +31 -0
  240. package/scss/mixins/typography.scss +26 -0
  241. package/scss/variables/common/colors.scss +119 -69
  242. package/scss/variables/common/media.scss +2 -0
  243. package/scss/variables/common/typography.scss +96 -28
  244. package/scss/variables/common/variables.scss +1 -0
  245. package/scss/variables/components/input.scss +7 -6
  246. package/scss/variables/index.scss +3 -2
  247. package/scss/variables/normalize.scss +25 -0
  248. package/typography/Text/TextView.d.ts +3 -0
  249. package/typography/Text/TextView.js +46 -0
  250. package/typography/Text/TextView.scss +16 -0
  251. package/typography/Title/TitleView.d.ts +3 -0
  252. package/typography/Title/TitleView.js +50 -0
  253. package/typography/Title/TitleView.scss +16 -0
  254. package/utils/renderIcon.d.ts +9 -0
  255. package/utils/renderIcon.js +27 -0
  256. package/content/Collapse/CollapseItemView.d.ts +0 -2
  257. package/content/Collapse/CollapseItemView.scss +0 -88
  258. package/content/Collapse/CollapseView.d.ts +0 -2
  259. package/icon/fontawesome.d.ts +0 -2
  260. package/icon/fontawesome.js +0 -254
  261. package/list/List/ListItemView.scss +0 -3
  262. package/scss/mixins/card.scss +0 -26
  263. package/scss/variables/components/card.scss +0 -20
@@ -1,96 +1,196 @@
1
- .ButtonView {
2
- $root: &;
1
+ $btn-font-weight-sm: 400;
2
+ $btn-font-weight-lg: 800;
3
+ $btn-line-height: 24px;
4
+ $btn-letter-spacing: 0.1em;
3
5
 
4
- transition-property: color, background-color, border-color, box-shadow;
5
- transition-duration: .15s;
6
- transition-timing-function: ease-in-out;
6
+ .ButtonView {
7
+ $root: &;
7
8
 
8
- &_button {
9
- position: relative;
10
- border-radius: $button-border-radius;
11
- user-select: none;
12
- border: $button-border;
9
+ transition-property: color, background-color, border-color, box-shadow;
10
+ transition-duration: $transition-duration;
11
+ transition-timing-function: ease-in-out;
13
12
 
14
- padding: $button-padding-y $button-padding-x;
15
13
  display: flex;
16
14
  justify-content: center;
17
15
  align-items: center;
18
16
 
19
- font-weight: $button-font-weight;
20
- font-size: $button-font-size;
17
+ cursor: pointer;
18
+
19
+ &_button {
20
+ position: relative;
21
+ border-radius: $radius-small;
22
+ user-select: none;
23
+ border: 3px solid transparent;
24
+
25
+ padding: 0 20px;
26
+ display: flex;
27
+ justify-content: center;
28
+ align-items: center;
29
+
30
+ font-family: $font-family-nunito;
31
+ font-weight: $btn-font-weight-sm;
32
+ font-size: $font-size-sm;
33
+ line-height: $btn-line-height;
34
+ outline: none;
35
+ }
36
+
37
+ @each $colorName, $colorMap in $color-themes {
38
+ &_color_#{$colorName} {
39
+ @include button-theme($colorMap, $colorName, $root);
40
+ }
41
+ }
21
42
 
22
- @each $color, $value in $color-themes {
23
- &#{$root}_color_#{$color} {
24
- @include button-theme($value)
25
- }
43
+ @each $colorName, $colorMap in $color-themes {
44
+ &_outline_#{$colorName} {
45
+ @include button-outline-theme($colorMap, $colorName, $root);
46
+ }
26
47
  }
27
48
 
28
- @each $color, $value in $color-themes {
29
- &#{$root}_outline_#{$color} {
30
- @include button-outline-theme($value)
31
- }
49
+ &__label {
50
+ display: flex;
51
+ justify-content: center;
52
+ align-items: center;
32
53
  }
33
54
 
34
- }
55
+ &_block {
56
+ display: block;
57
+ width: 100%;
35
58
 
36
- &_disabled {
37
- opacity: .5;
38
- color: rgba(0, 0, 0, .25);
39
- cursor: not-allowed;
40
- input {
41
- cursor: inherit;
59
+ #{$root}__label {
60
+ justify-content: center;
61
+ }
42
62
  }
43
- }
44
63
 
45
- &_size {
46
- &_sm {
47
- height: $button-height-sm;
48
- font-size: $button-font-size-sm;
64
+ &_tag {
65
+ &-a {
66
+ width: auto;
67
+ }
49
68
  }
50
- &_md {
51
- height: $button-height-md;
52
- font-size: $button-font-size-md;
69
+
70
+ &_disabled {
71
+ opacity: 0.5;
72
+ color: rgba(0, 0, 0, 0.1);
73
+ cursor: not-allowed;
74
+
75
+ input {
76
+ cursor: inherit;
77
+ }
53
78
  }
54
- &_lg {
55
- height: $button-height-lg;
56
- font-size: $button-font-size-lg;
79
+
80
+ &_size {
81
+ &_sm {
82
+ height: 34px;
83
+ font-size: $font-size-sm;
84
+ border-radius: $radius-small;
85
+ }
86
+ &_md {
87
+ height: 46px;
88
+ font-size: $font-size-base;
89
+ border-radius: $radius-large;
90
+ }
91
+ &_lg {
92
+ height: 56px;
93
+ font-size: $font-size-lg;
94
+ border-radius: $radius-large;
95
+ }
57
96
  }
58
- }
59
97
 
60
- &_link {
61
- justify-content: flex-start;
62
- background-color: transparent;
63
- }
98
+ &_link {
99
+ display: inline;
100
+ width: auto;
101
+ height: auto;
102
+ background-color: transparent;
64
103
 
65
- &__icon {
66
- margin-right: 3px;
104
+ &:focus-visible, &:focus {
105
+ border: none;
106
+ }
67
107
 
68
- &_without-label {
69
- margin: 0;
108
+ &:hover,&:active {
109
+ background-color: transparent;
110
+ }
111
+
70
112
  }
71
- }
72
113
 
73
- &_failed {
74
- &, &:hover {
75
- border-color: $danger;
76
- box-shadow: 0 0 1rem rgba($danger, .2);
114
+ &__link {
115
+ display: inline-flex;
116
+ align-items: center;
77
117
  }
78
- }
79
118
 
80
- &_loading &__label {
81
- opacity: 0;
82
- }
119
+ &__icon {
120
+ margin-right: 10px;
121
+ width: fit-content;
122
+ height: fit-content;
123
+ &_without-label {
124
+ margin: 0;
125
+ }
126
+
127
+ svg path {
128
+ transition: stroke 0.15s ease-in-out;
129
+ }
130
+ }
83
131
 
84
- &__preloader {
85
- position: absolute;
86
- top: 50%;
87
- left: 50%;
88
- transform: translate(-50%, -50%);
89
- }
132
+ &_failed {
133
+ &,
134
+ &:hover {
135
+ border-color: $danger;
136
+ box-shadow: 0 0 1rem rgba($danger, 0.2);
137
+ }
138
+ }
139
+
140
+ &_loading {
141
+ cursor: default;
142
+ }
90
143
 
91
- &__badge {
92
- position: relative;
93
- top: -1px;
94
- margin-left: 4px;
95
- }
144
+ &__preloader {
145
+ position: absolute;
146
+ top: 50%;
147
+ left: 50%;
148
+ transform: translate(-50%, -50%);
149
+ }
150
+
151
+ &__badge {
152
+ position: relative;
153
+ top: -1px;
154
+ margin-left: 4px;
155
+ border-radius: $radius-small;
156
+ font-size: $font-size-xs;
157
+ line-height: 16px;
158
+ padding: 3px 5px;
159
+
160
+ $badge-types: (
161
+ "primary": $primary,
162
+ "secondary": $secondary,
163
+ "success": $success,
164
+ "danger": $danger,
165
+ "warning": $warning,
166
+ "info": $info,
167
+ );
168
+
169
+ @each $type, $color in $badge-types {
170
+ &_#{$type} {
171
+ background-color: $color;
172
+ }
173
+ }
174
+ }
175
+
176
+ &__loader {
177
+ width: 24px;
178
+ height: 24px;
179
+ display: flex;
180
+ justify-content: center;
181
+ align-items: center;
182
+
183
+ svg {
184
+ width: 14px;
185
+ height: 14px;
186
+ transform-origin: center;
187
+ animation: rotate 1.45s linear infinite;
188
+ }
189
+ }
190
+ }
191
+
192
+ @keyframes rotate {
193
+ 100% {
194
+ transform: rotate(360deg);
195
+ }
96
196
  }
@@ -1,3 +1,2 @@
1
- import { IBemHocOutput } from '@steroidsjs/core/hoc/bem';
2
1
  import { ICheckboxFieldViewProps } from '@steroidsjs/core/ui/form/CheckboxField/CheckboxField';
3
- export default function CheckboxFieldView(props: ICheckboxFieldViewProps & IBemHocOutput): JSX.Element;
2
+ export default function CheckboxFieldView(props: ICheckboxFieldViewProps): JSX.Element;
@@ -43,9 +43,11 @@ var useUniqueId_1 = __importDefault(require("@steroidsjs/core/hooks/useUniqueId"
43
43
  function CheckboxFieldView(props) {
44
44
  var bem = (0, hooks_1.useBem)('CheckboxFieldView');
45
45
  var id = (0, useUniqueId_1["default"])('checkbox');
46
- return (React.createElement("div", { className: bem(bem.block({ 'is-invalid': !!props.errors }), 'custom-control', 'custom-checkbox') },
47
- React.createElement("input", __assign({ className: bem(bem.element('input'), 'custom-control-input', !!props.errors && 'is-invalid', props.className), id: id }, props.inputProps, { disabled: props.disabled, required: props.required })),
48
- React.createElement("label", { className: bem(bem.element('label'), 'custom-control-label'), htmlFor: id },
49
- React.createElement("span", { className: bem.element('label-text', { required: props.required }) }, props.label))));
46
+ return (React.createElement("div", { className: bem(bem.block({
47
+ size: props.size,
48
+ hasErrors: !!props.errors
49
+ }), props.className), style: props.style, onClick: props.onChange },
50
+ React.createElement("input", __assign({ className: bem.element('input'), id: props.id || id }, props.inputProps, { disabled: props.disabled, required: props.required })),
51
+ React.createElement("label", { className: bem.element('label'), htmlFor: props.id || id }, props.label && (React.createElement("span", { className: bem.element('label-text', { required: props.required }) }, props.label)))));
50
52
  }
51
53
  exports["default"] = CheckboxFieldView;
@@ -1,46 +1,205 @@
1
+ :root {
2
+ --disabled-text-color: rgba(0, 0, 0, 0.3);
3
+ }
4
+
5
+ html[data-theme="dark"] {
6
+ --disabled-text-color: rgba(255, 255, 255, 0.3);
7
+ }
8
+
9
+ $disabled-text-color: var(--disabled-text-color);
10
+
1
11
  .CheckboxFieldView {
2
- display: inline-block;
12
+ $root: &;
3
13
 
4
- &__label {
5
- &-text {
6
- &_required:after {
7
- display: inline-block;
8
- content: '*';
9
- color: $danger;
10
- margin: 0 0 0 3px;
11
- }
12
- }
13
- }
14
- .custom-control-label {
15
- &::before, &::after {
16
- top: 0;
14
+ display: inline-flex;
15
+
16
+ font-family: $font-family-nunito;
17
+
18
+ &__input + &__label {
19
+ display: inline-flex;
20
+ align-items: center;
21
+ user-select: none;
17
22
  }
18
- }
19
-
20
- .custom-control-input {
21
- &:checked ~ .custom-control-label {
22
- &::before {
23
- border-color: $primary;
24
- background: $primary;
25
- }
26
- &:hover {
23
+
24
+ &__label {
25
+ position: relative;
26
+ cursor: pointer;
27
+
28
+ //Сам кастомный checkbox
27
29
  &::before {
28
- background: $primary-dark;
30
+ content: "";
31
+ display: inline-block;
32
+ width: 24px;
33
+ height: 24px;
34
+ flex-shrink: 0;
35
+ flex-grow: 0;
36
+
37
+ border: 1px solid $gray;
38
+ border-radius: $radius-small;
39
+
40
+ background-repeat: no-repeat;
41
+ background-position: center center;
42
+ background-size: 50% 50%;
29
43
  }
30
- }
31
- &:active {
32
- &::before {
33
- background: $primary-light;
44
+
45
+ //Псевдоэлемент который служит для применения эффектов на чекбокс
46
+ &::after {
47
+ content: "";
48
+ display: inline-block;
49
+ position: absolute;
50
+ top: 0;
51
+ left: 0;
52
+ width: 26px;
53
+ height: 26px;
54
+
55
+ transform: translate(-12%, -11.5%);
56
+ transition: opacity 150ms ease-in-out;
57
+ opacity: 0;
58
+
59
+ border-radius: $radius-large;
60
+ border: 4px solid $primary-light;
61
+ }
62
+
63
+ &-text {
64
+ margin-left: 8px;
65
+ color: $text-color;
66
+ font-size: $font-size-sm;
67
+ font-weight: $font-weight-md;
68
+ transform: translateY(1px);
34
69
  }
35
- }
36
70
  }
37
- &:disabled ~ .custom-control-label {
38
- color: $border-default;
39
71
 
40
- &::before {
41
- border: unset;
42
- background-color: $back-disabled;
43
- }
72
+ &__input {
73
+ position: absolute;
74
+ z-index: -1;
75
+ opacity: 0;
76
+
77
+ //HOVER
78
+ &:not(:focus):not(:disabled):not(:checked):not(:active) + #{$root}__label:hover::before {
79
+ border-color: #d0d0d0;
80
+ }
81
+
82
+ //ACTIVE
83
+ &:not(:disabled):not(:checked):active + #{$root}__label::before {
84
+ border-color: $primary;
85
+ }
86
+
87
+ &:active:checked + #{$root}__label::after {
88
+ opacity: 0;
89
+ }
90
+
91
+ &:checked:active + #{$root}__label::before {
92
+ background-color: $primary-light;
93
+ border-color: transparent;
94
+ }
95
+
96
+ //FOCUS
97
+ &:focus + #{$root}__label::after {
98
+ opacity: 1;
99
+ }
100
+
101
+ //CHECKED
102
+ &:checked + #{$root}__label::before {
103
+ border-color: $primary;
104
+ background-color: $primary;
105
+ background-image: url("data:image/svg+xml,%3Csvg width='11' height='8' viewBox='0 0 11 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9.20898 1L3.70898 7L1.20898 4.27273' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
106
+ }
107
+
108
+ //DISABLED
109
+ &:disabled + #{$root}__label {
110
+ cursor: not-allowed;
111
+ span {
112
+ color: $disabled-text-color;
113
+ }
114
+
115
+ &::before {
116
+ background: $background-disabled-color;
117
+ border: none;
118
+ }
119
+ }
120
+
121
+ &:disabled:checked #{$root}__label::before {
122
+ background-color: $background-disabled-color;
123
+ border-color: none;
124
+ background-image: url("data:image/svg+xml,%3Csvg width='11' height='9' viewBox='0 0 11 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9.8584 1.48401L4.3584 7.48401L1.8584 4.75674' stroke='black' stroke-opacity='0.1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
125
+ }
126
+ }
127
+
128
+ &_size {
129
+ &_lg {
130
+ #{$root}__label {
131
+ &::before {
132
+ width: 24px;
133
+ height: 24px;
134
+ border-radius: $radius-small;
135
+ }
136
+ &::after {
137
+ width: 26px;
138
+ height: 26px;
139
+ border-radius: $radius-large;
140
+ }
141
+
142
+ &-text {
143
+ margin-left: 12px;
144
+ font-size: $font-size-lg;
145
+ line-height: 24px;
146
+ }
147
+ }
148
+ }
149
+
150
+ &_md {
151
+ #{$root}__label {
152
+ &::before {
153
+ width: 20px;
154
+ height: 20px;
155
+ border-radius: 6px;
156
+ }
157
+
158
+ &::after {
159
+ width: 22px;
160
+ height: 22px;
161
+ border-radius: $radius-medium;
162
+ transform: translate(-13.5%, -13.5%);
163
+ }
164
+
165
+ &-text {
166
+ margin-left: 8px;
167
+ font-size: $font-size-base;
168
+ line-height: 22px;
169
+ }
170
+ }
171
+ }
172
+
173
+ &_sm {
174
+ #{$root}__label {
175
+ &::before {
176
+ width: 16px;
177
+ height: 16px;
178
+ border-radius: 6px;
179
+ }
180
+
181
+ &::after {
182
+ width: 18px;
183
+ height: 18px;
184
+ border-radius: $radius-medium;
185
+ transform: translate(-15.5%, -15.5%);
186
+ }
187
+
188
+ &-text {
189
+ margin-left: 8px;
190
+ font-size: $font-size-sm;
191
+ line-height: 18px;
192
+ }
193
+ }
194
+ }
195
+ }
196
+ }
197
+ .has-errors label {
198
+ &::before {
199
+ border-color: $danger;
200
+ }
201
+
202
+ span {
203
+ color: $danger;
44
204
  }
45
- }
46
205
  }
@@ -1,3 +1,2 @@
1
- import { IBemHocOutput } from '@steroidsjs/core/hoc/bem';
2
1
  import { ICheckboxListFieldViewProps } from '@steroidsjs/core/ui/form/CheckboxListField/CheckboxListField';
3
- export default function CheckboxListFieldView(props: ICheckboxListFieldViewProps & IBemHocOutput): JSX.Element;
2
+ export default function CheckboxListFieldView(props: ICheckboxListFieldViewProps): JSX.Element;
@@ -1,15 +1,4 @@
1
1
  "use strict";
2
- var __assign = (this && this.__assign) || function () {
3
- __assign = Object.assign || function(t) {
4
- for (var s, i = 1, n = arguments.length; i < n; i++) {
5
- s = arguments[i];
6
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
- t[p] = s[p];
8
- }
9
- return t;
10
- };
11
- return __assign.apply(this, arguments);
12
- };
13
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
14
3
  if (k2 === undefined) k2 = k;
15
4
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -41,11 +30,25 @@ var React = __importStar(require("react"));
41
30
  var hooks_1 = require("@steroidsjs/core/hooks");
42
31
  var useUniqueId_1 = __importDefault(require("@steroidsjs/core/hooks/useUniqueId"));
43
32
  function CheckboxListFieldView(props) {
33
+ var _a;
44
34
  var bem = (0, hooks_1.useBem)('CheckboxListFieldView');
45
35
  var prefix = (0, useUniqueId_1["default"])('checkbox');
46
- return (React.createElement("div", { className: bem(bem.block({ 'is-invalid': !!props.errors }), props.className) }, props.items.map(function (item) { return (React.createElement("div", { key: item.id, className: "custom-control custom-checkbox" },
47
- React.createElement("input", __assign({}, props.inputProps, { disabled: props.disabled, required: props.required, id: "".concat(prefix, "_").concat(item.id), className: bem(bem.element('input'), 'custom-control-input', !!props.errors && 'is-invalid'), checked: props.selectedIds.includes(item.id), onChange: function () { return props.onItemSelect(item.id); }, onMouseOver: function () { return props.onItemHover(item.id); } })),
48
- React.createElement("label", { className: bem(bem.element('label'), 'custom-control-label'), htmlFor: "".concat(prefix, "_").concat(item.id) },
49
- React.createElement("span", { className: bem.element('label-text', { required: props.required }) }, item.label)))); })));
36
+ return (React.createElement("div", { className: bem(bem.block((_a = {},
37
+ _a["".concat(props.orientation)] = !!props.orientation,
38
+ _a))) }, props.items.map(function (checkbox, checkboxIndex) { return props.renderCheckbox({
39
+ inputProps: {
40
+ name: "".concat(prefix, "_").concat(checkbox.id),
41
+ checked: null,
42
+ type: 'checkbox',
43
+ disabled: false,
44
+ onChange: function () {
45
+ props.onItemSelect(checkbox.id);
46
+ }
47
+ },
48
+ disabled: props.disabled,
49
+ label: checkbox.label,
50
+ id: "".concat(prefix, "_").concat(checkbox.id),
51
+ key: checkboxIndex
52
+ }); })));
50
53
  }
51
54
  exports["default"] = CheckboxListFieldView;
@@ -1,47 +1,13 @@
1
1
  .CheckboxListFieldView {
2
- &__label {
3
- &-text {
4
- &_required:after {
5
- display: inline-block;
6
- content: '*';
7
- color: $danger;
8
- margin: 0 0 0 3px;
9
- }
10
- }
11
- }
12
-
13
- .custom-control-label {
14
- &::before, &::after {
15
- border-color: $border-default;
16
- top: 0;
17
- }
18
- }
2
+ display: flex;
19
3
 
20
- .custom-control-input {
21
- &:checked ~ .custom-control-label {
22
- &::before {
23
- border-color: $primary;
24
- background: $primary;
25
- }
26
- &:hover {
27
- &::before {
28
- background: $primary-dark;
29
- }
30
- }
31
- &:active {
32
- &::before {
33
- background: $primary-light;
34
- }
35
- }
4
+ &_vertical {
5
+ flex-flow: column wrap;
6
+ row-gap: 8px;
36
7
  }
37
- &:disabled ~ .custom-control-label {
38
- color: $border-default;
39
8
 
40
- &::before {
41
- border: unset;
42
- background-color: $back-disabled;
43
- }
9
+ &_horizontal {
10
+ flex-flow: row nowrap;
11
+ column-gap: 8px;
44
12
  }
45
- }
46
-
47
13
  }
@@ -46,7 +46,7 @@ var Calendar_1 = __importDefault(require("@steroidsjs/core/ui/content/Calendar")
46
46
  function DateFieldView(props) {
47
47
  var bem = (0, hooks_1.useBem)('DateFieldView');
48
48
  var renderCalendar = (0, react_1.useCallback)(function () { return (React.createElement(Calendar_1["default"], __assign({}, props.calendarProps))); }, [props.calendarProps]);
49
- return (React.createElement(DropDown_1["default"], { content: renderCalendar, position: 'bottomLeft', visible: props.isOpened, onClose: props.onClose },
49
+ return (React.createElement(DropDown_1["default"], { content: renderCalendar, position: 'bottomLeft', visible: props.isOpened, onClose: props.onClose, className: bem.element('dropdown') },
50
50
  React.createElement("div", { className: bem(bem.block({
51
51
  size: props.size,
52
52
  disabled: props.disabled,
@@ -54,12 +54,12 @@ function DateFieldView(props) {
54
54
  'is-invalid': !!props.errors
55
55
  }), props.className), style: props.style },
56
56
  React.createElement("div", { className: bem.element('body') },
57
- React.createElement("input", __assign({}, props.inputProps, { onChange: function (e) { return props.inputProps.onChange(e.target.value); }, className: bem(bem.element('input', { size: props.size }), props.isInvalid && 'is-invalid', props.inputProps.className) })),
57
+ React.createElement("input", __assign({}, props.inputProps, { onChange: function (e) { return props.inputProps.onChange(e.target.value); }, className: bem(bem.element('input'), props.inputProps.className) })),
58
58
  React.createElement("div", { className: bem.element('icon-container') },
59
- props.icon && (React.createElement(Icon_1["default"], { className: bem.element('icon'), name: typeof props.icon === 'string' ? props.icon : 'calendar-alt' })),
60
- props.showRemove && props.inputProps.value && (React.createElement(Icon_1["default"], { className: bem.element('icon', 'close'), onClick: function (e) {
59
+ !props.inputProps.value && props.icon && (React.createElement(Icon_1["default"], { className: bem.element('date-icon'), name: typeof props.icon === 'string' ? props.icon : 'calendar_range', tabIndex: -1 })),
60
+ props.showRemove && props.inputProps.value && (React.createElement(Icon_1["default"], { className: bem.element('close-icon'), onClick: function (e) {
61
61
  e.preventDefault();
62
62
  props.onClear();
63
- }, name: 'times-circle' })))))));
63
+ }, name: 'cross_8x8' })))))));
64
64
  }
65
65
  exports["default"] = DateFieldView;