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

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 (277) 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 +31 -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 +78 -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/SwitcherField/SwitcherFieldView.d.ts +1 -2
  104. package/form/SwitcherField/SwitcherFieldView.js +12 -7
  105. package/form/SwitcherField/SwitcherFieldView.scss +188 -1
  106. package/form/TextField/TextFieldView.d.ts +1 -2
  107. package/form/TextField/TextFieldView.js +10 -2
  108. package/form/TextField/TextFieldView.scss +144 -2
  109. package/form/TimeField/TimeFieldView.d.ts +1 -2
  110. package/icons/index.d.ts +2 -0
  111. package/icons/index.js +103 -0
  112. package/icons/svgs/add.svg +4 -0
  113. package/icons/svgs/add_square.svg +5 -0
  114. package/icons/svgs/arrow_down_18x18.svg +4 -0
  115. package/icons/svgs/arrow_down_24x24.svg +4 -0
  116. package/icons/svgs/arrow_drop_down_10x10.svg +3 -0
  117. package/icons/svgs/arrow_left_18x18.svg +4 -0
  118. package/icons/svgs/arrow_left_24x24.svg +4 -0
  119. package/icons/svgs/arrow_right_18x18.svg +4 -0
  120. package/icons/svgs/arrow_right_24x24.svg +4 -0
  121. package/icons/svgs/arrow_up_18x18.svg +4 -0
  122. package/icons/svgs/arrow_up_24x24.svg +4 -0
  123. package/icons/svgs/blank.svg +4 -0
  124. package/icons/svgs/calendar_check.svg +5 -0
  125. package/icons/svgs/calendar_range.svg +8 -0
  126. package/icons/svgs/cancel_ellips.svg +4 -0
  127. package/icons/svgs/chart.svg +6 -0
  128. package/icons/svgs/checkmark_12x12.svg +4 -0
  129. package/icons/svgs/checkmark_8x8.svg +4 -0
  130. package/icons/svgs/circle_cross_12x12.svg +4 -0
  131. package/icons/svgs/circle_cross_16x16.svg +4 -0
  132. package/icons/svgs/circle_cross_18x18.svg +4 -0
  133. package/icons/svgs/clip.svg +3 -0
  134. package/icons/svgs/copy.svg +5 -0
  135. package/icons/svgs/cross_12x12.svg +4 -0
  136. package/icons/svgs/cross_4x4.svg +3 -0
  137. package/icons/svgs/cross_8x8.svg +4 -0
  138. package/icons/svgs/cut.svg +3 -0
  139. package/icons/svgs/date_range.svg +8 -0
  140. package/icons/svgs/default_16x16.svg +4 -0
  141. package/icons/svgs/default_24x24.svg +11 -0
  142. package/icons/svgs/double_arrow_down.svg +5 -0
  143. package/icons/svgs/double_arrow_left.svg +5 -0
  144. package/icons/svgs/double_arrow_right.svg +5 -0
  145. package/icons/svgs/double_arrow_up.svg +5 -0
  146. package/icons/svgs/doughnut_chart.svg +5 -0
  147. package/icons/svgs/edit.svg +4 -0
  148. package/icons/svgs/error_16x16.svg +5 -0
  149. package/icons/svgs/error_24x24.svg +12 -0
  150. package/icons/svgs/expand_down.svg +3 -0
  151. package/icons/svgs/expand_left.svg +3 -0
  152. package/icons/svgs/expand_left_double.svg +4 -0
  153. package/icons/svgs/expand_right.svg +3 -0
  154. package/icons/svgs/expand_right_double.svg +4 -0
  155. package/icons/svgs/expand_up.svg +3 -0
  156. package/icons/svgs/file_dock.svg +6 -0
  157. package/icons/svgs/filter.svg +3 -0
  158. package/icons/svgs/fluid.svg +4 -0
  159. package/icons/svgs/folder.svg +3 -0
  160. package/icons/svgs/group.svg +8 -0
  161. package/icons/svgs/home.svg +4 -0
  162. package/icons/svgs/img_box.svg +5 -0
  163. package/icons/svgs/import.svg +4 -0
  164. package/icons/svgs/info_16x16.svg +5 -0
  165. package/icons/svgs/info_24x24.svg +12 -0
  166. package/icons/svgs/left_12x12.svg +3 -0
  167. package/icons/svgs/loading_default.svg +3 -0
  168. package/icons/svgs/loading_icon_thick.svg +3 -0
  169. package/icons/svgs/loading_purple.svg +9 -0
  170. package/icons/svgs/map.svg +7 -0
  171. package/icons/svgs/menu_dots.svg +5 -0
  172. package/icons/svgs/menu_left.svg +5 -0
  173. package/icons/svgs/minis_sq.svg +4 -0
  174. package/icons/svgs/paste.svg +8 -0
  175. package/icons/svgs/pie_chart.svg +5 -0
  176. package/icons/svgs/pin.svg +4 -0
  177. package/icons/svgs/sad.svg +6 -0
  178. package/icons/svgs/search.svg +4 -0
  179. package/icons/svgs/setting_line.svg +3 -0
  180. package/icons/svgs/share.svg +7 -0
  181. package/icons/svgs/star.svg +3 -0
  182. package/icons/svgs/success_16x16.svg +4 -0
  183. package/icons/svgs/success_24x24.svg +11 -0
  184. package/icons/svgs/support.svg +3 -0
  185. package/icons/svgs/trash.svg +6 -0
  186. package/icons/svgs/upload.svg +4 -0
  187. package/icons/svgs/user.svg +4 -0
  188. package/icons/svgs/view.svg +4 -0
  189. package/icons/svgs/view_hide.svg +5 -0
  190. package/icons/svgs/warning_16x16.svg +5 -0
  191. package/icons/svgs/warning_24x24.svg +12 -0
  192. package/index.d.ts +26 -2
  193. package/index.js +28 -4
  194. package/index.scss +16 -3
  195. package/layout/Header/HeaderView.scss +3 -3
  196. package/layout/Loader/LoaderView.d.ts +2 -2
  197. package/layout/Loader/LoaderView.js +6 -2
  198. package/layout/Loader/LoaderView.scss +67 -22
  199. package/layout/Notifications/NotificationsItemView.d.ts +1 -2
  200. package/layout/Notifications/NotificationsView.d.ts +1 -2
  201. package/layout/ProgressBar/CircleProgressBarView.d.ts +1 -2
  202. package/layout/ProgressBar/LineProgressBarView.d.ts +1 -2
  203. package/layout/Tooltip/TooltipView.d.ts +1 -2
  204. package/layout/Tooltip/TooltipView.js +6 -6
  205. package/layout/Tooltip/TooltipView.scss +45 -37
  206. package/list/CheckboxColumn/CheckboxColumnView.d.ts +1 -2
  207. package/list/CheckboxColumn/CheckboxColumnView.js +2 -1
  208. package/list/ControlsColumnView/ControlsColumnView.d.ts +1 -2
  209. package/list/Grid/GridView.js +8 -4
  210. package/list/Grid/GridView.scss +148 -37
  211. package/list/Grid/views/ContentColumnView/ContentColumnView.d.ts +3 -0
  212. package/list/Grid/views/ContentColumnView/ContentColumnView.js +51 -0
  213. package/list/Grid/views/ContentColumnView/ContentColumnView.scss +88 -0
  214. package/list/Grid/views/ContentColumnView/index.d.ts +2 -0
  215. package/list/Grid/views/ContentColumnView/index.js +7 -0
  216. package/list/List/ListItemView.d.ts +1 -2
  217. package/list/List/ListView.js +5 -7
  218. package/list/List/ListView.scss +32 -1
  219. package/list/Pagination/PaginationButtonView.js +34 -5
  220. package/list/Pagination/PaginationButtonView.scss +265 -1
  221. package/list/Pagination/PaginationMoreView.js +1 -1
  222. package/list/Pagination/PaginationMoreView.scss +4 -1
  223. package/modal/Modal/ModalView.d.ts +1 -2
  224. package/modal/Modal/ModalView.js +4 -7
  225. package/modal/Modal/ModalView.scss +129 -93
  226. package/modal/TwoFactorModal/TwoFactorModalView.d.ts +1 -2
  227. package/nav/Breadcrubms/BreadcrumbsView.js +9 -1
  228. package/nav/Breadcrubms/BreadcrumbsView.scss +49 -0
  229. package/nav/ButtonGroup/ButtonGroupView.d.ts +2 -0
  230. package/nav/ButtonGroup/ButtonGroupView.js +32 -0
  231. package/nav/ButtonGroup/ButtonGroupView.scss +83 -0
  232. package/nav/Controls/ControlsView.d.ts +1 -2
  233. package/nav/Controls/ControlsView.scss +9 -3
  234. package/nav/Nav/NavBarView.d.ts +1 -2
  235. package/nav/Nav/NavButtonView.d.ts +1 -2
  236. package/nav/Nav/NavIconView.d.ts +1 -2
  237. package/nav/Nav/NavIconView.js +1 -1
  238. package/nav/Nav/NavLinkView.d.ts +1 -2
  239. package/nav/Nav/NavListView.d.ts +1 -2
  240. package/nav/Nav/NavListView.js +1 -1
  241. package/nav/Nav/NavTabsView.d.ts +1 -2
  242. package/nav/Nav/NavTabsView.js +1 -1
  243. package/nav/Tree/TreeView.d.ts +1 -2
  244. package/nav/Tree/TreeView.scss +14 -11
  245. package/package.json +56 -56
  246. package/scss/animations/index.scss +1 -0
  247. package/scss/animations/loading.scss +13 -0
  248. package/scss/fonts.scss +6 -0
  249. package/scss/mixins/button.scss +80 -24
  250. package/scss/mixins/customMixins.scss +5 -0
  251. package/scss/mixins/date.scss +397 -0
  252. package/scss/mixins/index.scss +4 -1
  253. package/scss/mixins/scroll.scss +31 -0
  254. package/scss/mixins/typography.scss +26 -0
  255. package/scss/variables/common/colors.scss +119 -69
  256. package/scss/variables/common/media.scss +2 -0
  257. package/scss/variables/common/typography.scss +96 -28
  258. package/scss/variables/common/variables.scss +1 -0
  259. package/scss/variables/components/input.scss +7 -6
  260. package/scss/variables/index.scss +3 -2
  261. package/scss/variables/normalize.scss +25 -0
  262. package/typography/Text/TextView.d.ts +3 -0
  263. package/typography/Text/TextView.js +46 -0
  264. package/typography/Text/TextView.scss +16 -0
  265. package/typography/Title/TitleView.d.ts +3 -0
  266. package/typography/Title/TitleView.js +50 -0
  267. package/typography/Title/TitleView.scss +16 -0
  268. package/utils/renderIcon.d.ts +9 -0
  269. package/utils/renderIcon.js +27 -0
  270. package/content/Collapse/CollapseItemView.d.ts +0 -2
  271. package/content/Collapse/CollapseItemView.scss +0 -88
  272. package/content/Collapse/CollapseView.d.ts +0 -2
  273. package/icons/fontawesome.d.ts +0 -2
  274. package/icons/fontawesome.js +0 -254
  275. package/list/List/ListItemView.scss +0 -3
  276. package/scss/mixins/card.scss +0 -26
  277. package/scss/variables/components/card.scss +0 -20
