@steroidsjs/core 2.1.0-beta.3 → 2.1.0-beta.33

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 (584) hide show
  1. package/README.md +3 -1
  2. package/actions/form.d.ts +9 -0
  3. package/actions/form.js +11 -1
  4. package/actions/list.d.ts +1 -0
  5. package/actions/list.js +1 -0
  6. package/actions/modal.d.ts +3 -2
  7. package/components/ClientStorageComponent.d.ts +3 -3
  8. package/components/ClientStorageComponent.js +28 -22
  9. package/components/HttpComponent.js +32 -15
  10. package/components/LocaleComponent.js +9 -9
  11. package/components/MetricsComponent.js +3 -1
  12. package/components/SocialComponent.d.ts +1 -1
  13. package/components/SocialComponent.js +12 -10
  14. package/components/StoreComponent.d.ts +6 -0
  15. package/components/StoreComponent.js +6 -7
  16. package/components/UiComponent.d.ts +1 -1
  17. package/components/WebSocketComponent.d.ts +1 -1
  18. package/components/social/FacebookProvider.d.ts +1 -1
  19. package/components/social/FacebookProvider.js +5 -6
  20. package/components/social/GitlabProvider.d.ts +8 -0
  21. package/components/social/GitlabProvider.js +98 -0
  22. package/components/social/GoogleProvider.d.ts +1 -1
  23. package/components/social/GoogleProvider.js +2 -2
  24. package/components/social/SteamProvider.d.ts +1 -1
  25. package/components/social/SteamProvider.js +8 -9
  26. package/components/social/VkProvider.d.ts +1 -1
  27. package/components/social/VkProvider.js +8 -9
  28. package/hoc/components.d.ts +1 -1
  29. package/hoc/components.js +1 -1
  30. package/hoc/file.d.ts +1 -0
  31. package/hooks/index.d.ts +2 -1
  32. package/hooks/index.js +3 -1
  33. package/hooks/useAbsolutePositioning.d.ts +5 -0
  34. package/hooks/useAbsolutePositioning.js +6 -6
  35. package/hooks/useApplication.d.ts +29 -26
  36. package/hooks/useApplication.js +17 -82
  37. package/hooks/useComponents.d.ts +1 -14
  38. package/hooks/useComponents.js +4 -5
  39. package/hooks/useDataProvider.d.ts +1 -0
  40. package/hooks/useDataProvider.js +6 -4
  41. package/hooks/useDataSelect.d.ts +15 -8
  42. package/hooks/useDataSelect.js +60 -11
  43. package/hooks/useDispatch.d.ts +1 -1
  44. package/hooks/useFetch.d.ts +11 -3
  45. package/hooks/useFetch.js +37 -31
  46. package/hooks/useFile.js +13 -2
  47. package/hooks/useLayout.d.ts +9 -0
  48. package/hooks/useLayout.js +85 -56
  49. package/hooks/useList.d.ts +56 -1
  50. package/hooks/useList.js +89 -54
  51. package/hooks/useModel.js +1 -1
  52. package/hooks/useScreen.d.ts +1 -1
  53. package/hooks/useScreen.js +2 -2
  54. package/hooks/useSsr.d.ts +2 -0
  55. package/hooks/useSsr.js +8 -0
  56. package/index.d.ts +8 -2
  57. package/package.json +7 -4
  58. package/providers/ComponentsProvider.d.ts +26 -0
  59. package/providers/ComponentsProvider.js +28 -0
  60. package/providers/ScreenProvider.d.ts +20 -0
  61. package/providers/ScreenProvider.js +87 -0
  62. package/providers/SsrProvider.d.ts +17 -0
  63. package/providers/SsrProvider.js +32 -0
  64. package/providers/index.d.ts +4 -0
  65. package/providers/index.js +12 -0
  66. package/reducers/form.d.ts +2 -1
  67. package/reducers/form.js +6 -2
  68. package/reducers/index.js +1 -1
  69. package/reducers/list.js +1 -3
  70. package/reducers/router.js +8 -4
  71. package/ui/content/Alert/Alert.d.ts +60 -0
  72. package/ui/content/Alert/Alert.js +38 -0
  73. package/ui/content/Alert/demo/description.d.ts +9 -0
  74. package/ui/content/Alert/demo/description.js +43 -0
  75. package/ui/content/Alert/demo/icon.d.ts +8 -0
  76. package/ui/content/Alert/demo/icon.js +42 -0
  77. package/ui/content/Alert/demo/text.d.ts +8 -0
  78. package/ui/content/Alert/demo/text.js +42 -0
  79. package/ui/content/Alert/index.d.ts +2 -0
  80. package/ui/content/Alert/index.js +7 -0
  81. package/ui/content/Avatar/Avatar.d.ts +54 -13
  82. package/ui/content/Avatar/Avatar.js +25 -4
  83. package/ui/content/Avatar/AvatarGroup.d.ts +3 -5
  84. package/ui/content/Avatar/AvatarGroup.js +27 -11
  85. package/ui/{form/TimeField/demo/show-remove.d.ts → content/Avatar/demo/custome size.d.ts } +2 -2
  86. package/ui/content/Avatar/demo/custome size.js +35 -0
  87. package/ui/{form/SwitcherField/demo/sizes.d.ts → content/Avatar/demo/group.d.ts} +1 -1
  88. package/ui/content/Avatar/demo/group.js +49 -0
  89. package/ui/content/Avatar/demo/shape.d.ts +8 -0
  90. package/ui/content/Avatar/demo/shape.js +41 -0
  91. package/ui/content/Avatar/demo/size.d.ts +8 -0
  92. package/ui/content/Avatar/demo/size.js +41 -0
  93. package/ui/content/Avatar/demo/title.d.ts +8 -0
  94. package/ui/content/Avatar/demo/title.js +41 -0
  95. package/ui/content/Avatar/index.d.ts +6 -1
  96. package/ui/content/Avatar/index.js +4 -0
  97. package/ui/content/Calendar/demo/basic.d.ts +8 -0
  98. package/ui/{form/FieldLayout → content/Calendar}/demo/basic.js +3 -3
  99. package/ui/content/Card/Card.d.ts +62 -14
  100. package/ui/content/Card/Card.js +3 -2
  101. package/ui/{form/FieldLayout/demo/hint.d.ts → content/Card/demo/basic.d.ts} +2 -2
  102. package/ui/{form/SwitcherField/demo/sizes.js → content/Card/demo/basic.js} +6 -12
  103. package/ui/content/Card/demo/border color.d.ts +3 -0
  104. package/ui/content/Card/demo/border color.js +47 -0
  105. package/ui/content/Card/demo/color.d.ts +3 -0
  106. package/ui/content/Card/demo/color.js +47 -0
  107. package/ui/{form/DateTimeField/demo/sizes.d.ts → content/Card/demo/header.d.ts} +2 -2
  108. package/ui/content/Card/demo/header.js +42 -0
  109. package/ui/content/Card/demo/hover.d.ts +8 -0
  110. package/ui/content/Card/demo/hover.js +37 -0
  111. package/ui/content/Card/demo/link.d.ts +8 -0
  112. package/ui/content/Card/demo/link.js +38 -0
  113. package/ui/content/Card/demo/orientation.d.ts +3 -0
  114. package/ui/content/Card/demo/orientation.js +41 -0
  115. package/ui/content/Collapse/Collapse.d.ts +63 -0
  116. package/ui/content/Collapse/Collapse.js +80 -0
  117. package/ui/content/Collapse/CollapseItem.d.ts +67 -0
  118. package/ui/content/Collapse/CollapseItem.js +22 -0
  119. package/ui/content/Collapse/demo/accordion.d.ts +8 -0
  120. package/ui/content/Collapse/demo/accordion.js +37 -0
  121. package/ui/{form/FieldLayout → content/Collapse}/demo/basic.d.ts +0 -0
  122. package/ui/content/Collapse/demo/basic.js +37 -0
  123. package/ui/{form/SliderField/demo/required.d.ts → content/Collapse/demo/borderless.d.ts} +2 -2
  124. package/ui/content/Collapse/demo/borderless.js +37 -0
  125. package/ui/content/Collapse/demo/disable.d.ts +8 -0
  126. package/ui/content/Collapse/demo/disable.js +37 -0
  127. package/ui/content/Collapse/demo/icon position.d.ts +8 -0
  128. package/ui/content/Collapse/demo/icon position.js +37 -0
  129. package/ui/{form/SliderField/demo/size.d.ts → content/Collapse/demo/icon.d.ts} +1 -1
  130. package/ui/content/Collapse/demo/icon.js +52 -0
  131. package/ui/content/Collapse/demo/onChange.d.ts +8 -0
  132. package/ui/content/Collapse/demo/onChange.js +47 -0
  133. package/ui/content/Collapse/demo/show icon.d.ts +8 -0
  134. package/ui/content/Collapse/demo/show icon.js +37 -0
  135. package/ui/content/Collapse/index.d.ts +7 -0
  136. package/ui/content/Collapse/index.js +8 -0
  137. package/ui/content/Detail/Detail.d.ts +102 -0
  138. package/ui/content/Detail/Detail.js +155 -0
  139. package/ui/content/Detail/DetailItem.d.ts +43 -0
  140. package/ui/content/Detail/DetailItem.js +10 -0
  141. package/ui/content/Detail/demo/basic.d.ts +8 -0
  142. package/ui/content/Detail/demo/basic.js +56 -0
  143. package/ui/content/Detail/demo/colors.d.ts +3 -0
  144. package/ui/content/Detail/demo/colors.js +39 -0
  145. package/ui/content/Detail/demo/controls.d.ts +8 -0
  146. package/ui/content/Detail/demo/controls.js +56 -0
  147. package/ui/content/Detail/demo/layout.d.ts +8 -0
  148. package/ui/content/Detail/demo/layout.js +56 -0
  149. package/ui/content/Detail/demo/responsive.d.ts +8 -0
  150. package/ui/content/Detail/demo/responsive.js +71 -0
  151. package/ui/content/Detail/demo/sizes.d.ts +8 -0
  152. package/ui/content/Detail/demo/sizes.js +61 -0
  153. package/ui/content/Detail/index.d.ts +3 -0
  154. package/ui/content/Detail/index.js +10 -0
  155. package/ui/content/DropDown/DropDown.d.ts +1 -0
  156. package/ui/content/DropDown/DropDown.js +1 -0
  157. package/ui/content/index.d.ts +13 -0
  158. package/ui/content/index.js +22 -0
  159. package/ui/crud/Crud/Crud.d.ts +1 -1
  160. package/ui/crud/Crud/Crud.js +5 -3
  161. package/ui/crud/Crud/CrudContent.d.ts +5 -1
  162. package/ui/crud/Crud/CrudContent.js +5 -5
  163. package/ui/crud/index.d.ts +2 -0
  164. package/ui/form/AutoCompleteField/AutoCompleteField.d.ts +1 -6
  165. package/ui/form/AutoCompleteField/demo/basic.d.ts +5 -5
  166. package/ui/form/AutoCompleteField/demo/basic.js +5 -5
  167. package/ui/form/AutoCompleteField/demo/disabled.d.ts +1 -1
  168. package/ui/form/AutoCompleteField/demo/disabled.js +1 -1
  169. package/ui/form/AutoCompleteField/demo/errors.d.ts +1 -1
  170. package/ui/form/AutoCompleteField/demo/errors.js +2 -2
  171. package/ui/form/AutoCompleteField/demo/placeholder.d.ts +1 -1
  172. package/ui/form/AutoCompleteField/demo/placeholder.js +1 -1
  173. package/ui/form/AutoCompleteField/demo/required.d.ts +1 -1
  174. package/ui/form/AutoCompleteField/demo/required.js +1 -1
  175. package/ui/form/AutoCompleteField/demo/sizes.d.ts +0 -5
  176. package/ui/form/AutoCompleteField/demo/sizes.js +5 -5
  177. package/ui/form/BlankField/BlankField.d.ts +6 -7
  178. package/ui/form/BlankField/demo/basic.d.ts +12 -0
  179. package/ui/form/BlankField/demo/basic.js +51 -0
  180. package/ui/form/Button/Button.d.ts +1 -0
  181. package/ui/form/Button/Button.js +1 -0
  182. package/ui/form/Button/demo/badge.d.ts +1 -1
  183. package/ui/form/Button/demo/badge.js +1 -1
  184. package/ui/form/Button/demo/basic.d.ts +1 -1
  185. package/ui/form/Button/demo/basic.js +1 -1
  186. package/ui/form/Button/demo/block.d.ts +1 -1
  187. package/ui/form/Button/demo/block.js +1 -1
  188. package/ui/form/Button/demo/colors.d.ts +1 -1
  189. package/ui/form/Button/demo/colors.js +3 -3
  190. package/ui/form/Button/demo/confirm.d.ts +1 -1
  191. package/ui/form/Button/demo/confirm.js +2 -2
  192. package/ui/form/Button/demo/disabled.d.ts +1 -1
  193. package/ui/form/Button/demo/disabled.js +1 -1
  194. package/ui/form/Button/demo/hint.d.ts +1 -1
  195. package/ui/form/Button/demo/hint.js +1 -1
  196. package/ui/form/Button/demo/icon.d.ts +1 -1
  197. package/ui/form/Button/demo/icon.js +1 -1
  198. package/ui/form/Button/demo/link.d.ts +1 -1
  199. package/ui/form/Button/demo/link.js +1 -1
  200. package/ui/form/Button/demo/sizes.d.ts +0 -5
  201. package/ui/form/Button/demo/sizes.js +5 -5
  202. package/ui/form/Button/demo/tags.d.ts +1 -1
  203. package/ui/form/Button/demo/tags.js +1 -1
  204. package/ui/form/CheckboxField/CheckboxField.d.ts +1 -6
  205. package/ui/form/CheckboxField/demo/basic.d.ts +1 -1
  206. package/ui/form/CheckboxField/demo/basic.js +1 -1
  207. package/ui/form/CheckboxField/demo/disabled.d.ts +1 -1
  208. package/ui/form/CheckboxField/demo/disabled.js +1 -1
  209. package/ui/form/CheckboxField/demo/errors.d.ts +1 -1
  210. package/ui/form/CheckboxField/demo/errors.js +2 -2
  211. package/ui/form/CheckboxField/demo/required.d.ts +1 -1
  212. package/ui/form/CheckboxField/demo/required.js +1 -1
  213. package/ui/form/CheckboxListField/CheckboxListField.d.ts +1 -6
  214. package/ui/form/CheckboxListField/demo/basic.d.ts +3 -3
  215. package/ui/form/CheckboxListField/demo/basic.js +5 -5
  216. package/ui/form/CheckboxListField/demo/disabled.d.ts +1 -1
  217. package/ui/form/CheckboxListField/demo/disabled.js +1 -1
  218. package/ui/form/CheckboxListField/demo/errors.d.ts +1 -1
  219. package/ui/form/CheckboxListField/demo/errors.js +2 -2
  220. package/ui/form/CheckboxListField/demo/required.d.ts +1 -1
  221. package/ui/form/CheckboxListField/demo/required.js +1 -1
  222. package/ui/form/DateField/DateField.d.ts +1 -7
  223. package/ui/form/DateField/DateField.js +1 -1
  224. package/ui/form/DateField/demo/basic.d.ts +1 -1
  225. package/ui/form/DateField/demo/basic.js +1 -1
  226. package/ui/form/DateField/demo/disabled.d.ts +1 -1
  227. package/ui/form/DateField/demo/disabled.js +1 -1
  228. package/ui/form/DateField/demo/errors.d.ts +1 -1
  229. package/ui/form/DateField/demo/errors.js +1 -1
  230. package/ui/form/DateField/demo/icon.d.ts +1 -1
  231. package/ui/form/DateField/demo/icon.js +2 -2
  232. package/ui/form/DateField/demo/placeholder.d.ts +1 -1
  233. package/ui/form/DateField/demo/placeholder.js +1 -1
  234. package/ui/form/DateField/demo/required.d.ts +1 -1
  235. package/ui/form/DateField/demo/required.js +1 -1
  236. package/ui/form/DateField/demo/sizes.d.ts +1 -1
  237. package/ui/form/DateField/demo/sizes.js +1 -1
  238. package/ui/form/DateField/useDateInputState.d.ts +4 -0
  239. package/ui/form/DateField/useDateInputState.js +3 -3
  240. package/ui/form/DateField/useDateTime.js +9 -7
  241. package/ui/form/DateRangeField/DateRangeField.d.ts +1 -7
  242. package/ui/form/DateRangeField/DateRangeField.js +3 -2
  243. package/ui/form/DateRangeField/demo/basic.d.ts +1 -1
  244. package/ui/form/DateRangeField/demo/basic.js +1 -1
  245. package/ui/form/DateRangeField/demo/disabled.d.ts +8 -0
  246. package/ui/form/DateRangeField/demo/disabled.js +33 -0
  247. package/ui/form/DateRangeField/demo/errors.d.ts +8 -0
  248. package/ui/form/DateRangeField/demo/errors.js +33 -0
  249. package/ui/form/DateRangeField/demo/icon.d.ts +8 -0
  250. package/ui/form/DateRangeField/demo/icon.js +35 -0
  251. package/ui/form/DateRangeField/demo/placeholder.d.ts +8 -0
  252. package/ui/form/DateRangeField/demo/placeholder.js +33 -0
  253. package/ui/form/DateRangeField/demo/required.d.ts +8 -0
  254. package/ui/form/DateRangeField/demo/required.js +33 -0
  255. package/ui/form/DateTimeField/DateTimeField.d.ts +1 -7
  256. package/ui/form/DateTimeField/DateTimeField.js +3 -2
  257. package/ui/form/DateTimeField/demo/basic.d.ts +1 -1
  258. package/ui/form/DateTimeField/demo/basic.js +1 -1
  259. package/ui/form/DateTimeField/demo/disabled.d.ts +1 -1
  260. package/ui/form/DateTimeField/demo/disabled.js +1 -1
  261. package/ui/form/DateTimeField/demo/errors.d.ts +1 -1
  262. package/ui/form/DateTimeField/demo/errors.js +2 -2
  263. package/ui/form/DateTimeField/demo/icon.d.ts +1 -1
  264. package/ui/form/DateTimeField/demo/icon.js +2 -2
  265. package/ui/form/DateTimeField/demo/placeholder.d.ts +1 -1
  266. package/ui/form/DateTimeField/demo/placeholder.js +2 -6
  267. package/ui/form/DateTimeField/demo/required.d.ts +1 -1
  268. package/ui/form/DateTimeField/demo/required.js +1 -1
  269. package/ui/form/DateTimeField/demo/showRemove.d.ts +8 -0
  270. package/ui/form/DateTimeField/demo/showRemove.js +32 -0
  271. package/ui/form/DateTimeRangeField/DateTimeRangeField.d.ts +1 -7
  272. package/ui/form/DateTimeRangeField/DateTimeRangeField.js +11 -2
  273. package/ui/form/DateTimeRangeField/demo/basic.d.ts +8 -0
  274. package/ui/form/DateTimeRangeField/demo/basic.js +32 -0
  275. package/ui/form/DateTimeRangeField/demo/disabled.d.ts +8 -0
  276. package/ui/form/{FieldLayout/demo/hint.js → DateTimeRangeField/demo/disabled.js} +4 -5
  277. package/ui/form/DateTimeRangeField/demo/errors.d.ts +8 -0
  278. package/ui/form/DateTimeRangeField/demo/errors.js +33 -0
  279. package/ui/form/DateTimeRangeField/demo/icon.d.ts +8 -0
  280. package/ui/form/DateTimeRangeField/demo/icon.js +32 -0
  281. package/ui/form/DateTimeRangeField/demo/placeholder.d.ts +8 -0
  282. package/ui/form/DateTimeRangeField/demo/placeholder.js +33 -0
  283. package/ui/form/DateTimeRangeField/demo/required.d.ts +8 -0
  284. package/ui/form/DateTimeRangeField/demo/required.js +33 -0
  285. package/ui/form/DateTimeRangeField/demo/showRemove.d.ts +8 -0
  286. package/ui/form/DateTimeRangeField/demo/showRemove.js +32 -0
  287. package/ui/form/DropDownField/DropDownField.d.ts +3 -8
  288. package/ui/form/DropDownField/DropDownField.js +20 -11
  289. package/ui/form/DropDownField/demo/auto-complete.d.ts +1 -1
  290. package/ui/form/DropDownField/demo/auto-complete.js +1 -1
  291. package/ui/form/DropDownField/demo/basic.d.ts +5 -5
  292. package/ui/form/DropDownField/demo/basic.js +6 -6
  293. package/ui/form/DropDownField/demo/disabled.d.ts +1 -1
  294. package/ui/form/DropDownField/demo/disabled.js +1 -1
  295. package/ui/form/DropDownField/demo/errors.d.ts +1 -1
  296. package/ui/form/DropDownField/demo/errors.js +2 -2
  297. package/ui/form/DropDownField/demo/multiple.d.ts +1 -1
  298. package/ui/form/DropDownField/demo/multiple.js +1 -1
  299. package/ui/form/DropDownField/demo/no-border.d.ts +1 -1
  300. package/ui/form/DropDownField/demo/no-border.js +1 -1
  301. package/ui/form/DropDownField/demo/placeholder.d.ts +1 -1
  302. package/ui/form/DropDownField/demo/placeholder.js +1 -1
  303. package/ui/form/DropDownField/demo/required.d.ts +1 -1
  304. package/ui/form/DropDownField/demo/required.js +1 -1
  305. package/ui/form/DropDownField/demo/show-reset.d.ts +1 -1
  306. package/ui/form/DropDownField/demo/show-reset.js +1 -1
  307. package/ui/form/DropDownField/demo/size.d.ts +1 -1
  308. package/ui/form/DropDownField/demo/size.js +1 -1
  309. package/ui/form/Field/demo/basic.d.ts +1 -1
  310. package/ui/form/Field/demo/basic.js +1 -1
  311. package/ui/form/Field/demo/component.d.ts +1 -1
  312. package/ui/form/Field/demo/component.js +1 -1
  313. package/ui/form/Field/demo/model.d.ts +1 -1
  314. package/ui/form/Field/demo/model.js +1 -1
  315. package/ui/form/Field/fieldWrapper.d.ts +4 -4
  316. package/ui/form/FieldLayout/demo/errors.d.ts +1 -1
  317. package/ui/form/FieldLayout/demo/errors.js +4 -3
  318. package/ui/form/FieldLayout/demo/layouts.d.ts +1 -1
  319. package/ui/form/FieldLayout/demo/layouts.js +4 -3
  320. package/ui/form/FieldLayout/demo/required.d.ts +1 -1
  321. package/ui/form/FieldLayout/demo/required.js +3 -2
  322. package/ui/form/FieldList/FieldList.d.ts +1 -6
  323. package/ui/form/FieldList/demo/basic.d.ts +1 -1
  324. package/ui/form/FieldList/demo/basic.js +1 -1
  325. package/ui/form/FieldList/demo/disabled.d.ts +8 -0
  326. package/ui/form/FieldList/demo/disabled.js +58 -0
  327. package/ui/form/FieldSet/demo/basic.d.ts +1 -1
  328. package/ui/form/FieldSet/demo/basic.js +1 -1
  329. package/ui/form/FileField/FileField.d.ts +1 -6
  330. package/ui/form/FileField/demo/basic.d.ts +8 -0
  331. package/ui/form/FileField/demo/basic.js +33 -0
  332. package/ui/form/Form/Form.d.ts +6 -0
  333. package/ui/form/Form/Form.js +119 -107
  334. package/ui/form/Form/demo/basic.d.ts +1 -1
  335. package/ui/form/Form/demo/basic.js +2 -2
  336. package/ui/form/Form/demo/border.d.ts +8 -0
  337. package/ui/form/Form/demo/border.js +58 -0
  338. package/ui/form/Form/demo/horizontal.d.ts +8 -0
  339. package/ui/form/Form/demo/horizontal.js +51 -0
  340. package/ui/form/Form/demo/inline.d.ts +8 -0
  341. package/ui/form/Form/demo/inline.js +49 -0
  342. package/ui/form/HtmlField/HtmlField.d.ts +1 -7
  343. package/ui/form/HtmlField/demo/basic.d.ts +1 -1
  344. package/ui/form/HtmlField/demo/basic.js +1 -1
  345. package/ui/form/ImageField/ImageField.d.ts +81 -0
  346. package/ui/form/ImageField/ImageField.js +145 -0
  347. package/ui/form/ImageField/index.d.ts +2 -0
  348. package/ui/form/ImageField/index.js +7 -0
  349. package/ui/form/InputField/InputField.d.ts +8 -6
  350. package/ui/form/InputField/InputField.js +26 -22
  351. package/ui/form/InputField/demo/addons.d.ts +3 -3
  352. package/ui/form/InputField/demo/addons.js +3 -3
  353. package/ui/form/InputField/demo/basic.d.ts +1 -1
  354. package/ui/form/InputField/demo/basic.js +2 -3
  355. package/ui/form/InputField/demo/disabled.d.ts +1 -1
  356. package/ui/form/InputField/demo/disabled.js +2 -3
  357. package/ui/form/InputField/demo/errors.d.ts +2 -2
  358. package/ui/form/InputField/demo/errors.js +3 -3
  359. package/ui/form/InputField/demo/mask.d.ts +2 -2
  360. package/ui/form/InputField/demo/mask.js +2 -2
  361. package/ui/form/InputField/demo/placeholder.d.ts +1 -1
  362. package/ui/form/InputField/demo/placeholder.js +1 -1
  363. package/ui/form/InputField/demo/required.d.ts +1 -1
  364. package/ui/form/InputField/demo/required.js +1 -1
  365. package/ui/form/InputField/demo/sizes.d.ts +0 -5
  366. package/ui/form/InputField/demo/sizes.js +5 -5
  367. package/ui/form/InputField/demo/textAddons.d.ts +3 -3
  368. package/ui/form/InputField/demo/textAddons.js +3 -3
  369. package/ui/form/InputField/demo/types.d.ts +0 -5
  370. package/ui/form/InputField/demo/types.js +7 -7
  371. package/ui/form/NavField/NavField.d.ts +2 -8
  372. package/ui/form/NavField/NavField.js +6 -3
  373. package/ui/form/NavField/demo/basic.d.ts +5 -5
  374. package/ui/form/NavField/demo/basic.js +6 -6
  375. package/ui/form/NavField/demo/disabled.d.ts +2 -2
  376. package/ui/form/NavField/demo/disabled.js +3 -3
  377. package/ui/form/NavField/demo/errors.d.ts +2 -2
  378. package/ui/form/NavField/demo/errors.js +4 -4
  379. package/ui/form/NavField/demo/layouts.d.ts +12 -0
  380. package/ui/form/NavField/demo/layouts.js +57 -0
  381. package/ui/form/NavField/demo/required.d.ts +2 -2
  382. package/ui/form/NavField/demo/required.js +3 -3
  383. package/ui/form/NumberField/NumberField.d.ts +1 -6
  384. package/ui/form/NumberField/demo/basic.d.ts +1 -1
  385. package/ui/form/NumberField/demo/basic.js +1 -1
  386. package/ui/form/NumberField/demo/disabled.d.ts +1 -1
  387. package/ui/form/NumberField/demo/disabled.js +1 -1
  388. package/ui/form/NumberField/demo/errors.d.ts +1 -1
  389. package/ui/form/NumberField/demo/errors.js +2 -2
  390. package/ui/form/NumberField/demo/placeholder.d.ts +1 -1
  391. package/ui/form/NumberField/demo/placeholder.js +1 -1
  392. package/ui/form/NumberField/demo/required.d.ts +1 -1
  393. package/ui/form/NumberField/demo/required.js +1 -1
  394. package/ui/form/NumberField/demo/sizes.d.ts +2 -2
  395. package/ui/form/NumberField/demo/sizes.js +2 -2
  396. package/ui/form/PasswordField/PasswordField.d.ts +1 -6
  397. package/ui/form/PasswordField/demo/basic.d.ts +1 -1
  398. package/ui/form/PasswordField/demo/basic.js +1 -1
  399. package/ui/form/PasswordField/demo/disabled.d.ts +1 -1
  400. package/ui/form/PasswordField/demo/disabled.js +1 -1
  401. package/ui/form/PasswordField/demo/errors.d.ts +1 -1
  402. package/ui/form/PasswordField/demo/errors.js +2 -2
  403. package/ui/form/PasswordField/demo/placeholder.d.ts +1 -1
  404. package/ui/form/PasswordField/demo/placeholder.js +1 -1
  405. package/ui/form/PasswordField/demo/required.d.ts +1 -1
  406. package/ui/form/PasswordField/demo/required.js +1 -1
  407. package/ui/form/PasswordField/demo/security.d.ts +1 -1
  408. package/ui/form/PasswordField/demo/security.js +1 -1
  409. package/ui/form/PasswordField/demo/sizes.d.ts +2 -2
  410. package/ui/form/PasswordField/demo/sizes.js +2 -2
  411. package/ui/form/RadioListField/RadioListField.d.ts +1 -6
  412. package/ui/form/RadioListField/demo/basic.d.ts +5 -5
  413. package/ui/form/RadioListField/demo/basic.js +5 -5
  414. package/ui/form/RadioListField/demo/disabled.d.ts +1 -1
  415. package/ui/form/RadioListField/demo/disabled.js +1 -1
  416. package/ui/form/RadioListField/demo/errors.d.ts +1 -1
  417. package/ui/form/RadioListField/demo/errors.js +2 -2
  418. package/ui/form/RadioListField/demo/required.d.ts +1 -1
  419. package/ui/form/RadioListField/demo/required.js +1 -1
  420. package/ui/form/RateField/RateField.d.ts +2 -8
  421. package/ui/form/RateField/demo/allow-clear.d.ts +1 -1
  422. package/ui/form/RateField/demo/allow-clear.js +1 -1
  423. package/ui/form/RateField/demo/basic.d.ts +1 -1
  424. package/ui/form/RateField/demo/basic.js +1 -1
  425. package/ui/form/RateField/demo/default-value.d.ts +1 -1
  426. package/ui/form/RateField/demo/default-value.js +1 -1
  427. package/ui/form/RateField/demo/disabled.d.ts +1 -1
  428. package/ui/form/RateField/demo/disabled.js +1 -1
  429. package/ui/form/RateField/demo/errors.d.ts +1 -1
  430. package/ui/form/RateField/demo/errors.js +2 -2
  431. package/ui/form/RateField/demo/items-count.d.ts +1 -1
  432. package/ui/form/RateField/demo/items-count.js +1 -1
  433. package/ui/form/RateField/demo/required.d.ts +1 -1
  434. package/ui/form/RateField/demo/required.js +1 -1
  435. package/ui/form/ReCaptchaField/ReCaptchaField.d.ts +1 -7
  436. package/ui/form/ReCaptchaField/demo/basic.d.ts +1 -1
  437. package/ui/form/ReCaptchaField/demo/basic.js +1 -1
  438. package/ui/form/SliderField/SliderField.d.ts +42 -15
  439. package/ui/form/SliderField/SliderField.js +18 -9
  440. package/ui/form/SliderField/demo/basic.d.ts +1 -1
  441. package/ui/form/SliderField/demo/basic.js +2 -2
  442. package/ui/form/SliderField/demo/disabled.d.ts +1 -1
  443. package/ui/form/SliderField/demo/disabled.js +2 -2
  444. package/ui/form/SliderField/demo/errors.d.ts +2 -2
  445. package/ui/form/SliderField/demo/errors.js +4 -4
  446. package/ui/form/SliderField/demo/marks.d.ts +3 -0
  447. package/ui/form/SliderField/demo/marks.js +45 -0
  448. package/ui/form/SliderField/demo/min-max.d.ts +2 -2
  449. package/ui/form/SliderField/demo/min-max.js +3 -3
  450. package/ui/form/SliderField/demo/onAfterChange.d.ts +8 -0
  451. package/ui/form/SliderField/demo/onAfterChange.js +39 -0
  452. package/ui/form/SliderField/demo/onChange.d.ts +8 -0
  453. package/ui/form/SliderField/demo/onChange.js +39 -0
  454. package/ui/form/SliderField/demo/range.d.ts +8 -0
  455. package/ui/form/SliderField/demo/{size.js → range.js} +5 -10
  456. package/ui/form/SwitcherField/SwitcherField.d.ts +1 -7
  457. package/ui/form/SwitcherField/demo/basic.d.ts +5 -5
  458. package/ui/form/SwitcherField/demo/basic.js +5 -5
  459. package/ui/form/SwitcherField/demo/disabled.d.ts +1 -1
  460. package/ui/form/SwitcherField/demo/disabled.js +2 -2
  461. package/ui/form/SwitcherField/demo/errors.d.ts +1 -1
  462. package/ui/form/SwitcherField/demo/errors.js +3 -3
  463. package/ui/form/SwitcherField/demo/required.d.ts +1 -1
  464. package/ui/form/SwitcherField/demo/required.js +2 -2
  465. package/ui/form/TextField/TextField.d.ts +3 -7
  466. package/ui/form/TextField/TextField.js +1 -1
  467. package/ui/form/TextField/demo/basic.d.ts +1 -1
  468. package/ui/form/TextField/demo/basic.js +1 -1
  469. package/ui/form/TextField/demo/disabled.d.ts +1 -1
  470. package/ui/form/TextField/demo/disabled.js +1 -1
  471. package/ui/form/TextField/demo/errors.d.ts +1 -1
  472. package/ui/form/TextField/demo/errors.js +2 -2
  473. package/ui/form/TextField/demo/placeholder.d.ts +1 -1
  474. package/ui/form/TextField/demo/placeholder.js +1 -1
  475. package/ui/form/TextField/demo/required.d.ts +1 -1
  476. package/ui/form/TextField/demo/required.js +1 -1
  477. package/ui/form/TextField/demo/sizes.d.ts +0 -5
  478. package/ui/form/TextField/demo/sizes.js +5 -5
  479. package/ui/form/TextField/demo/submit.d.ts +2 -2
  480. package/ui/form/TextField/demo/submit.js +2 -2
  481. package/ui/form/TimeField/TimeField.d.ts +1 -7
  482. package/ui/form/TimeField/TimeField.js +1 -1
  483. package/ui/form/TimeField/demo/basic.d.ts +1 -1
  484. package/ui/form/TimeField/demo/basic.js +1 -1
  485. package/ui/form/TimeField/demo/disabled.d.ts +1 -1
  486. package/ui/form/TimeField/demo/disabled.js +1 -1
  487. package/ui/form/TimeField/demo/errors.d.ts +1 -1
  488. package/ui/form/TimeField/demo/errors.js +2 -2
  489. package/ui/form/TimeField/demo/icon.d.ts +8 -0
  490. package/ui/form/TimeField/demo/icon.js +33 -0
  491. package/ui/form/TimeField/demo/{no-border.d.ts → noBorder.d.ts} +1 -1
  492. package/ui/form/TimeField/demo/{no-border.js → noBorder.js} +1 -1
  493. package/ui/form/TimeField/demo/placeholder.d.ts +1 -1
  494. package/ui/form/TimeField/demo/placeholder.js +1 -1
  495. package/ui/form/TimeField/demo/required.d.ts +1 -1
  496. package/ui/form/TimeField/demo/required.js +1 -1
  497. package/ui/form/TimeField/demo/showRemove.d.ts +8 -0
  498. package/ui/form/TimeField/demo/{show-remove.js → showRemove.js} +1 -1
  499. package/ui/form/index.d.ts +22 -132
  500. package/ui/format/EnumFormatter/EnumFormatter.js +1 -1
  501. package/ui/icon/Icon/Icon.js +3 -0
  502. package/ui/icon/Icon/demo/icon.d.ts +3 -0
  503. package/ui/{form/SliderField/demo/required.js → icon/Icon/demo/icon.js} +2 -7
  504. package/ui/layout/Meta/Meta.d.ts +56 -0
  505. package/ui/layout/Meta/Meta.js +38 -0
  506. package/ui/layout/Meta/index.d.ts +2 -0
  507. package/ui/layout/Meta/index.js +7 -0
  508. package/ui/layout/Notifications/Notifications.d.ts +14 -0
  509. package/ui/layout/Notifications/Notifications.js +1 -1
  510. package/ui/layout/Notifications/demo/basic.d.ts +8 -0
  511. package/ui/layout/Notifications/demo/basic.js +53 -0
  512. package/ui/layout/Notifications/demo/position.d.ts +3 -0
  513. package/ui/layout/Notifications/demo/position.js +45 -0
  514. package/ui/layout/Notifications/demo/timeOut.d.ts +3 -0
  515. package/ui/layout/Notifications/demo/timeOut.js +45 -0
  516. package/ui/layout/Portal.js +3 -0
  517. package/ui/layout/ProgressBar/ProgressBar.d.ts +55 -0
  518. package/ui/layout/ProgressBar/ProgressBar.js +53 -0
  519. package/ui/layout/ProgressBar/demo/percent.d.ts +8 -0
  520. package/ui/layout/ProgressBar/demo/percent.js +49 -0
  521. package/ui/layout/ProgressBar/demo/showLabel.d.ts +8 -0
  522. package/ui/layout/ProgressBar/demo/showLabel.js +40 -0
  523. package/ui/{form/TimeField → layout/ProgressBar}/demo/sizes.d.ts +1 -1
  524. package/ui/layout/ProgressBar/demo/sizes.js +40 -0
  525. package/ui/layout/ProgressBar/demo/status.d.ts +8 -0
  526. package/ui/{form/DateTimeField/demo/sizes.js → layout/ProgressBar/demo/status.js} +8 -12
  527. package/ui/layout/ProgressBar/demo/type.d.ts +8 -0
  528. package/ui/layout/ProgressBar/demo/type.js +40 -0
  529. package/ui/layout/ProgressBar/index.d.ts +2 -0
  530. package/ui/layout/ProgressBar/index.js +7 -0
  531. package/ui/layout/Skeleton/Skeleton.d.ts +25 -0
  532. package/ui/layout/Skeleton/Skeleton.js +11 -0
  533. package/ui/layout/Skeleton/demo/animations.d.ts +8 -0
  534. package/ui/layout/Skeleton/demo/animations.js +49 -0
  535. package/ui/layout/Skeleton/demo/width height.d.ts +8 -0
  536. package/ui/layout/Skeleton/demo/width height.js +38 -0
  537. package/ui/layout/Skeleton/index.d.ts +2 -0
  538. package/ui/layout/Skeleton/index.js +7 -0
  539. package/ui/layout/Tooltip/demo/basic.d.ts +5 -0
  540. package/ui/layout/Tooltip/demo/basic.js +20 -9
  541. package/ui/list/Grid/Grid.js +3 -1
  542. package/ui/list/Grid/demo/inner-search-form.d.ts +1 -6
  543. package/ui/list/LayoutNames/LayoutNames.js +4 -3
  544. package/ui/list/List/List.js +4 -6
  545. package/ui/list/PaginationSize/PaginationSize.d.ts +2 -2
  546. package/ui/list/Steps/Steps.d.ts +32 -0
  547. package/ui/list/Steps/Steps.js +23 -0
  548. package/ui/list/Steps/index.d.ts +2 -0
  549. package/ui/list/Steps/index.js +7 -0
  550. package/ui/modal/Modal/Modal.d.ts +52 -32
  551. package/ui/modal/Modal/Modal.js +3 -1
  552. package/ui/modal/Modal/demo/basic.d.ts +1 -1
  553. package/ui/modal/Modal/demo/basic.js +16 -7
  554. package/ui/modal/Modal/demo/closeTimeout.d.ts +8 -0
  555. package/ui/modal/Modal/demo/closeTimeout.js +60 -0
  556. package/ui/modal/Modal/demo/closing.d.ts +9 -0
  557. package/ui/modal/Modal/demo/closing.js +63 -0
  558. package/ui/modal/Modal/demo/component.d.ts +10 -0
  559. package/ui/modal/Modal/demo/component.js +51 -0
  560. package/ui/modal/Modal/demo/controls.d.ts +8 -0
  561. package/ui/modal/Modal/demo/controls.js +62 -0
  562. package/ui/modal/Modal/demo/size.d.ts +8 -0
  563. package/ui/modal/Modal/demo/size.js +66 -0
  564. package/ui/modal/ModalPortal/ModalPortal.d.ts +8 -0
  565. package/ui/modal/ModalPortal/ModalPortal.js +7 -9
  566. package/ui/nav/Breadcrumbs/Breadcrumbs.d.ts +10 -4
  567. package/ui/nav/Breadcrumbs/demo/basic.d.ts +1 -1
  568. package/ui/nav/Breadcrumbs/demo/basic.js +1 -1
  569. package/ui/nav/Breadcrumbs/demo/items.d.ts +8 -0
  570. package/ui/{form/TimeField/demo/sizes.js → nav/Breadcrumbs/demo/items.js} +9 -10
  571. package/ui/nav/Breadcrumbs/demo/page-title.d.ts +1 -1
  572. package/ui/nav/Breadcrumbs/demo/page-title.js +1 -1
  573. package/ui/nav/Nav/Nav.js +1 -1
  574. package/ui/nav/Router/Router.d.ts +18 -0
  575. package/ui/nav/Router/Router.js +1 -3
  576. package/utils/calendar.d.ts +1 -1
  577. package/utils/calendar.js +8 -1
  578. package/utils/form.d.ts +2 -7
  579. package/components/social/index.d.ts +0 -11
  580. package/components/social/index.js +0 -15
  581. package/ui/content/Avatar/SizeContext.d.ts +0 -1
  582. package/ui/content/Avatar/SizeContext.js +0 -14
  583. package/ui/nav/Router/SsrProvider.d.ts +0 -15
  584. package/ui/nav/Router/SsrProvider.js +0 -55
