@lowdefy/blocks-antd 4.7.2 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (356) hide show
  1. package/dist/blocks/Affix/Affix.js +6 -12
  2. package/dist/blocks/Affix/{schema.js → meta.js} +23 -14
  3. package/dist/blocks/Alert/Alert.js +17 -12
  4. package/dist/blocks/Alert/e2e.js +1 -1
  5. package/dist/blocks/Alert/meta.js +186 -0
  6. package/dist/blocks/AutoComplete/AutoComplete.js +15 -22
  7. package/dist/blocks/AutoComplete/meta.js +265 -0
  8. package/dist/blocks/Avatar/Avatar.js +58 -18
  9. package/dist/blocks/Avatar/meta.js +277 -0
  10. package/dist/blocks/Badge/Badge.js +13 -12
  11. package/dist/blocks/Badge/{schema.js → meta.js} +80 -1
  12. package/dist/blocks/Breadcrumb/Breadcrumb.js +40 -41
  13. package/dist/blocks/Breadcrumb/meta.js +90 -0
  14. package/dist/blocks/Button/Button.js +77 -39
  15. package/dist/blocks/Button/meta.js +230 -0
  16. package/dist/blocks/ButtonSelector/ButtonSelector.js +54 -59
  17. package/dist/blocks/ButtonSelector/meta.js +213 -0
  18. package/dist/blocks/Calendar/Calendar.js +111 -0
  19. package/dist/blocks/Calendar/e2e.js +27 -0
  20. package/dist/blocks/Calendar/meta.js +148 -0
  21. package/dist/blocks/Card/Card.js +22 -21
  22. package/dist/blocks/Card/meta.js +170 -0
  23. package/dist/blocks/Carousel/Carousel.js +6 -12
  24. package/dist/blocks/Carousel/{schema.js → meta.js} +61 -22
  25. package/dist/blocks/CheckboxSelector/CheckboxSelector.js +58 -64
  26. package/dist/blocks/CheckboxSelector/meta.js +150 -0
  27. package/dist/blocks/CheckboxSwitch/CheckboxSwitch.js +38 -44
  28. package/dist/blocks/CheckboxSwitch/meta.js +183 -0
  29. package/dist/blocks/Collapse/Collapse.js +21 -12
  30. package/dist/blocks/Collapse/meta.js +179 -0
  31. package/dist/blocks/ColorSelector/ColorSelector.js +97 -0
  32. package/dist/blocks/ColorSelector/e2e.js +32 -0
  33. package/dist/blocks/ColorSelector/meta.js +250 -0
  34. package/dist/blocks/ConfigProvider/ConfigProvider.js +51 -0
  35. package/dist/blocks/{Alert/style.less → ConfigProvider/e2e.js} +5 -3
  36. package/dist/blocks/{ControlledList/schema.js → ConfigProvider/meta.js} +43 -45
  37. package/dist/blocks/ConfirmModal/ConfirmModal.js +45 -25
  38. package/dist/blocks/ConfirmModal/{schema.js → meta.js} +93 -35
  39. package/dist/blocks/Content/Content.js +5 -12
  40. package/dist/blocks/{Layout/schema.js → Content/meta.js} +11 -3
  41. package/dist/blocks/ControlledList/ControlledList.js +42 -54
  42. package/dist/blocks/ControlledList/meta.js +158 -0
  43. package/dist/blocks/DateRangeSelector/DateRangeSelector.js +31 -29
  44. package/dist/blocks/DateRangeSelector/meta.js +297 -0
  45. package/dist/blocks/DateSelector/DateSelector.js +28 -28
  46. package/dist/blocks/DateSelector/meta.js +241 -0
  47. package/dist/blocks/DateTimeSelector/DateTimeSelector.js +28 -28
  48. package/dist/blocks/DateTimeSelector/meta.js +282 -0
  49. package/dist/blocks/Descriptions/Descriptions.js +20 -22
  50. package/dist/blocks/Descriptions/{schema.js → meta.js} +71 -15
  51. package/dist/blocks/Divider/Divider.js +8 -14
  52. package/dist/blocks/Divider/meta.js +86 -0
  53. package/dist/blocks/Drawer/Drawer.js +21 -16
  54. package/dist/blocks/Drawer/{schema.js → meta.js} +61 -61
  55. package/dist/blocks/DropdownButton/DropdownButton.js +221 -0
  56. package/dist/blocks/DropdownButton/e2e.js +30 -0
  57. package/dist/blocks/DropdownButton/meta.js +317 -0
  58. package/dist/blocks/DropdownMenu/DropdownMenu.js +130 -0
  59. package/dist/blocks/DropdownMenu/e2e.js +28 -0
  60. package/dist/blocks/DropdownMenu/meta.js +322 -0
  61. package/dist/blocks/Flex/Flex.js +31 -0
  62. package/dist/blocks/{Comment → Flex}/e2e.js +1 -2
  63. package/dist/blocks/Flex/meta.js +115 -0
  64. package/dist/blocks/FloatButton/FloatButton.js +46 -0
  65. package/dist/blocks/FloatButton/e2e.js +28 -0
  66. package/dist/blocks/FloatButton/meta.js +156 -0
  67. package/dist/blocks/Footer/Footer.js +8 -17
  68. package/dist/blocks/{Header/schema.js → Footer/meta.js} +11 -12
  69. package/dist/blocks/Header/Header.js +38 -18
  70. package/dist/blocks/Header/meta.js +318 -0
  71. package/dist/blocks/Label/Label.js +19 -27
  72. package/dist/blocks/Label/labelLogic.js +37 -41
  73. package/dist/blocks/Label/meta.js +148 -0
  74. package/dist/blocks/Label/style.module.css +185 -0
  75. package/dist/blocks/Layout/Layout.js +10 -13
  76. package/dist/blocks/{Content/schema.js → Layout/meta.js} +11 -3
  77. package/dist/blocks/Masonry/Masonry.js +37 -0
  78. package/dist/blocks/{Affix/style.less → Masonry/e2e.js} +9 -3
  79. package/dist/blocks/Masonry/meta.js +86 -0
  80. package/dist/blocks/MasonryList/MasonryList.js +42 -0
  81. package/dist/blocks/{AutoComplete/style.less → MasonryList/e2e.js} +9 -3
  82. package/dist/blocks/MasonryList/meta.js +86 -0
  83. package/dist/blocks/Menu/Menu.js +148 -122
  84. package/dist/blocks/Menu/meta.js +544 -0
  85. package/dist/blocks/Message/Message.js +18 -16
  86. package/dist/blocks/Message/{schema.js → meta.js} +29 -14
  87. package/dist/blocks/MobileMenu/MobileMenu.js +13 -21
  88. package/dist/blocks/MobileMenu/{schema.js → meta.js} +17 -31
  89. package/dist/blocks/Modal/Modal.js +20 -16
  90. package/dist/blocks/Modal/meta.js +234 -0
  91. package/dist/blocks/MonthSelector/MonthSelector.js +30 -30
  92. package/dist/blocks/MonthSelector/meta.js +260 -0
  93. package/dist/blocks/MultipleSelector/MultipleSelector.js +49 -36
  94. package/dist/blocks/MultipleSelector/{schema.js → meta.js} +177 -151
  95. package/dist/blocks/Notification/Notification.js +39 -23
  96. package/dist/blocks/Notification/{schema.js → meta.js} +36 -22
  97. package/dist/blocks/NumberInput/NumberInput.js +12 -21
  98. package/dist/blocks/NumberInput/meta.js +250 -0
  99. package/dist/blocks/PageHeaderMenu/PageHeaderMenu.js +137 -189
  100. package/dist/blocks/PageHeaderMenu/meta.js +420 -0
  101. package/dist/blocks/PageSiderMenu/PageSiderMenu.js +151 -192
  102. package/dist/blocks/PageSiderMenu/meta.js +476 -0
  103. package/dist/blocks/Pagination/Pagination.js +6 -15
  104. package/dist/blocks/Pagination/meta.js +233 -0
  105. package/dist/blocks/Paragraph/Paragraph.js +28 -16
  106. package/dist/blocks/Paragraph/{schema.js → meta.js} +68 -18
  107. package/dist/blocks/ParagraphInput/ParagraphInput.js +34 -17
  108. package/dist/blocks/ParagraphInput/{schema.js → meta.js} +134 -18
  109. package/dist/blocks/PasswordInput/PasswordInput.js +9 -16
  110. package/dist/blocks/PasswordInput/meta.js +195 -0
  111. package/dist/blocks/PhoneNumberInput/PhoneNumberInput.js +37 -33
  112. package/dist/blocks/PhoneNumberInput/formatPhoneNumber.js +25 -0
  113. package/dist/blocks/PhoneNumberInput/meta.js +225 -0
  114. package/dist/blocks/PhoneNumberInput/upstream-formatting-spec.md +173 -0
  115. package/dist/blocks/Popover/Popover.js +7 -12
  116. package/dist/blocks/Popover/{schema.js → meta.js} +81 -11
  117. package/dist/blocks/Progress/Progress.js +7 -12
  118. package/dist/blocks/Progress/{schema.js → meta.js} +74 -4
  119. package/dist/blocks/QRCode/QRCode.js +39 -0
  120. package/dist/blocks/{Footer/schema.js → QRCode/e2e.js} +9 -15
  121. package/dist/blocks/QRCode/meta.js +152 -0
  122. package/dist/blocks/RadioSelector/RadioSelector.js +55 -63
  123. package/dist/blocks/RadioSelector/meta.js +179 -0
  124. package/dist/blocks/RatingSlider/RatingSlider.js +95 -103
  125. package/dist/blocks/RatingSlider/meta.js +221 -0
  126. package/dist/blocks/Result/Result.js +13 -12
  127. package/dist/blocks/Result/meta.js +129 -0
  128. package/dist/blocks/Search/Search.js +135 -0
  129. package/dist/blocks/Search/SearchHighlight.js +33 -0
  130. package/dist/blocks/Search/SearchModal.js +171 -0
  131. package/dist/blocks/Search/SearchResults.js +129 -0
  132. package/dist/blocks/Search/meta.js +258 -0
  133. package/dist/blocks/Search/style.module.css +96 -0
  134. package/dist/blocks/Search/useListKeyboardNav.js +45 -0
  135. package/dist/blocks/Search/useRecentSearches.js +77 -0
  136. package/dist/blocks/Search/useSearchIndex.js +144 -0
  137. package/dist/blocks/SegmentedSelector/SegmentedSelector.js +93 -0
  138. package/dist/blocks/SegmentedSelector/e2e.js +32 -0
  139. package/dist/blocks/SegmentedSelector/meta.js +222 -0
  140. package/dist/blocks/Selector/Selector.js +35 -30
  141. package/dist/blocks/Selector/meta.js +379 -0
  142. package/dist/blocks/Sider/Sider.js +9 -18
  143. package/dist/blocks/Sider/{schema.js → meta.js} +20 -34
  144. package/dist/blocks/Slider/Slider.js +8 -20
  145. package/dist/blocks/Slider/meta.js +226 -0
  146. package/dist/blocks/Splitter/Splitter.js +70 -0
  147. package/dist/blocks/Splitter/e2e.js +24 -0
  148. package/dist/blocks/Splitter/meta.js +193 -0
  149. package/dist/blocks/Statistic/Statistic.js +26 -15
  150. package/dist/blocks/Statistic/{schema.js → meta.js} +41 -4
  151. package/dist/blocks/Steps/Steps.js +94 -0
  152. package/dist/blocks/Steps/e2e.js +31 -0
  153. package/dist/blocks/Steps/meta.js +246 -0
  154. package/dist/blocks/Switch/Switch.js +59 -54
  155. package/dist/blocks/Switch/meta.js +178 -0
  156. package/dist/blocks/Tabs/Tabs.js +49 -18
  157. package/dist/blocks/Tabs/meta.js +258 -0
  158. package/dist/blocks/Tag/Tag.js +17 -15
  159. package/dist/blocks/Tag/{schema.js → meta.js} +35 -13
  160. package/dist/blocks/TextArea/TextArea.js +10 -16
  161. package/dist/blocks/TextArea/meta.js +255 -0
  162. package/dist/blocks/TextInput/TextInput.js +23 -18
  163. package/dist/blocks/TextInput/meta.js +286 -0
  164. package/dist/blocks/TimelineList/TimelineList.js +29 -27
  165. package/dist/blocks/TimelineList/{schema.js → meta.js} +45 -8
  166. package/dist/blocks/Title/Title.js +34 -21
  167. package/dist/blocks/Title/{schema.js → meta.js} +117 -14
  168. package/dist/blocks/TitleInput/TitleInput.js +43 -25
  169. package/dist/blocks/TitleInput/{schema.js → meta.js} +156 -18
  170. package/dist/blocks/Tooltip/Tooltip.js +16 -16
  171. package/dist/blocks/Tooltip/{schema.js → meta.js} +74 -19
  172. package/dist/blocks/Tour/Tour.js +75 -0
  173. package/dist/blocks/Tour/e2e.js +31 -0
  174. package/dist/blocks/Tour/meta.js +255 -0
  175. package/dist/blocks/TreeSelector/TreeSelector.js +6 -12
  176. package/dist/blocks/TreeSelector/{schema.js → meta.js} +134 -25
  177. package/dist/blocks/Watermark/Watermark.js +34 -0
  178. package/dist/blocks/Watermark/e2e.js +23 -0
  179. package/dist/blocks/Watermark/meta.js +148 -0
  180. package/dist/blocks/WeekSelector/WeekSelector.js +35 -31
  181. package/dist/blocks/WeekSelector/meta.js +269 -0
  182. package/dist/blocks/buildMenuItems.js +95 -0
  183. package/dist/blocks/headerActions.js +220 -0
  184. package/dist/blocks/useItemShortcuts.js +64 -0
  185. package/dist/blocks/withTheme.js +40 -0
  186. package/dist/blocks.js +16 -1
  187. package/dist/disabledDate.js +15 -7
  188. package/dist/e2e.js +4 -1
  189. package/dist/metas.js +91 -0
  190. package/dist/schemas/breadcrumbList.js +64 -0
  191. package/dist/schemas/disabledDates.js +83 -0
  192. package/dist/{blocks/Avatar/style.less → schemas/icon.js} +10 -3
  193. package/dist/schemas/index.js +21 -0
  194. package/dist/schemas/inputProperties.js +70 -0
  195. package/dist/schemas/label.js +62 -0
  196. package/dist/schemas/menuLinks.js +49 -0
  197. package/dist/schemas/options.js +84 -0
  198. package/dist/types.js +4 -18
  199. package/package.json +19 -17
  200. package/dist/blocks/Affix/schema.json +0 -34
  201. package/dist/blocks/Alert/schema.js +0 -84
  202. package/dist/blocks/Alert/schema.json +0 -62
  203. package/dist/blocks/AutoComplete/schema.js +0 -181
  204. package/dist/blocks/AutoComplete/schema.json +0 -160
  205. package/dist/blocks/Avatar/schema.js +0 -98
  206. package/dist/blocks/Avatar/schema.json +0 -71
  207. package/dist/blocks/Badge/schema.json +0 -70
  208. package/dist/blocks/Badge/style.less +0 -17
  209. package/dist/blocks/Breadcrumb/schema.js +0 -95
  210. package/dist/blocks/Breadcrumb/schema.json +0 -78
  211. package/dist/blocks/Breadcrumb/style.less +0 -17
  212. package/dist/blocks/Button/schema.js +0 -123
  213. package/dist/blocks/Button/schema.json +0 -91
  214. package/dist/blocks/Button/style.less +0 -17
  215. package/dist/blocks/ButtonSelector/schema.js +0 -214
  216. package/dist/blocks/ButtonSelector/schema.json +0 -188
  217. package/dist/blocks/ButtonSelector/style.less +0 -18
  218. package/dist/blocks/Card/schema.js +0 -75
  219. package/dist/blocks/Card/schema.json +0 -58
  220. package/dist/blocks/Card/style.less +0 -17
  221. package/dist/blocks/Carousel/schema.json +0 -183
  222. package/dist/blocks/Carousel/style.less +0 -17
  223. package/dist/blocks/CheckboxSelector/schema.js +0 -220
  224. package/dist/blocks/CheckboxSelector/schema.json +0 -193
  225. package/dist/blocks/CheckboxSelector/style.less +0 -19
  226. package/dist/blocks/CheckboxSwitch/schema.js +0 -122
  227. package/dist/blocks/CheckboxSwitch/schema.json +0 -105
  228. package/dist/blocks/CheckboxSwitch/style.less +0 -19
  229. package/dist/blocks/Collapse/schema.js +0 -110
  230. package/dist/blocks/Collapse/schema.json +0 -90
  231. package/dist/blocks/Collapse/style.less +0 -17
  232. package/dist/blocks/Comment/Comment.js +0 -56
  233. package/dist/blocks/Comment/schema.js +0 -56
  234. package/dist/blocks/Comment/schema.json +0 -39
  235. package/dist/blocks/Comment/style.less +0 -18
  236. package/dist/blocks/ConfirmModal/schema.json +0 -122
  237. package/dist/blocks/ConfirmModal/style.less +0 -17
  238. package/dist/blocks/Content/schema.json +0 -16
  239. package/dist/blocks/Content/style.less +0 -17
  240. package/dist/blocks/ControlledList/schema.json +0 -73
  241. package/dist/blocks/ControlledList/style.less +0 -19
  242. package/dist/blocks/DateRangeSelector/schema.js +0 -266
  243. package/dist/blocks/DateRangeSelector/schema.json +0 -221
  244. package/dist/blocks/DateRangeSelector/style.less +0 -18
  245. package/dist/blocks/DateSelector/schema.js +0 -219
  246. package/dist/blocks/DateSelector/schema.json +0 -183
  247. package/dist/blocks/DateSelector/style.less +0 -18
  248. package/dist/blocks/DateTimeSelector/schema.js +0 -251
  249. package/dist/blocks/DateTimeSelector/schema.json +0 -215
  250. package/dist/blocks/DateTimeSelector/style.less +0 -18
  251. package/dist/blocks/Descriptions/schema.json +0 -186
  252. package/dist/blocks/Descriptions/style.less +0 -17
  253. package/dist/blocks/Divider/schema.js +0 -56
  254. package/dist/blocks/Divider/schema.json +0 -35
  255. package/dist/blocks/Divider/style.less +0 -17
  256. package/dist/blocks/Drawer/schema.json +0 -121
  257. package/dist/blocks/Drawer/style.less +0 -17
  258. package/dist/blocks/Footer/schema.json +0 -16
  259. package/dist/blocks/Footer/style.less +0 -17
  260. package/dist/blocks/Header/schema.json +0 -22
  261. package/dist/blocks/Header/style.less +0 -17
  262. package/dist/blocks/Label/schema.js +0 -83
  263. package/dist/blocks/Label/schema.json +0 -62
  264. package/dist/blocks/Label/style.less +0 -34
  265. package/dist/blocks/Layout/schema.json +0 -16
  266. package/dist/blocks/Layout/style.less +0 -17
  267. package/dist/blocks/Menu/schema.js +0 -283
  268. package/dist/blocks/Menu/schema.json +0 -236
  269. package/dist/blocks/Menu/style.less +0 -17
  270. package/dist/blocks/Message/schema.json +0 -48
  271. package/dist/blocks/Message/style.less +0 -17
  272. package/dist/blocks/MobileMenu/schema.json +0 -236
  273. package/dist/blocks/MobileMenu/style.less +0 -19
  274. package/dist/blocks/Modal/schema.js +0 -142
  275. package/dist/blocks/Modal/schema.json +0 -125
  276. package/dist/blocks/Modal/style.less +0 -17
  277. package/dist/blocks/MonthSelector/schema.js +0 -219
  278. package/dist/blocks/MonthSelector/schema.json +0 -183
  279. package/dist/blocks/MonthSelector/style.less +0 -18
  280. package/dist/blocks/MultipleSelector/schema.json +0 -297
  281. package/dist/blocks/MultipleSelector/style.less +0 -19
  282. package/dist/blocks/Notification/schema.json +0 -85
  283. package/dist/blocks/Notification/style.less +0 -18
  284. package/dist/blocks/NumberInput/schema.js +0 -193
  285. package/dist/blocks/NumberInput/schema.json +0 -172
  286. package/dist/blocks/NumberInput/style.less +0 -18
  287. package/dist/blocks/PageHeaderMenu/schema.js +0 -241
  288. package/dist/blocks/PageHeaderMenu/schema.json +0 -215
  289. package/dist/blocks/PageHeaderMenu/style.less +0 -23
  290. package/dist/blocks/PageSiderMenu/schema.js +0 -321
  291. package/dist/blocks/PageSiderMenu/schema.json +0 -283
  292. package/dist/blocks/PageSiderMenu/style.less +0 -26
  293. package/dist/blocks/Pagination/schema.js +0 -101
  294. package/dist/blocks/Pagination/schema.json +0 -75
  295. package/dist/blocks/Pagination/style.less +0 -17
  296. package/dist/blocks/Paragraph/schema.json +0 -135
  297. package/dist/blocks/Paragraph/style.less +0 -18
  298. package/dist/blocks/ParagraphInput/schema.json +0 -162
  299. package/dist/blocks/ParagraphInput/style.less +0 -17
  300. package/dist/blocks/PasswordInput/schema.js +0 -152
  301. package/dist/blocks/PasswordInput/schema.json +0 -131
  302. package/dist/blocks/PasswordInput/style.less +0 -18
  303. package/dist/blocks/PhoneNumberInput/schema.js +0 -243
  304. package/dist/blocks/PhoneNumberInput/schema.json +0 -216
  305. package/dist/blocks/PhoneNumberInput/style.less +0 -33
  306. package/dist/blocks/Popover/schema.json +0 -86
  307. package/dist/blocks/Popover/style.less +0 -17
  308. package/dist/blocks/Progress/schema.json +0 -76
  309. package/dist/blocks/Progress/style.less +0 -17
  310. package/dist/blocks/RadioSelector/schema.js +0 -217
  311. package/dist/blocks/RadioSelector/schema.json +0 -190
  312. package/dist/blocks/RadioSelector/style.less +0 -19
  313. package/dist/blocks/RatingSlider/schema.js +0 -196
  314. package/dist/blocks/RatingSlider/schema.json +0 -169
  315. package/dist/blocks/RatingSlider/style.less +0 -19
  316. package/dist/blocks/Result/schema.js +0 -55
  317. package/dist/blocks/Result/schema.json +0 -30
  318. package/dist/blocks/Result/style.less +0 -17
  319. package/dist/blocks/Selector/schema.js +0 -287
  320. package/dist/blocks/Selector/schema.json +0 -258
  321. package/dist/blocks/Selector/style.less +0 -18
  322. package/dist/blocks/Sider/schema.json +0 -71
  323. package/dist/blocks/Sider/style.less +0 -17
  324. package/dist/blocks/Slider/style.less +0 -18
  325. package/dist/blocks/Statistic/schema.json +0 -74
  326. package/dist/blocks/Statistic/style.less +0 -17
  327. package/dist/blocks/Switch/schema.js +0 -162
  328. package/dist/blocks/Switch/schema.json +0 -136
  329. package/dist/blocks/Switch/style.less +0 -18
  330. package/dist/blocks/Tabs/schema.js +0 -124
  331. package/dist/blocks/Tabs/schema.json +0 -93
  332. package/dist/blocks/Tabs/style.less +0 -17
  333. package/dist/blocks/Tag/schema.json +0 -45
  334. package/dist/blocks/Tag/style.less +0 -17
  335. package/dist/blocks/TextArea/schema.js +0 -196
  336. package/dist/blocks/TextArea/schema.json +0 -172
  337. package/dist/blocks/TextArea/style.less +0 -18
  338. package/dist/blocks/TextInput/schema.js +0 -223
  339. package/dist/blocks/TextInput/schema.json +0 -189
  340. package/dist/blocks/TextInput/style.less +0 -18
  341. package/dist/blocks/TimelineList/schema.json +0 -65
  342. package/dist/blocks/TimelineList/style.less +0 -17
  343. package/dist/blocks/Title/schema.json +0 -136
  344. package/dist/blocks/Title/style.less +0 -18
  345. package/dist/blocks/TitleInput/schema.json +0 -171
  346. package/dist/blocks/TitleInput/style.less +0 -17
  347. package/dist/blocks/Tooltip/schema.json +0 -91
  348. package/dist/blocks/Tooltip/style.less +0 -17
  349. package/dist/blocks/TreeSelector/schema.json +0 -166
  350. package/dist/blocks/TreeSelector/style.less +0 -27
  351. package/dist/blocks/WeekSelector/schema.js +0 -219
  352. package/dist/blocks/WeekSelector/schema.json +0 -183
  353. package/dist/blocks/WeekSelector/style.less +0 -18
  354. package/dist/color.js +0 -85
  355. package/dist/schemas.js +0 -75
  356. package/dist/style.less +0 -17