@@ -0,0 +1,226 @@
1
+ :root {
2
+ --radio-hover-color: #651fff;
3
+ }
4
+
5
+ html[data-theme="dark"] {
6
+ --radio-hover-color: #6648a7;
7
+ }
8
+
9
+ $radio-hover-color: var(--radio-hover-color);
10
+
11
+ .RadioFieldView {
12
+ position: relative;
13
+ box-sizing: border-box;
14
+
15
+ $root: &;
16
+
17
+ font-family: $font-family-nunito;
18
+ color: $text-color;
19
+ line-height: 24px;
20
+ font-weight: 400;
21
+ font-size: $font-size-sm;
22
+
23
+ &__ellipse {
24
+ position: absolute;
25
+ top: 50%;
26
+ left: 6px;
27
+ transform: translateY(-50%);
28
+ display: inline-block;
29
+ width: 12px;
30
+ height: 12px;
31
+ background-color: $primary;
32
+ border-radius: $radius-circle;
33
+ opacity: 0;
34
+ pointer-events: none;
35
+ }
36
+
37
+ &__label {
38
+ position: relative;
39
+ }
40
+
41
+ &__input {
42
+ position: absolute;
43
+ z-index: -1;
44
+ opacity: 0;
45
+ }
46
+
47
+ &__input + &__label {
48
+ position: relative;
49
+ display: inline-flex;
50
+ align-items: center;
51
+ user-select: none;
52
+ cursor: pointer;
53
+ }
54
+
55
+ //Custom Radio
56
+ &__input + label::before {
57
+ content: "";
58
+ display: inline-block;
59
+ width: 24px;
60
+ height: 24px;
61
+ border-radius: $radius-circle;
62
+ border: 1px solid $border-color;
63
+ margin-right: 8px;
64
+ cursor: pointer;
65
+
66
+ background-repeat: no-repeat;
67
+ background-position: 53% 50%;
68
+ background-size: 50% 50%;
69
+ }
70
+
71
+ &__input + &__label::after {
72
+ content: "";
73
+ width: 26px;
74
+ height: 26px;
75
+ position: absolute;
76
+ top: 0;
77
+ left: 0;
78
+ border: 4px solid $primary-light;
79
+ border-radius: $radius-circle;
80
+ pointer-events: none;
81
+ opacity: 0;
82
+
83
+ transform: translate(-12%, -12%);
84
+
85
+ transition: opacity 150ms ease-in-out;
86
+ }
87
+
88
+ &__input:not(:disabled):not(:checked):hover + &__label::before {
89
+ border-color: $border-color-hover;
90
+ }
91
+
92
+ &__input:not(:disabled):not(:checked):active + &__label::before {
93
+ border-color: $primary;
94
+ }
95
+
96
+ &__input:not(:disabled):focus + &__label::after {
97
+ opacity: 1;
98
+ }
99
+
100
+ &__input:not(:disabled):focus + &__label &__ellipse {
101
+ opacity: 1;
102
+ }
103
+
104
+ &__input:checked + &__label::before {
105
+ border: 1px solid $primary;
106
+ }
107
+ &__input:checked + &__label &__ellipse {
108
+ opacity: 1;
109
+ }
110
+
111
+ &__input:not(:disabled):checked:hover + &__label::before {
112
+ border-color: $primary-dark;
113
+ }
114
+
115
+ &__input:not(:disabled):checked:hover + &__label &__ellipse {
116
+ opacity: 1;
117
+ background-color: $radio-hover-color;
118
+ }
119
+
120
+ &__input:not(:disabled):checked:active + &__label::before {
121
+ border-color: $primary-light;
122
+ }
123
+
124
+ &__input:not(:disabled):checked:active + &__label &__ellipse {
125
+ opacity: 1;
126
+ background-color: $primary-light;
127
+ }
128
+
129
+ &__input:disabled + &__label {
130
+ cursor: not-allowed;
131
+ color: $placeholder-color;
132
+
133
+ &::before {
134
+ cursor: not-allowed;
135
+ background-color: $background-disabled-color;
136
+ }
137
+ }
138
+
139
+ &__input:disabled:checked + &__label::before {
140
+ cursor: not-allowed;
141
+
142
+ background-color: transparent;
143
+ border-color: $background-disabled-color;
144
+ }
145
+
146
+ &__input:disabled:checked + &__label &__ellipse {
147
+ background-color: $background-disabled-color;
148
+ }
149
+
150
+ &_hasError {
151
+ #{$root}__input:not(:disabled):not(:checked) + #{$root}__label {
152
+ color: $danger;
153
+
154
+ &::before {
155
+ border-color: $danger;
156
+ }
157
+ }
158
+ }
159
+
160
+ &_size {
161
+ &_lg {
162
+ #{$root}__label {
163
+ font-size: $font-size-lg;
164
+ line-height: 24px;
165
+
166
+ &::before {
167
+ width: 22px;
168
+ height: 22px;
169
+ }
170
+
171
+ &::after {
172
+ width: 24px;
173
+ height: 24px;
174
+ }
175
+ }
176
+ }
177
+
178
+ &_md {
179
+ #{$root}__label {
180
+ font-size: $font-size-base;
181
+ line-height: 22px;
182
+
183
+ &::before {
184
+ width: 18px;
185
+ height: 18px;
186
+ }
187
+
188
+ &::after {
189
+ width: 20px;
190
+ height: 20px;
191
+ transform: translate(-14.5%, -10.5%);
192
+ }
193
+ }
194
+
195
+ #{$root}__ellipse {
196
+ width: 10px;
197
+ height: 10px;
198
+ left: 5px;
199
+ }
200
+ }
201
+
202
+ &_sm {
203
+ #{$root}__label {
204
+ font-size: $font-size-sm;
205
+ line-height: 18px;
206
+
207
+ &::before {
208
+ width: 14px;
209
+ height: 14px;
210
+ }
211
+
212
+ &::after {
213
+ width: 16px;
214
+ height: 16px;
215
+ transform: translate(-16.5%, -12.5%);
216
+ }
217
+ }
218
+
219
+ #{$root}__ellipse {
220
+ width: 8px;
221
+ height: 8px;
222
+ left: 4px;
223
+ }
224
+ }
225
+ }
226
+ }
@@ -1,3 +1,2 @@
1
- import { IBemHocOutput } from '@steroidsjs/core/hoc/bem';
2
1
  import { IRadioListFieldViewProps } from '@steroidsjs/core/ui/form/RadioListField/RadioListField';