package/hooks/useList.js CHANGED
@@ -33,6 +33,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
33
33
  return (mod && mod.__esModule) ? mod : { "default": mod };
34
34
  };
35
35
  exports.__esModule = true;
36
+ exports.createInitialValues = exports.getDefaultSearchModel = exports.normalizeSortProps = exports.defaultConfig = void 0;
36
37
  var react_1 = require("react");
37
38
  var get_1 = __importDefault(require("lodash-es/get"));
38
39
  var union_1 = __importDefault(require("lodash-es/union"));
@@ -52,8 +53,7 @@ var useInitial_1 = __importDefault(require("../hooks/useInitial"));
52
53
  var Pagination_1 = require("../ui/list/Pagination/Pagination");
53
54
  var PaginationSize_1 = require("../ui/list/PaginationSize/PaginationSize");
54
55
  var Empty_1 = require("../ui/list/Empty/Empty");
55
- var index_1 = require("../hooks/index");
56
- var defaultConfig = {
56
+ exports.defaultConfig = {
57
57
  actionMethod: 'get',
58
58
  primaryKey: 'id',
59
59
  autoDestroy: true,
@@ -67,6 +67,43 @@ var defaultConfig = {
67
67
  useHash: false
68
68
  }
69
69
  };
70
+ var normalizeSortProps = function (props) { return (__assign(__assign(__assign({}, exports.defaultConfig.sort), { enable: !!props }), (typeof props === 'boolean' ? { enable: props } : props))); };
71
+ exports.normalizeSortProps = normalizeSortProps;
72
+ var getDefaultSearchModel = function (_a) {
73
+ var paginationProps = _a.paginationProps, paginationSizeProps = _a.paginationSizeProps, sort = _a.sort, layoutNamesProps = _a.layoutNamesProps;
74
+ return ({
75
+ attributes: [
76
+ paginationProps.enable && {
77
+ type: 'number',
78
+ attribute: paginationProps.attribute,
79
+ defaultValue: paginationProps.defaultValue
80
+ },
81
+ paginationSizeProps.enable && {
82
+ type: 'number',
83
+ attribute: paginationSizeProps.attribute,
84
+ defaultValue: paginationSizeProps.defaultValue
85
+ },
86
+ sort.enable && {
87
+ type: 'string',
88
+ jsType: 'string[]',
89
+ attribute: sort.attribute,
90
+ defaultValue: sort.defaultValue
91
+ },
92
+ layoutNamesProps.enable && {
93
+ type: 'string',
94
+ attribute: layoutNamesProps.attribute,
95
+ defaultValue: layoutNamesProps.defaultValue
96
+ },
97
+ ].filter(Boolean)
98
+ });
99
+ };
100
+ exports.getDefaultSearchModel = getDefaultSearchModel;
101
+ var createInitialValues = function (_a) {
102
+ var _b;
103
+ var paginationProps = _a.paginationProps, paginationSizeProps = _a.paginationSizeProps, sort = _a.sort, layoutNamesProps = _a.layoutNamesProps, initialQuery = _a.initialQuery, configQuery = _a.configQuery;
104
+ return (__assign(__assign((_b = {}, _b[paginationProps.attribute] = paginationProps.defaultValue, _b[paginationSizeProps.attribute] = paginationSizeProps.defaultValue, _b[sort.attribute] = sort.defaultValue, _b[layoutNamesProps.attribute] = layoutNamesProps.defaultValue, _b), initialQuery), configQuery));
105
+ };
106
+ exports.createInitialValues = createInitialValues;
70
107
  /**
71
108
  * useList
72
109
  * Добавляет массу возможностей для взаимодействия с коллекциями. Коллекции можно получать как с бекенда,
@@ -75,11 +112,10 @@ var defaultConfig = {
75
112
  */
76
113
  function useList(config) {
77
114
  var _a, _b;
78
- var components = index_1.useComponents();
79
115
  // Get list from redux state
80
116
  var list = useSelector_1["default"](function (state) { return list_1.getList(state, config.listId); });
81
117
  // Normalize sort config
82
- var sort = react_1.useMemo(function () { return (__assign(__assign(__assign({}, defaultConfig.sort), { enable: !!config.sort }), (typeof config.sort === 'boolean' ? { enable: config.sort } : config.sort))); }, [config.sort]);
118
+ var sort = exports.normalizeSortProps(config.sort);
83
119
  // Empty
84
120
  var Empty = require('../ui/list/Empty')["default"];
85
121
  var emptyProps = Empty_1.normalizeEmptyProps(config.empty);
@@ -107,32 +143,14 @@ function useList(config) {
107
143
  var layoutNamesProps = LayoutNames_1.normalizeLayoutNamesProps(config.layout);
108
144
  var renderLayoutNames = function () { return React.createElement(LayoutNames, __assign({ list: list }, layoutNamesProps)); };
109
145
  // Models
146
+ var defaultSearchModel = react_1.useMemo(function () { return exports.getDefaultSearchModel({
147
+ paginationProps: paginationProps,
148
+ paginationSizeProps: paginationSizeProps,
149
+ sort: sort,
150
+ layoutNamesProps: layoutNamesProps
151
+ }); }, [layoutNamesProps, paginationProps, paginationSizeProps, sort]);
110
152
  var model = useModel_1["default"](config.model);
111
- var searchModel = useModel_1["default"](config.searchModel || ((_a = config.searchForm) === null || _a === void 0 ? void 0 : _a.model), {
112
- attributes: [
113
- paginationProps.enable && {
114
- type: 'number',
115
- attribute: paginationProps.attribute,
116
- defaultValue: paginationProps.defaultValue
117
- },
118
- paginationSizeProps.enable && {
119
- type: 'number',
120
- attribute: paginationSizeProps.attribute,
121
- defaultValue: paginationSizeProps.defaultValue
122
- },
123
- sort.enable && {
124
- type: 'string',
125
- jsType: 'string[]',
126
- attribute: sort.attribute,
127
- defaultValue: sort.defaultValue
128
- },
129
- layoutNamesProps.enable && {
130
- type: 'string',
131
- attribute: layoutNamesProps.attribute,
132
- defaultValue: layoutNamesProps.defaultValue
133
- },
134
- ].filter(Boolean)
135
- });
153
+ var searchModel = useModel_1["default"](config.searchModel || ((_a = config.searchForm) === null || _a === void 0 ? void 0 : _a.model), defaultSearchModel);
136
154
  // Address bar synchronization
137
155
  var _c = useAddressBar_1["default"](__assign({ enable: !!config.addressBar, model: searchModel }, (typeof config.addressBar === 'boolean' ? { enable: config.addressBar } : config.addressBar))), initialQuery = _c.initialQuery, updateQuery = _c.updateQuery;
138
156
  // Outside search form
@@ -149,34 +167,51 @@ function useList(config) {
149
167
  var formId = get_1["default"](config, 'searchForm.formId') || config.listId;
150
168
  var dispatch = useDispatch_1["default"]();
151
169
  // List wrapper (form context)
152
- var initialValues = useInitial_1["default"](function () {
153
- var _a;
154
- return (__assign(__assign((_a = {}, _a[paginationProps.attribute] = paginationProps.defaultValue, _a[paginationSizeProps.attribute] = paginationSizeProps.defaultValue, _a[sort.attribute] = sort.defaultValue, _a[layoutNamesProps.attribute] = layoutNamesProps.defaultValue, _a), initialQuery), config.query));
155
- });
170
+ var _initialValues = react_1.useMemo(function () { return exports.createInitialValues({
171
+ paginationProps: paginationProps,
172
+ paginationSizeProps: paginationSizeProps,
173
+ sort: sort,
174
+ layoutNamesProps: layoutNamesProps,
175
+ initialQuery: initialQuery,
176
+ configQuery: config.query
177
+ }); }, [config.query, initialQuery, layoutNamesProps, paginationProps, paginationSizeProps, sort]);
178
+ var initialValues = useInitial_1["default"](function () { return _initialValues; });
156
179
  var renderList = react_1.useCallback(function (children) {
157
180
  var Form = require('../ui/form/Form')["default"];
158
181
  return (React.createElement(Form, { formId: formId, initialValues: initialValues, view: false, useRedux: true }, children));
159
182
  }, [formId, initialValues]);
160
183
  // Init list in redux store
161
184
  react_use_1.useMount(function () {
162
- dispatch(list_2.listInit(config.listId, {
163
- listId: config.listId,
164
- action: config.action || config.action === '' ? config.action : null,
165
- actionMethod: config.actionMethod || defaultConfig.actionMethod,
166
- onFetch: config.onFetch,
167
- condition: config.condition,
168
- scope: config.scope,
169
- items: null,
170
- sourceItems: config.items || null,
171
- isRemote: !config.items,
172
- primaryKey: config.primaryKey || defaultConfig.primaryKey,
173
- formId: formId,
174
- loadMore: paginationProps.loadMore,
175
- pageAttribute: paginationProps.attribute || null,
176
- pageSizeAttribute: paginationSizeProps.attribute || null,
177
- sortAttribute: sort.attribute || null,
178
- layoutAttribute: layoutNamesProps.attribute || null
179
- }));
185
+ if (!list) {
186
+ var toDispatch = [
187
+ list_2.listInit(config.listId, {
188
+ listId: config.listId,
189
+ action: config.action || config.action === '' ? config.action : null,
190
+ actionMethod: config.actionMethod || exports.defaultConfig.actionMethod,
191
+ onFetch: config.onFetch,
192
+ condition: config.condition,
193
+ scope: config.scope,
194
+ items: null,
195
+ sourceItems: config.items || null,
196
+ total: config.initialTotal,
197
+ isRemote: !config.items,
198
+ primaryKey: config.primaryKey || exports.defaultConfig.primaryKey,
199
+ formId: formId,
200
+ loadMore: paginationProps.loadMore,
201
+ pageAttribute: paginationProps.attribute || null,
202
+ pageSizeAttribute: paginationSizeProps.attribute || null,
203
+ sortAttribute: sort.attribute || null,
204
+ layoutAttribute: layoutNamesProps.attribute || null
205
+ }),
206
+ ];
207
+ if (config.initialItems || config.items) {
208
+ toDispatch.push(list_2.listSetItems(config.listId, config.initialItems || config.items));
209
+ }
210
+ if (!config.initialItems) {
211
+ toDispatch.push(list_2.listLazyFetch(config.listId));
212
+ }
213
+ dispatch(toDispatch);
214
+ }
180
215
  });
181
216
  // Check form values change
182
217
  var formValues = useSelector_1["default"](function (state) { return form_2.formSelector(state, formId, function (_a) {
@@ -185,7 +220,7 @@ function useList(config) {
185
220
  }); });
186
221
  var prevFormValues = react_use_1.usePrevious(formValues);
187
222
  react_use_1.useUpdateEffect(function () {
188
- if (!isEqual_1["default"](formValues, prevFormValues)) {
223
+ if (prevFormValues && !isEqual_1["default"](formValues, prevFormValues)) {
189
224
  // Has changes (but not page) -> reset page
190
225
  var attribute = paginationProps.attribute;
191
226
  if ((prevFormValues === null || prevFormValues === void 0 ? void 0 : prevFormValues[attribute]) === formValues[attribute] && formValues[attribute] > 1) {
@@ -210,7 +245,7 @@ function useList(config) {
210
245
  });
211
246
  }, [formId, prevQuery, config.query, dispatch]);
212
247
  // Check change items
213
- react_1.useEffect(function () {
248
+ react_use_1.useUpdateEffect(function () {
214
249
  dispatch([
215
250
  list_2.listSetItems(config.listId, config.items),
216
251
  list_2.listLazyFetch(config.listId),
@@ -218,7 +253,7 @@ function useList(config) {
218
253
  }, [dispatch, config.items, config.listId]);
219
254
  // Destroy
220
255
  react_use_1.useUnmount(function () {
221
- var autoDestroy = typeof config.autoDestroy === 'boolean' ? config.autoDestroy : defaultConfig.autoDestroy;
256
+ var autoDestroy = typeof config.autoDestroy === 'boolean' ? config.autoDestroy : exports.defaultConfig.autoDestroy;
222
257
  if (autoDestroy) {
223
258
  dispatch(list_2.listDestroy(config.listId));
224
259
  }
package/hooks/useModel.js CHANGED
@@ -8,6 +8,6 @@ var useComponents_1 = __importDefault(require("./useComponents"));
8
8
  function useModel(model, defaultModel) {
9
9
  if (defaultModel === void 0) { defaultModel = null; }
10
10
  var components = useComponents_1["default"]();
11
- return react_1.useMemo(function () { return components.meta.normalizeModel(components.meta.getModel(model), defaultModel); }, [components.meta, defaultModel, model]);
11
+ return react_1.useMemo(function () { return components.meta.normalizeModel(typeof model === 'string' ? components.meta.getModel(model) : model, defaultModel); }, [components.meta, defaultModel, model]);
12
12
  }
13
13
  exports["default"] = useModel;
@@ -1,2 +1,2 @@
1
- import { IScreen } from './useApplication';
1
+ import { IScreen } from '../providers/ScreenProvider';
2
2
  export default function useScreen(): IScreen;
@@ -1,8 +1,8 @@
1
1
  "use strict";
2
2
  exports.__esModule = true;
3
3
  var react_1 = require("react");
4
- var useApplication_1 = require("../hooks/useApplication");
4
+ var ScreenProvider_1 = require("../providers/ScreenProvider");
5
5
  function useScreen() {
6
- return react_1.useContext(useApplication_1.ScreenContext);
6
+ return react_1.useContext(ScreenProvider_1.ScreenContext);
7
7
  }
8
8
  exports["default"] = useScreen;
@@ -0,0 +1,2 @@
1
+ import { ISsr } from '../providers/SsrProvider';
2
+ export default function useSsr(): ISsr;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ exports.__esModule = true;
3
+ var react_1 = require("react");
4
+ var SsrProvider_1 = require("../providers/SsrProvider");
5
+ function useSsr() {
6
+ return react_1.useContext(SsrProvider_1.SsrProviderContext) || {};
7
+ }
8
+ exports["default"] = useSsr;
package/index.d.ts CHANGED
@@ -26,7 +26,7 @@ declare function __(phrase: string, params?: any): string;
26
26
  * Название цвета, соответствующее ему состоянию
27
27
  */
28
28
  declare type ColorName =
29
- 'primary'
29
+ | 'primary'
30
30
  | 'secondary'
31
31
  | 'success'
32
32
  | 'info'
@@ -44,7 +44,7 @@ declare type PrimaryKey = number | string;
44
44
  /**
45
45
  * Размер элемента
46
46
  */
47
- declare type Size = 'sm' | 'md' | 'lg' | string;
47
+ declare type Size = 'small' | 'middle' | 'large' | string;
48
48
 
49
49
  /**
50
50
  * Макет формы или ее части, влияющий на расположение полей
@@ -78,6 +78,12 @@ declare type FormInputType = {
78
78
  */
79
79
  declare type CssClassName = string;
80
80
 
81
+ /**
82
+ * Дополнительные стили
83
+ * @example my-block
84
+ */
85
+ declare type CustomStyle = React.CSSProperties;
86
+
81
87
  /**
82
88
  * Переопределение view React компонента для кастомизации отображения
83
89
  * @example MyCustomView
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@steroidsjs/core",
3
- "version": "2.1.0-beta.3",
3
+ "version": "2.1.0-beta.33",
4
4
  "description": "",
5
5
  "author": "Vladimir Kozhin <hello@kozhindev.com>",
6
6
  "repository": {
@@ -43,13 +43,16 @@
43
43
  "react-day-picker": "^7.4.8",
44
44
  "react-dom": "^17.0.2",
45
45
  "react-grid-gallery": "^0.4.8",
46
+ "react-helmet": "^6.1.0",
47
+ "react-image-crop": "^9.0.2",
46
48
  "react-input-mask": "^3.0.0-alpha.2",
47
- "react-redux": "^7.1.1",
49
+ "react-redux": "7.1.1",
48
50
  "react-router": "^5.2.0",
49
51
  "react-router-dom": "^5.2.0",
50
52
  "react-use": "^17.1.0",
51
53
  "redux": "^4.0.4",
52
- "redux-mock-store": "^1.5.4"
54
+ "redux-mock-store": "^1.5.4",
55
+ "set-cookie-parser": "^2.4.8"
53
56
  },
54
57
  "devDependencies": {
55
58
  "@babel/cli": "^7.13.14",
@@ -58,12 +61,12 @@
58
61
  "@babel/preset-react": "^7.13.13",
59
62
  "@babel/preset-typescript": "^7.13.0",
60
63
  "@types/enzyme": "^3.10.8",
64
+ "@types/enzyme-adapter-react-16": "^1.0.6",
61
65
  "@types/jest": "^26.0.22",
62
66
  "@types/markdown-to-jsx": "^6.11.3",
63
67
  "@types/reach__router": "^1.3.7",
64
68
  "@types/react": "=17.0.3",
65
69
  "@types/react-color": "^3.0.4",
66
- "@types/enzyme-adapter-react-16": "^1.0.6",
67
70
  "@types/react-syntax-highlighter": "^13.5.0",
68
71
  "@types/webpack-env": "^1.16.0",
69
72
  "@typescript-eslint/eslint-plugin": "^4.15.0",
@@ -0,0 +1,26 @@
1
+ import * as React from 'react';
2
+ import { PropsWithChildren } from 'react';
3
+ declare global {
4
+ interface Window {
5
+ SteroidsComponents: IComponents;
6
+ }
7
+ }
8
+ export interface IComponents {
9
+ api?: any;
10
+ clientStorage?: any;
11
+ html?: any;
12
+ http?: any;
13
+ locale?: any;
14
+ store?: any;
15
+ ui?: any;
16
+ resource?: any;
17
+ ws?: any;
18
+ pushNotification?: any;
19
+ meta?: any;
20
+ [key: string]: any;
21
+ }
22
+ export interface IComponentsProviderProps extends PropsWithChildren<any> {
23
+ components: IComponents;
24
+ }
25
+ export declare const ComponentsContext: React.Context<IComponents>;
26
+ export default function ComponentsProvider(props: IComponentsProviderProps): JSX.Element;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ exports.__esModule = true;
22
+ exports.ComponentsContext = void 0;
23
+ var React = __importStar(require("react"));
24
+ exports.ComponentsContext = React.createContext({});
25
+ function ComponentsProvider(props) {
26
+ return (React.createElement(exports.ComponentsContext.Provider, { value: props.components }, props.children));
27
+ }
28
+ exports["default"] = ComponentsProvider;
@@ -0,0 +1,20 @@
1
+ import * as React from 'react';
2
+ import { PropsWithChildren } from 'react';
3
+ export interface IScreen {
4
+ width: number;
5
+ media: Record<string, any>;
6
+ setMedia: any;
7
+ isPhone: () => boolean;
8
+ isTablet: () => boolean;
9
+ isDesktop: () => boolean;
10
+ getDeviceType: () => string;
11
+ }
12
+ export declare const ScreenContext: React.Context<IScreen>;
13
+ export interface IScreenProviderProps extends PropsWithChildren<any> {
14
+ media?: Record<string, any>;
15
+ skipTimeout?: boolean;
16
+ }
17
+ export declare const SCREEN_PHONE = "phone";
18
+ export declare const SCREEN_TABLET = "tablet";
19
+ export declare const SCREEN_DESKTOP = "desktop";
20
+ export default function ScreenProvider(props: IScreenProviderProps): JSX.Element;
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ exports.__esModule = true;
22
+ exports.SCREEN_DESKTOP = exports.SCREEN_TABLET = exports.SCREEN_PHONE = exports.ScreenContext = void 0;
23
+ var React = __importStar(require("react"));
24
+ var react_1 = require("react");
25
+ var react_use_1 = require("react-use");
26
+ exports.ScreenContext = React.createContext({});
27
+ exports.SCREEN_PHONE = 'phone';
28
+ exports.SCREEN_TABLET = 'tablet';
29
+ exports.SCREEN_DESKTOP = 'desktop';
30
+ function ScreenProvider(props) {
31
+ var _a;
32
+ var _b = react_1.useState(!process.env.IS_SSR ? window.innerWidth : 1280), width = _b[0], setWidth = _b[1];
33
+ var _c = react_1.useState(props.media || (_a = {},
34
+ _a[exports.SCREEN_PHONE] = 320,
35
+ _a[exports.SCREEN_TABLET] = 768,
36
+ _a[exports.SCREEN_DESKTOP] = 1024,
37
+ _a)), media = _c[0], setMedia = _c[1];
38
+ var timer = null;
39
+ var onResize = function () {
40
+ if (timer) {
41
+ clearTimeout(timer);
42
+ }
43
+ if (props.skipTimeout) {
44
+ setWidth(window.innerWidth);
45
+ }
46
+ else {
47
+ timer = setTimeout(function () { return setWidth(window.innerWidth); }, 100);
48
+ }
49
+ };
50
+ react_use_1.useMount(function () {
51
+ window.addEventListener('resize', onResize, false);
52
+ });
53
+ react_use_1.useUnmount(function () {
54
+ window.removeEventListener('resize', onResize);
55
+ });
56
+ var getDeviceType = react_1.useCallback(function () {
57
+ if (width < media[exports.SCREEN_TABLET]) {
58
+ return exports.SCREEN_PHONE;
59
+ }
60
+ if (width < media[exports.SCREEN_DESKTOP]) {
61
+ return exports.SCREEN_TABLET;
62
+ }
63
+ return exports.SCREEN_DESKTOP;
64
+ }, [width, media]);
65
+ var isPhone = react_1.useCallback(function () { return getDeviceType() === exports.SCREEN_PHONE; }, [getDeviceType]);
66
+ var isTablet = react_1.useCallback(function () { return getDeviceType() === exports.SCREEN_TABLET; }, [getDeviceType]);
67
+ var isDesktop = react_1.useCallback(function () { return getDeviceType() === exports.SCREEN_DESKTOP; }, [getDeviceType]);
68
+ var value = react_1.useMemo(function () { return ({
69
+ width: width,
70
+ media: media,
71
+ setMedia: setMedia,
72
+ isPhone: isPhone,
73
+ isTablet: isTablet,
74
+ isDesktop: isDesktop,
75
+ getDeviceType: getDeviceType
76
+ }); }, [
77
+ width,
78
+ media,
79
+ setMedia,
80
+ isPhone,
81
+ isTablet,
82
+ isDesktop,
83
+ getDeviceType,
84
+ ]);
85
+ return (React.createElement(exports.ScreenContext.Provider, { value: value }, props.children));
86
+ }
87
+ exports["default"] = ScreenProvider;
@@ -0,0 +1,17 @@
1
+ import * as React from 'react';
2
+ import { PropsWithChildren } from 'react';
3
+ import { StaticRouterContext } from 'react-router';
4
+ export interface IPreloadedData {
5
+ [configId: string]: any;
6
+ }
7
+ export interface ISsr {
8
+ history?: {
9
+ initialEntries: string[];
10
+ };
11
+ staticContext?: StaticRouterContext;
12
+ preloadedData?: IPreloadedData;
13
+ }
14
+ export declare const SsrProviderContext: React.Context<ISsr>;
15
+ export interface ISsrProviderProps extends ISsr, PropsWithChildren<any> {
16
+ }
17
+ export default function SsrProvider(props: ISsrProviderProps): JSX.Element;
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ exports.__esModule = true;
22
+ exports.SsrProviderContext = void 0;
23
+ var React = __importStar(require("react"));
24
+ exports.SsrProviderContext = React.createContext(null);
25
+ function SsrProvider(props) {
26
+ return (React.createElement(exports.SsrProviderContext.Provider, { value: {
27
+ history: props.history,
28
+ staticContext: props.staticContext,
29
+ preloadedData: props.preloadedData
30
+ } }, props.children));
31
+ }
32
+ exports["default"] = SsrProvider;
@@ -0,0 +1,4 @@
1
+ import SsrProvider from '@steroidsjs/core/providers/SsrProvider';
2
+ import ScreenProvider from '@steroidsjs/core/providers/ScreenProvider';
3
+ import ComponentsProvider from '@steroidsjs/core/providers/ComponentsProvider';
4
+ export { SsrProvider, ScreenProvider, ComponentsProvider };
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ exports.__esModule = true;
6
+ exports.ComponentsProvider = exports.ScreenProvider = exports.SsrProvider = void 0;
7
+ var SsrProvider_1 = __importDefault(require("@steroidsjs/core/providers/SsrProvider"));
8
+ exports.SsrProvider = SsrProvider_1["default"];
9
+ var ScreenProvider_1 = __importDefault(require("@steroidsjs/core/providers/ScreenProvider"));
10
+ exports.ScreenProvider = ScreenProvider_1["default"];
11
+ var ComponentsProvider_1 = __importDefault(require("@steroidsjs/core/providers/ComponentsProvider"));
12
+ exports.ComponentsProvider = ComponentsProvider_1["default"];
@@ -4,6 +4,7 @@
4
4
  * @param action
5
5
  */
6
6
  export declare function reducerItem(state: any, action: any): any;
7
- declare const _default: (state: {}, action: any) => {};
7
+ declare const _default: (state: {}, action: any) => any;
8
8
  export default _default;
9
9
  export declare const formSelector: (state: any, formId: any, selector: any) => any;
10
+ export declare const getFormValues: (state: any, formId: any) => any;
package/reducers/form.js CHANGED
@@ -14,7 +14,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
14
14
  return (mod && mod.__esModule) ? mod : { "default": mod };
15
15
  };
16
16
  exports.__esModule = true;
17
- exports.formSelector = exports.reducerItem = void 0;
17
+ exports.getFormValues = exports.formSelector = exports.reducerItem = void 0;
18
18
  var get_1 = __importDefault(require("lodash-es/get"));
19
19
  var cloneDeep_1 = __importDefault(require("lodash-es/cloneDeep"));
20
20
  var dot_prop_immutable_1 = require("dot-prop-immutable");
@@ -38,6 +38,8 @@ function reducerItem(state, action) {
38
38
  return dot_prop_immutable_1.set(state, 'values.' + action.name, action.value);
39
39
  case form_1.FORM_SET_ERRORS:
40
40
  return dot_prop_immutable_1.set(state, 'errors', action.errors);
41
+ case form_1.FORM_SUBMIT:
42
+ return dot_prop_immutable_1.set(state, 'submitCounter', (state.submitCounter || 0) + 1);
41
43
  case form_1.FORM_RESET:
42
44
  return dot_prop_immutable_1.set(state, 'values', cloneDeep_1["default"](state.initialValues || {}));
43
45
  case form_1.FORM_ARRAY_ADD:
@@ -58,9 +60,11 @@ var initialState = {};
58
60
  exports["default"] = (function (state, action) {
59
61
  if (state === void 0) { state = initialState; }
60
62
  if (action.formId) {
61
- state[action.formId] = reducerItem(state[action.formId], action);
63
+ return dot_prop_immutable_1.set(state, action.formId, reducerItem(state[action.formId], action));
62
64
  }
63
65
  return state;
64
66
  });
65
67
  var formSelector = function (state, formId, selector) { var _a; return selector(((_a = state.form) === null || _a === void 0 ? void 0 : _a[formId]) || {}); };
66
68
  exports.formSelector = formSelector;
69
+ var getFormValues = function (state, formId) { var _a, _b; return ((_b = (_a = state.form) === null || _a === void 0 ? void 0 : _a[formId]) === null || _b === void 0 ? void 0 : _b.values) || null; };
70
+ exports.getFormValues = getFormValues;
package/reducers/index.js CHANGED
@@ -38,4 +38,4 @@ exports["default"] = (function (asyncReducers) { return redux_1.combineReducers(
38
38
  list: list_1["default"],
39
39
  notifications: notifications_1["default"],
40
40
  modal: modal_1["default"],
41
- screen: screen_1["default"] }, asyncReducers), { router: function (state, action) { return router_1["default"](asyncReducers.router(state, action), action); } })); });
41
+ screen: screen_1["default"] }, asyncReducers), { router: function (state, action) { return router_1["default"](asyncReducers.router ? asyncReducers.router(state, action) : {}, action); } })); });
package/reducers/list.js CHANGED
@@ -32,9 +32,7 @@ var reducerMap = (_a = {},
32
32
  },
33
33
  _a[list_1.LIST_SET_ITEMS] = function (state, action) {
34
34
  var _a;
35
- return (__assign(__assign({}, state), { lists: __assign(__assign({}, state.lists), (_a = {}, _a[action.listId] = {
36
- items: action.items
37
- }, _a)) }));
35
+ return (__assign(__assign({}, state), { lists: __assign(__assign({}, state.lists), (_a = {}, _a[action.listId] = __assign(__assign({}, state.lists[action.listId]), { items: action.items }), _a)) }));
38
36
  },
39
37
  _a[list_1.LIST_BEFORE_FETCH] = function (state, action) {
40
38
  var _a;