@@ -0,0 +1,90 @@
1
+ /*
2
+ Copyright 2020-2026 Lowdefy, Inc
3
+
4
+ Licensed under the Apache License, Version 2.0 (the "License");
5
+ you may not use this file except in compliance with the License.
6
+ You may obtain a copy of the License at
7
+
8
+ http://www.apache.org/licenses/LICENSE-2.0
9
+
10
+ Unless required by applicable law or agreed to in writing, software
11
+ distributed under the License is distributed on an "AS IS" BASIS,
12
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ See the License for the specific language governing permissions and
14
+ limitations under the License.
15
+ */ import breadcrumbList from '../../schemas/breadcrumbList.js';
16
+ export default {
17
+ category: 'display',
18
+ icons: [],
19
+ valueType: null,
20
+ cssKeys: {
21
+ element: 'The Breadcrumb element.',
22
+ icon: 'The icon in the Breadcrumb.'
23
+ },
24
+ events: {
25
+ onClick: {
26
+ description: 'Triggered when breadcrumb item is clicked.',
27
+ event: {
28
+ link: 'The clicked breadcrumb link.',
29
+ index: 'The index of the clicked item.'
30
+ }
31
+ }
32
+ },
33
+ properties: {
34
+ type: 'object',
35
+ additionalProperties: false,
36
+ properties: {
37
+ separator: {
38
+ type: 'string',
39
+ default: '/',
40
+ description: 'Use a custom separator string.'
41
+ },
42
+ list: breadcrumbList,
43
+ theme: {
44
+ type: 'object',
45
+ description: 'Antd design token overrides for this block. See <a href="https://ant.design/components/overview#design-token">antd design tokens</a>.',
46
+ docs: {
47
+ displayType: 'yaml',
48
+ link: 'https://ant.design/components/breadcrumb#design-token'
49
+ },
50
+ properties: {
51
+ itemColor: {
52
+ type: 'string',
53
+ default: 'rgba(0, 0, 0, 0.45)',
54
+ description: 'Text color of breadcrumb item.'
55
+ },
56
+ iconFontSize: {
57
+ type: 'number',
58
+ default: 14,
59
+ description: 'Icon size of breadcrumb item.'
60
+ },
61
+ linkColor: {
62
+ type: 'string',
63
+ default: 'rgba(0, 0, 0, 0.45)',
64
+ description: 'Text color of link.'
65
+ },
66
+ linkHoverColor: {
67
+ type: 'string',
68
+ default: 'rgba(0, 0, 0, 0.88)',
69
+ description: 'Color of hovered link.'
70
+ },
71
+ lastItemColor: {
72
+ type: 'string',
73
+ default: 'rgba(0, 0, 0, 0.88)',
74
+ description: 'Text color of the last item.'
75
+ },
76
+ separatorMargin: {
77
+ type: 'number',
78
+ default: 8,
79
+ description: 'Margin of separator.'
80
+ },
81
+ separatorColor: {
82
+ type: 'string',
83
+ default: 'rgba(0, 0, 0, 0.45)',
84
+ description: 'Color of separator.'
85
+ }
86
+ }
87
+ }
88
+ }
89
+ }
90
+ };
@@ -13,35 +13,66 @@
13
13
  See the License for the specific language governing permissions and