3
- export default function RadioListFieldView(props: IRadioListFieldViewProps & IBemHocOutput): JSX.Element;
2
+ export default function RadioListFieldView(props: IRadioListFieldViewProps): 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,12 +30,27 @@ 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 RadioListFieldView(props) {
33
+ var _a;
44
34
  var bem = (0, hooks_1.useBem)('RadioListFieldView');
45
35
  var prefix = (0, useUniqueId_1["default"])('radio');
46
- return (React.createElement("div", { className: bem.block() }, props.items.map(function (item) { return (React.createElement("div", { key: typeof item.id !== 'boolean' ? item.id : (item.id ? 'true' : 'false'), className: 'custom-control custom-radio' },
47
- React.createElement("input", __assign({}, props.inputProps, { id: "".concat(prefix, "_").concat(item.id), className: bem(bem.element('input'), 'custom-control-input', !!props.errors && 'is-invalid'), checked: props.selectedIds.includes(item.id), disabled: props.disabled || item.disabled, onChange: function () {
48
- props.onItemSelect(item.id);
49
- } })),
50
- React.createElement("label", { className: 'custom-control-label', htmlFor: "".concat(prefix, "_").concat(item.id) }, item.label))); })));
36
+ return (React.createElement("div", { className: bem(bem.block((_a = {},
37
+ _a["".concat(props.orientation)] = !!props.orientation,
38
+ _a)), props.className) }, props.items.map(function (radio, radioIndex) { return props.renderRadio({
39
+ inputProps: {
40
+ name: "".concat(prefix, "_").concat(radio.id),
41
+ checked: null,
42
+ type: 'radio',
43
+ disabled: false,
44
+ onChange: function () {
45
+ props.onItemSelect(radio.id);
46
+ }
47
+ },
48
+ disabled: props.disabled,
49
+ checked: props.selectedIds.includes(radio.id),
50
+ label: radio.label,
51
+ id: "".concat(prefix, "_").concat(radio.id),
52
+ key: radioIndex,
53
+ size: props.size
54
+ }); })));
51
55
  }
52
56
  exports["default"] = RadioListFieldView;
@@ -1,3 +1,13 @@
1
1
  .RadioListFieldView {
2
+ display: flex;
2
3
 
3
- }
4
+ &_vertical {
5
+ flex-flow: column wrap;
6
+ row-gap: 8px;
7
+ }
8
+
9
+ &_horizontal {
10
+ flex-flow: row nowrap;
11
+ column-gap: 8px;
12
+ }
13
+ }
@@ -1,3 +1,2 @@
1
- import { IBemHocOutput } from '@steroidsjs/core/hoc/bem';
2
1
  import { IReCaptchaFieldViewProps } from '@steroidsjs/core/ui/form/ReCaptchaField/ReCaptchaField';
3
- export default function ReCaptchaFieldView(props: IReCaptchaFieldViewProps & IBemHocOutput): JSX.Element;
2
+ export default function ReCaptchaFieldView(props: IReCaptchaFieldViewProps): JSX.Element;
@@ -31,9 +31,9 @@ function ReCaptchaFieldView(props) {
31
31
  return (React.createElement("div", { className: bem.block() },
32
32
  React.createElement("small", { className: 'text-muted' },
33
33
  __('This site is protected by reCAPTCHA and the Google') + ' ',
34
- React.createElement(nav_1.Link, { url: 'https://policies.google.com/privacy', target: '_blank', label: __('Privacy Policy'), layout: false }),
34
+ React.createElement(nav_1.Link, { url: 'https://policies.google.com/privacy', target: '_blank', label: __('Privacy Policy') }),
35
35
  ' ' + __('and') + ' ',
36
- React.createElement(nav_1.Link, { url: 'https://policies.google.com/terms', target: '_blank', label: __('Terms of Service'), layout: false }),
36
+ React.createElement(nav_1.Link, { url: 'https://policies.google.com/terms', target: '_blank', label: __('Terms of Service') }),
37
37
  ' ' + __('apply'),
38
38
  ".")));
39
39
  }