14
14
  limitations under the License.
15
15
  */ import React from 'react';
16
- import { Button } from 'antd';
16
+ import { Button, ConfigProvider } from 'antd';
17
17
  import { get, type } from '@lowdefy/helpers';
18
- import { blockDefaultProps, renderHtml } from '@lowdefy/block-utils';
19
- import color from '../../color.js';
20
- const ButtonBlock = ({ blockId, components: { Icon }, events, loading, methods, onClick, properties, rename })=>{
18
+ import { renderHtml, withBlockDefaults } from '@lowdefy/block-utils';
19
+ import withTheme from '../withTheme.js';
20
+ const ANTD_COLOR_PRESETS = new Set([
21
+ 'default',
22
+ 'primary',
23
+ 'danger',
24
+ 'blue',
25
+ 'purple',
26
+ 'cyan',
27
+ 'green',
28
+ 'magenta',
29
+ 'pink',
30
+ 'red',
31
+ 'orange',
32
+ 'yellow',
33
+ 'volcano',
34
+ 'geekblue',
35
+ 'lime',
36
+ 'gold'
37
+ ]);
38
+ function getButtonProps(properties) {
39
+ if (properties.variant) {
40
+ return {
41
+ color: properties.color,
42
+ variant: properties.variant
43
+ };
44
+ }
45
+ const buttonType = properties.type ?? 'primary';
46
+ if (buttonType === 'danger') {
47
+ return {
48
+ color: 'danger',
49
+ variant: 'solid'
50
+ };
51
+ }
52
+ return {
53
+ type: buttonType
54
+ };
55
+ }
56
+ const ButtonBlock = ({ blockId, classNames = {}, components: { Icon, ShortcutBadge }, events, loading, methods, onClick, properties, rename, styles = {} })=>{
21
57
  const onClickActionName = get(rename, 'events.onClick', {
22
58
  default: 'onClick'
23
59
  });
24
- return /*#__PURE__*/ React.createElement(Button, {
60
+ const { color: buttonColor, variant, type: buttonType } = getButtonProps(properties);
61
+ const isPresetColor = ANTD_COLOR_PRESETS.has(properties.color);
62
+ const resolvedColor = isPresetColor ? buttonColor : properties.color ? 'primary' : buttonColor;
63
+ const button = /*#__PURE__*/ React.createElement(Button, {
25
64
  block: properties.block,
26
- className: methods.makeCssClass([
27
- {
28
- backgroundColor: properties.color,
29
- borderColor: properties.color,
30
- '&:active': properties.color && {
31
- backgroundColor: color(properties.color, 7),
32
- borderColor: color(properties.color, 7)
33
- },
34
- '&:hover': properties.color && {
35
- backgroundColor: color(properties.color, 5),
36
- borderColor: color(properties.color, 5)
37
- },
38
- '&:focus': properties.color && {
39
- backgroundColor: properties.color,
40
- borderColor: properties.color
41
- }
42
- },
43
- properties.style
44
- ]),
65
+ className: classNames.element,
66
+ style: styles.element,
67
+ classNames: {
68
+ icon: classNames.icon
69
+ },
70
+ styles: {
71
+ icon: styles.icon
72
+ },
73
+ color: resolvedColor,
74
+ variant: variant,
75
+ type: buttonType,
45
76
  disabled: properties.disabled || get(events, `${onClickActionName}.loading`) || loading,
46
77
  ghost: properties.ghost,
47
78
  danger: properties.danger,
@@ -50,28 +81,35 @@ const ButtonBlock = ({ blockId, components: { Icon }, events, loading, methods,
50
81
  loading: get(events, `${onClickActionName}.loading`),
51
82
  shape: properties.shape,
52
83
  size: properties.size,
53
- type: get(properties, 'type', {
54
- default: 'primary'
55
- }),
56
84
  icon: properties.icon && /*#__PURE__*/ React.createElement(Icon, {
57
85
  blockId: `${blockId}_icon`,
86
+ classNames: {
87
+ element: classNames.icon
88
+ },
58
89
  events: events,
59
- properties: properties.icon
90
+ properties: properties.icon,
91
+ styles: {
92
+ element: styles.icon
93
+ }
60
94
  }),
61
95
  onClick: onClick || (()=>methods.triggerEvent({
62
96
  name: onClickActionName
63
97
  }))
64
- }, !properties.hideTitle && renderHtml({
98
+ }, !properties.hideTitle && !(properties.shape === 'circle' && type.isNone(properties.title)) && /*#__PURE__*/ React.createElement(React.Fragment, null, renderHtml({
65
99
  html: type.isNone(properties.title) ? blockId : properties.title,
66
100
  methods
67
- }));
68
- };
69
- ButtonBlock.defaultProps = blockDefaultProps;
70
- ButtonBlock.meta = {
71
- category: 'display',
72
- icons: [],
73
- styles: [
74
- 'blocks/Button/style.less'
75
- ]
101
+ }), /*#__PURE__*/ React.createElement(ShortcutBadge, {
102
+ shortcut: events[onClickActionName]?.shortcut
103
+ })));
104
+ if (properties.color && !isPresetColor) {
105
+ return /*#__PURE__*/ React.createElement(ConfigProvider, {
106
+ theme: {
107
+ token: {
108
+ colorPrimary: properties.color
109
+ }
110
+ }
111
+ }, button);
112
+ }
113
+ return button;
76
114
  };
77
- export default ButtonBlock;
115
+ export default withTheme('Button', withBlockDefaults(ButtonBlock));
@@ -0,0 +1,230 @@
1
+ /*
2
+ Copyright 2020-2026 Lowdefy, Inc
3
+
4
+ Licensed under the Apache License, Version 2.0 (the "License");
5
+ you may not use this file except in compliance with the License.
6
+ You may obtain a copy of the License at
7
+
8
+ http://www.apache.org/licenses/LICENSE-2.0
9
+
10
+ Unless required by applicable law or agreed to in writing, software
11
+ distributed under the License is distributed on an "AS IS" BASIS,
12
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ See the License for the specific language governing permissions and
14
+ limitations under the License.
15
+ */ export default {
16
+ category: 'display',
17
+ icons: [],
18
+ valueType: null,
19
+ cssKeys: {
20
+ element: 'The Button element.',
21
+ icon: 'The icon in the Button.'
22
+ },
23
+ events: {
24
+ onClick: 'Trigger action when button is clicked. Renders a shortcut badge when a shortcut is configured.'
25
+ },
26
+ properties: {
27
+ type: 'object',
28
+ additionalProperties: false,
29
+ properties: {
30
+ block: {
31
+ type: 'boolean',
32
+ description: "Fit the button's span to its parent container span.",
33
+ default: false
34
+ },
35
+ color: {
36
+ type: 'string',
37
+ description: 'Button color. Preset values: default, primary, danger, blue, purple, cyan, green, magenta, pink, red, orange, yellow, volcano, geekblue, lime, gold. Also accepts custom hex color strings.',
38
+ docs: {
39
+ displayType: 'color'
40
+ }
41
+ },
42
+ danger: {
43
+ type: 'boolean',
44
+ description: 'Set button style to danger.',
45
+ default: false
46
+ },
47
+ disabled: {
48
+ type: 'boolean',
49
+ description: 'Disable the button if true.',
50
+ default: false
51
+ },
52
+ ghost: {
53
+ type: 'boolean',
54
+ description: "Make the button's background transparent when true.",
55
+ default: false
56
+ },
57
+ hideTitle: {
58
+ type: 'boolean',
59
+ description: "Hide the button's title.",
60
+ default: false
61
+ },
62
+ href: {
63
+ type: 'string',
64
+ description: 'The URL to redirect to when the button is clicked. Useful when used with a type link button.'
65
+ },
66
+ icon: {
67
+ type: [
68
+ 'string',
69
+ 'object'
70
+ ],
71
+ description: "Name of an React-Icon (See <a href='https://react-icons.github.io/react-icons/'>all icons</a>) or properties of an Icon block to use icon in button.",
72
+ docs: {
73
+ displayType: 'icon'
74
+ }
75
+ },
76
+ shape: {
77
+ type: 'string',
78
+ default: 'square',
79
+ enum: [
80
+ 'circle',
81
+ 'round',
82
+ 'square'
83
+ ],
84
+ description: 'Shape of the button.'
85
+ },
86
+ size: {
87
+ type: 'string',
88
+ enum: [
89
+ 'small',
90
+ 'default',
91
+ 'large'
92
+ ],
93
+ default: 'default',
94
+ description: 'Size of the button.'
95
+ },
96
+ title: {
97
+ type: 'string',
98
+ description: 'Title text on the button - supports html.'
99
+ },
100
+ type: {
101
+ type: 'string',
102
+ default: 'primary',
103
+ enum: [
104
+ 'primary',
105
+ 'default',
106
+ 'dashed',
107
+ 'link',
108
+ 'text'
109
+ ],
110
+ description: 'Deprecated - use color and variant instead. The button type.'
111
+ },
112
+ variant: {
113
+ type: 'string',
114
+ enum: [
115
+ 'solid',
116
+ 'outlined',
117
+ 'dashed',
118
+ 'filled',
119
+ 'text',
120
+ 'link'
121
+ ],
122
+ description: 'Button visual variant. When set, takes precedence over type.'
123
+ },
124
+ theme: {
125
+ type: 'object',
126
+ description: 'Antd design token overrides for this block. See <a href="https://ant.design/components/overview#design-token">antd design tokens</a>.',
127
+ docs: {
128
+ displayType: 'yaml',
129
+ link: 'https://ant.design/components/button#design-token'
130
+ },
131
+ properties: {
132
+ borderRadius: {
133
+ type: 'number',
134
+ default: 6,
135
+ description: 'Border radius of the button.'
136
+ },
137
+ borderRadiusLG: {
138
+ type: 'number',
139
+ default: 8,
140
+ description: 'Border radius for large buttons.'
141
+ },
142
+ borderRadiusSM: {
143
+ type: 'number',
144
+ default: 4,
145
+ description: 'Border radius for small buttons.'
146
+ },
147
+ controlHeight: {
148
+ type: 'number',
149
+ default: 32,
150
+ description: 'Height of the button.'
151
+ },
152
+ controlHeightLG: {
153
+ type: 'number',
154
+ default: 40,
155
+ description: 'Height for large buttons.'
156
+ },
157
+ controlHeightSM: {
158
+ type: 'number',
159
+ default: 24,
160
+ description: 'Height for small buttons.'
161
+ },
162
+ fontSize: {
163
+ type: 'number',
164
+ default: 14,
165
+ description: 'Font size.'
166
+ },
167
+ fontSizeLG: {
168
+ type: 'number',
169
+ default: 16,
170
+ description: 'Font size for large buttons.'
171
+ },
172
+ fontSizeSM: {
173
+ type: 'number',
174
+ default: 14,
175
+ description: 'Font size for small buttons.'
176
+ },
177
+ lineWidth: {
178
+ type: 'number',
179
+ default: 1,
180
+ description: 'Border width.'
181
+ },
182
+ paddingInline: {
183
+ type: 'number',
184
+ default: 15,
185
+ description: 'Horizontal padding.'
186
+ },
187
+ paddingInlineLG: {
188
+ type: 'number',
189
+ default: 15,
190
+ description: 'Horizontal padding for large buttons.'
191
+ },
192
+ paddingInlineSM: {
193
+ type: 'number',
194
+ default: 7,
195
+ description: 'Horizontal padding for small buttons.'
196
+ },
197
+ paddingBlock: {
198
+ type: 'number',
199
+ default: 0,
200
+ description: 'Vertical padding.'
201
+ },
202
+ colorPrimary: {
203
+ type: 'string',
204
+ description: 'Primary color override.'
205
+ },
206
+ colorPrimaryHover: {
207
+ type: 'string',
208
+ description: 'Primary hover color.'
209
+ },
210
+ colorPrimaryActive: {
211
+ type: 'string',
212
+ description: 'Primary active color.'
213
+ },
214
+ colorBgContainer: {
215
+ type: 'string',
216
+ description: 'Background color for default buttons.'
217
+ },
218
+ colorText: {
219
+ type: 'string',
220
+ description: 'Text color for default buttons.'
221
+ },
222
+ colorBorder: {
223
+ type: 'string',
224
+ description: 'Border color for outlined and dashed buttons.'
225
+ }
226
+ }
227
+ }
228
+ }
229
+ }
230
+ };
@@ -13,16 +13,57 @@
13
13
  See the License for the specific language governing permissions and
14
14
  limitations under the License.
15
15
  */ import React from 'react';
16
- import { Radio } from 'antd';
17
- import { blockDefaultProps, renderHtml } from '@lowdefy/block-utils';
16
+ import { ConfigProvider, Radio } from 'antd';
17
+ import { renderHtml, withBlockDefaults } from '@lowdefy/block-utils';
18
18
  import { type } from '@lowdefy/helpers';
19
19
  import Label from '../Label/Label.js';
20
20
  import getValueIndex from '../../getValueIndex.js';
21
21
  import getUniqueValues from '../../getUniqueValues.js';
22
- const ButtonSelector = ({ blockId, components, events, loading, properties, required, validation, value, methods })=>{
22
+ import withTheme from '../withTheme.js';
23
+ const ButtonSelector = ({ blockId, classNames = {}, components, events, loading, properties, required, styles = {}, validation, value, methods })=>{
23
24
  const uniqueValueOptions = getUniqueValues(properties.options || []);
25
+ const radioGroup = /*#__PURE__*/ React.createElement(Radio.Group, {
26
+ id: `${blockId}_input`,
27
+ className: classNames.element,
28
+ disabled: properties.disabled || loading,
29
+ size: properties.size,
30
+ buttonStyle: properties.buttonStyle ? properties.buttonStyle : 'solid',
31
+ style: styles.element,
32
+ onChange: (event)=>{
33
+ const value = type.isPrimitive(uniqueValueOptions[event.target.value]) ? uniqueValueOptions[event.target.value] : uniqueValueOptions[event.target.value].value;
34
+ methods.setValue(value);
35
+ methods.triggerEvent({
36
+ name: 'onChange',
37
+ event: {
38
+ value
39
+ }
40
+ });
41
+ },
42
+ value: type.isNone(value) ? undefined : getValueIndex(value, properties.options || [])
43
+ }, uniqueValueOptions.map((opt, i)=>type.isPrimitive(opt) ? /*#__PURE__*/ React.createElement(Radio.Button, {
44
+ id: `${blockId}_${i}`,
45
+ key: i,
46
+ value: `${i}`,
47
+ disabled: properties.disabled || loading
48
+ }, renderHtml({
49
+ html: `${opt}`,
50
+ methods
51
+ })) : /*#__PURE__*/ React.createElement(Radio.Button, {
52
+ id: `${blockId}_${i}`,
53
+ key: i,
54
+ value: `${i}`,
55
+ disabled: opt.disabled || properties.disabled || loading,
56
+ style: opt.style
57
+ }, type.isNone(opt.label) ? renderHtml({
58
+ html: `${opt.value}`,
59
+ methods
60
+ }) : renderHtml({
61
+ html: opt.label,
62
+ methods
63
+ }))));
24
64
  return /*#__PURE__*/ React.createElement(Label, {
25
65
  blockId: blockId,
66
+ classNames: classNames,
26
67
  components: components,
27
68
  events: events,
28
69
  properties: {
@@ -32,64 +73,18 @@ const ButtonSelector = ({ blockId, components, events, loading, properties, requ
32
73
  },
33
74
  validation: validation,
34
75
  required: required,
76
+ styles: styles,
35
77
  content: {
36
- content: ()=>/*#__PURE__*/ React.createElement(Radio.Group, {
37
- id: `${blockId}_input`,
38
- className: methods.makeCssClass([
39
- properties.color && {
40
- '& > label.ant-radio-button-wrapper-checked:not(.ant-radio-button-wrapper-disabled)': {
41
- backgroundColor: `${properties.color} !important`,
42
- borderColor: `${properties.color} !important`
43
- }
44
- },
45
- properties.inputStyle
46
- ]),
47
- disabled: properties.disabled || loading,
48
- size: properties.size,
49
- buttonStyle: properties.buttonStyle ? properties.buttonStyle : 'solid',
50
- onChange: (event)=>{
51
- const value = type.isPrimitive(uniqueValueOptions[event.target.value]) ? uniqueValueOptions[event.target.value] : uniqueValueOptions[event.target.value].value;
52
- methods.setValue(value);
53
- methods.triggerEvent({
54
- name: 'onChange',
55
- event: {
56
- value
78
+ content: ()=>properties.color ? /*#__PURE__*/ React.createElement(ConfigProvider, {
79
+ theme: {
80
+ components: {
81
+ Radio: {
82
+ colorPrimary: properties.color
57
83
  }
58
- });
59
- },
60
- value: type.isNone(value) ? undefined : getValueIndex(value, properties.options || [])
61
- }, uniqueValueOptions.map((opt, i)=>type.isPrimitive(opt) ? /*#__PURE__*/ React.createElement(Radio.Button, {
62
- id: `${blockId}_${i}`,
63
- key: i,
64
- value: `${i}`
65
- }, renderHtml({
66
- html: `${opt}`,
67
- methods
68
- })) : /*#__PURE__*/ React.createElement(Radio.Button, {
69
- id: `${blockId}_${i}`,
70
- key: i,
71
- value: `${i}`,
72
- disabled: opt.disabled,
73
- className: methods.makeCssClass(opt.style)
74
- }, type.isNone(opt.label) ? renderHtml({
75
- html: `${opt.value}`,
76
- methods
77
- }) : renderHtml({
78
- html: opt.label,
79
- methods
80
- }))))
84
+ }
85
+ }
86
+ }, radioGroup) : radioGroup
81
87
  }
82
88
  });
83
89
  };
84
- ButtonSelector.defaultProps = blockDefaultProps;
85
- ButtonSelector.meta = {
86
- valueType: 'any',
87
- category: 'input',
88
- icons: [
89
- ...Label.meta.icons
90
- ],
91
- styles: [
92
- 'blocks/ButtonSelector/style.less'
93
- ]
94
- };
95
- export default ButtonSelector;
90
+ export default withTheme('Radio', withBlockDefaults(ButtonSelector));