@@ -1,3 +1,2 @@
1
- import { IBemHocOutput } from '@steroidsjs/core/hoc/bem';
2
1
  import { ISliderFieldViewProps } from '@steroidsjs/core/ui/form/SliderField/SliderField';
3
- export default function SliderFieldView(props: ISliderFieldViewProps & IBemHocOutput): JSX.Element;
2
+ export default function SliderFieldView(props: ISliderFieldViewProps): JSX.Element;
@@ -1,3 +1,2 @@
1
- import { IBemHocOutput } from '@steroidsjs/core/hoc/bem';
2
1
  import { ISwitcherFieldViewProps } from '@steroidsjs/core/ui/form/SwitcherField/SwitcherField';
3
- export default function SwitcherFieldView(props: ISwitcherFieldViewProps & IBemHocOutput): JSX.Element;
2
+ export default function SwitcherFieldView(props: ISwitcherFieldViewProps): JSX.Element;
@@ -33,18 +33,23 @@ var __importStar = (this && this.__importStar) || function (mod) {
33
33
  __setModuleDefault(result, mod);
34
34
  return result;
35
35
  };
36
- var __importDefault = (this && this.__importDefault) || function (mod) {
37
- return (mod && mod.__esModule) ? mod : { "default": mod };
38
- };
39
36
  exports.__esModule = true;
40
37
  var React = __importStar(require("react"));
41
- var get_1 = __importDefault(require("lodash-es/get"));
42
- var Button_1 = __importDefault(require("@steroidsjs/core/ui/form/Button"));
43
38
  var hooks_1 = require("@steroidsjs/core/hooks");
44
39
  function SwitcherFieldView(props) {
45
40
  var bem = (0, hooks_1.useBem)('SwitcherFieldView');
46
- return (React.createElement("div", { className: bem(bem.block({
41
+ var prefix = (0, hooks_1.useUniqueId)('switcher');
42
+ var renderLabel = React.useCallback(function (item) {
43
+ if (typeof item.label === 'object') {
44
+ return props.selectedIds.includes(item.id) ? item.label.checked : item.label.unchecked;
45
+ }
46
+ return item.label;
47
+ }, [props.selectedIds]);
48
+ return (React.createElement("div", { className: bem(bem.block(), props.className), style: props.style }, props.items.map(function (switcher, switcherIndex) { return (React.createElement("label", { key: switcherIndex, className: bem.element('switcher', {
47
49
  size: props.size
48
- }), props.className, 'btn-group') }, props.items.map(function (item) { return (React.createElement(Button_1["default"], __assign({ key: String(item[props.primaryKey]) }, props.buttonProps, { className: bem((0, get_1["default"])(props, 'buttonProps.className'), props.hoveredId === item[props.primaryKey] && 'hover', props.selectedIds.includes(item[props.primaryKey]) && 'active'), disabled: props.disabled, onClick: function () { return props.onItemSelect(item[props.primaryKey]); }, onMouseOver: function () { return props.onItemHover(item[props.primaryKey]); }, layout: false }), item.label)); })));
50
+ }), htmlFor: "".concat(prefix, "_").concat(switcher.id) },
51
+ React.createElement("input", __assign({}, props.inputProps, { id: "".concat(prefix, "_").concat(switcher.id), onChange: function () { return props.onItemSelect(switcher.id); }, checked: props.selectedIds.includes(switcher.id), className: bem.element('input') })),
52
+ React.createElement("span", { className: bem.element('slider') }),
53
+ React.createElement("span", { className: bem.element('label') }, renderLabel(switcher)))); })));
49
54
  }
50
55
  exports["default"] = SwitcherFieldView;
@@ -1,2 +1,189 @@
1
+ :root {
2
+ --switcher-dot-disabled-color: #dbe2e6;
3
+ --switcher-slider-disabled-color: #f1f5f7;
4
+ }
5
+
6
+ html[data-theme="dark"] {
7
+ --switcher-dot-disabled-color: #4e4f57;
8
+ --switcher-slider-disabled-color: #5b5c6b;
9
+ }
10
+
11
+ $switcher-dot-disabled-color: var(--switcher-dot-disabled-color);
12
+ $switcher-slider-disabled-color: var(--switcher-slider-disabled-color);
13
+
14
+ $background-color-transition-timing: 150ms;
15
+
1
16
  .SwitcherFieldView {
2
- }
17
+ $root: &;
18
+ display: flex;
19
+ flex-flow: column nowrap;
20
+ align-items: flex-start;
21
+ row-gap: 10px;
22
+
23
+ &__switcher {
24
+ display: inline-flex;
25
+ column-gap: 12px;
26
+ align-items: center;
27
+ position: relative;
28
+ cursor: pointer;
29
+
30
+ $sizes: () !default;
31
+ $sizes: map-merge(
32
+ (
33
+ "lg": (
34
+ "width": 40px,
35
+ "height": 24px,
36
+ "dotSize": 18px,
37
+ "dotTranslateDefault": translateY(-50%) translateX(4px),
38
+ "dotTranslateActive": translateY(-50%) translateX(16px),
39
+ "font-size": $font-size-lg,
40
+ "line-height": $line-height-lg,
41
+ ),
42
+ "md": (
43
+ "width": 34px,
44
+ "height": 20px,
45
+ "dotSize": 14px,
46
+ "dotTranslateDefault": translateY(-50%) translateX(3px),
47
+ "dotTranslateActive": translateY(-50%) translateX(15px),
48
+ "font-size": $font-size-base,
49
+ "line-height": $line-height-base,
50
+ ),
51
+ "sm": (
52
+ "width": 28px,
53
+ "height": 16px,
54
+ "dotSize": 12px,
55
+ "dotTranslateDefault": translateY(-50%) translateX(2px),
56
+ "dotTranslateActive": translateY(-50%) translateX(12px),
57
+ "font-size": $font-size-sm,
58
+ "line-height": $line-height-sm,
59
+ ),
60
+ ),
61
+ $sizes
62
+ );
63
+
64
+ &_size {
65
+ @each $size, $sizeMap in $sizes {
66
+ &_#{$size} {
67
+ #{$root}__slider {
68
+ width: map-get($sizeMap, width);
69
+ height: map-get($sizeMap, height);
70
+
71
+ &::before {
72
+ width: map-get($sizeMap, dotSize);
73
+ height: map-get($sizeMap, dotSize);
74
+ transform: map-get($sizeMap, dotTranslateDefault);
75
+ }
76
+ }
77
+
78
+ #{$root}__input:checked + #{$root}__slider {
79
+ &::before {
80
+ transform: map-get($sizeMap, dotTranslateActive);
81
+ }
82
+ }
83
+
84
+ #{$root}__label {
85
+ font-size: map-get($sizeMap, font-size);
86
+ line-height: map-get($sizeMap, line-height);
87
+ }
88
+ }
89
+ }
90
+ }
91
+ }
92
+
93
+ &__input {
94
+ position: absolute;
95
+ cursor: pointer;
96
+ z-index: 3;
97
+ opacity: 0;
98
+ top: 0;
99
+ left: 0;
100
+ right: 0;
101
+ bottom: 0;
102
+
103
+ &:checked + #{$root}__slider {
104
+ background-color: $primary;
105
+ border-color: transparent;
106
+
107
+ &::before {
108
+ background-color: $white;
109
+ }
110
+
111
+ &::after {
112
+ border-color: $primary-light;
113
+ }
114
+ }
115
+
116
+ &:hover:not(:checked):not(:disabled) + #{$root}__slider {
117
+ &::before {
118
+ background-color: $gray-dark;
119
+ }
120
+ }
121
+
122
+ &:checked:hover + #{$root}__slider {
123
+ background-color: $primary-dark;
124
+ }
125
+
126
+ &:focus:not(:active) + #{$root}__slider {
127
+ &:after {
128
+ opacity: 1;
129
+ }
130
+ }
131
+
132
+ &:disabled {
133
+ cursor: not-allowed;
134
+ }
135
+
136
+ &:disabled ~ #{$root}__label {
137
+ color: $gray;
138
+ }
139
+
140
+ &:disabled + #{$root}__slider {
141
+ background-color: $switcher-slider-disabled-color;
142
+
143
+ &::before {
144
+ background-color: $switcher-dot-disabled-color;
145
+ }
146
+ }
147
+ }
148
+
149
+ &__slider {
150
+ width: 100%;
151
+ height: 100%;
152
+ position: relative;
153
+ display: inline-block;
154
+ border: 1px solid $gray;
155
+ border-radius: 200px;
156
+ transition: background-color $background-color-transition-timing ease-in-out;
157
+
158
+ &::after {
159
+ position: absolute;
160
+ content: "";
161
+ top: 0;
162
+ left: 0;
163
+ right: 0;
164
+ bottom: 0;
165
+ display: inline-block;
166
+ height: calc(100% + 2px);
167
+ width: calc(100% + 2px);
168
+ border-radius: inherit;
169
+ border: 4px solid $gray;
170
+ transform: translateX(-5px) translateY(-5px);
171
+ opacity: 0;
172
+ pointer-events: none;
173
+ }
174
+
175
+ &::before {
176
+ position: absolute;
177
+ content: "";
178
+ display: inline-block;
179
+ top: 50%;
180
+ border-radius: $radius-circle;
181
+ background-color: $gray;
182
+ transition: transform 100ms ease-in-out, background-color $background-color-transition-timing ease-in-out;
183
+ }
184
+ }
185
+
186
+ &__label {
187
+ color: $text-color;
188
+ }
189
+ }
@@ -1,3 +1,2 @@
1
- import { IBemHocOutput } from '@steroidsjs/core/hoc/bem';
2
1
  import { ITextFieldViewProps } from '@steroidsjs/core/ui/form/TextField/TextField';
3
- export default function TextFieldView(props: ITextFieldViewProps & IBemHocOutput): JSX.Element;
2
+ export default function TextFieldView(props: ITextFieldViewProps): JSX.Element;
@@ -33,13 +33,21 @@ var __importStar = (this && this.__importStar) || function (mod) {
33
33
  __setModuleDefault(result, mod);
34
34
  return result;
35
35
  };
36
+ var __importDefault = (this && this.__importDefault) || function (mod) {
37
+ return (mod && mod.__esModule) ? mod : { "default": mod };
38
+ };
36
39
  exports.__esModule = true;
37
40
  var React = __importStar(require("react"));
38
41
  var hooks_1 = require("@steroidsjs/core/hooks");
42
+ var Icon_1 = __importDefault(require("@steroidsjs/core/ui/content/Icon"));
39
43
  function TextFieldView(props) {
40
44
  var bem = (0, hooks_1.useBem)('TextFieldView');
41
- return (React.createElement("textarea", __assign({ className: bem(bem.block({
45
+ return (React.createElement("div", { className: bem(bem.block({
46
+ hasErrors: !!props.errors,
47
+ filled: !!props.inputProps.value,
42
48
  size: props.size
43
- }), 'form-control', 'form-control-' + props.size, !!props.errors && 'is-invalid', props.className) }, props.inputProps)));
49
+ }), props.className) },
50
+ React.createElement("textarea", __assign({ className: bem.element('textarea'), id: props.id }, props.inputProps)),
51
+ props.showClear && (React.createElement(Icon_1["default"], { className: bem.element('clear'), name: "cross_8x8", onClick: props.onClear }))));
44
52
  }
45
53
  exports["default"] = TextFieldView;