@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,86 @@
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 Divider element.'
21
+ },
22
+ properties: {
23
+ type: 'object',
24
+ additionalProperties: false,
25
+ properties: {
26
+ dashed: {
27
+ type: 'boolean',
28
+ default: false,
29
+ description: 'Whether line is dashed.'
30
+ },
31
+ orientation: {
32
+ type: 'string',
33
+ default: 'horizontal',
34
+ enum: [
35
+ 'horizontal',
36
+ 'vertical'
37
+ ],
38
+ description: 'Direction of the divider line.'
39
+ },
40
+ title: {
41
+ type: 'string',
42
+ description: 'Divider title - supports html.'
43
+ },
44
+ titlePlacement: {
45
+ type: 'string',
46
+ default: 'center',
47
+ enum: [
48
+ 'start',
49
+ 'end',
50
+ 'center'
51
+ ],
52
+ description: 'Position of title text within the divider.'
53
+ },
54
+ plain: {
55
+ type: 'boolean',
56
+ default: false,
57
+ description: 'Show text as plain style.'
58
+ },
59
+ theme: {
60
+ type: 'object',
61
+ description: 'Antd design token overrides for this block. See <a href="https://ant.design/components/overview#design-token">antd design tokens</a>.',
62
+ docs: {
63
+ displayType: 'yaml',
64
+ link: 'https://ant.design/components/divider#design-token'
65
+ },
66
+ properties: {
67
+ textPaddingInline: {
68
+ type: 'string',
69
+ default: '1em',
70
+ description: 'Horizontal padding of text content in the divider.'
71
+ },
72
+ orientationMargin: {
73
+ type: 'number',
74
+ default: 0.05,
75
+ description: 'Distance between text and edge when orientation is left or right. Value between 0 and 1 representing a percentage.'
76
+ },
77
+ verticalMarginInline: {
78
+ type: 'number',
79
+ default: 8,
80
+ description: 'Horizontal margin for vertical dividers.'
81
+ }
82
+ }
83
+ }
84
+ }
85
+ }
86
+ };
@@ -15,7 +15,8 @@
15
15
  */ import React, { useState, useEffect } from 'react';
16
16
  import { Drawer } from 'antd';
17
17
  import { get } from '@lowdefy/helpers';
18
- import { blockDefaultProps } from '@lowdefy/block-utils';
18
+ import { withBlockDefaults } from '@lowdefy/block-utils';
19
+ import withTheme from '../withTheme.js';
19
20
  const handleClose = async ({ methods, rename, setOpen })=>{
20
21
  const response = await methods.triggerEvent({
21
22
  name: get(rename, 'events.onClose', {
@@ -87,7 +88,7 @@ const setOpenState = ({ open, methods, rename, setOpen })=>{
87
88
  });
88
89
  }
89
90
  };
90
- const DrawerBlock = ({ blockId, content, properties, methods, rename, onClose })=>{
91
+ const DrawerBlock = ({ blockId, classNames = {}, content, properties, methods, rename, onClose, styles = {} })=>{
91
92
  const [openState, setOpen] = useState(false);
92
93
  useEffect(()=>{
93
94
  methods.registerMethod(get(rename, 'methods.toggleOpen', {
@@ -131,19 +132,23 @@ const DrawerBlock = ({ blockId, content, properties, methods, rename, onClose })
131
132
  methods,
132
133
  rename
133
134
  }),
134
- drawerStyle: methods.makeCssClass(properties.drawerStyle, true),
135
- headerStyle: methods.makeCssClass(properties.headerStyle, true),
136
- bodyStyle: methods.makeCssClass(properties.bodyStyle, true),
137
- maskStyle: methods.makeCssClass(properties.maskStyle, true),
138
- contentWrapperStyle: methods.makeCssClass(properties.contentWrapperStyle, true)
135
+ className: classNames.element,
136
+ classNames: {
137
+ header: classNames.header,
138
+ body: classNames.body,
139
+ footer: classNames.footer,
140
+ mask: classNames.mask,
141
+ wrapper: classNames.wrapper,
142
+ content: classNames.content
143
+ },
144
+ style: styles.element,
145
+ styles: {
146
+ header: styles.header,
147
+ body: styles.body,
148
+ mask: styles.mask,
149
+ wrapper: styles.wrapper,
150
+ content: styles.content
151
+ }
139
152
  }, content.content && content.content());
140
153
  };
141
- DrawerBlock.defaultProps = blockDefaultProps;
142
- DrawerBlock.meta = {
143
- category: 'container',
144
- icons: [],
145
- styles: [
146
- 'blocks/Drawer/style.less'
147
- ]
148
- };
149
- export default DrawerBlock;
154
+ export default withTheme('Drawer', withBlockDefaults(DrawerBlock));
@@ -13,7 +13,29 @@
13
13
  See the License for the specific language governing permissions and
14
14
  limitations under the License.
15
15
  */ export default {
16
- type: 'object',
16
+ category: 'container',
17
+ icons: [],
18
+ valueType: null,
19
+ slots: {
20
+ content: 'Main Drawer body.',
21
+ extra: 'Extra content in the header.'
22
+ },
23
+ cssKeys: {
24
+ element: 'The Drawer element.',
25
+ header: 'The Drawer header.',
26
+ body: 'The Drawer body.',
27
+ footer: 'The Drawer footer.',
28
+ mask: 'The Drawer mask.',
29
+ wrapper: 'The Drawer wrapper.',
30
+ content: 'The Drawer content.'
31
+ },
32
+ events: {
33
+ onToggle: 'Trigger actions when drawer is toggled.',
34
+ onClose: 'Trigger actions when drawer is closed.',
35
+ onOpen: 'Trigger actions when drawer is opened.',
36
+ afterClose: 'Trigger actions after drawer is closed.',
37
+ afterOpenChange: 'Trigger actions after drawer is opened.'
38
+ },
17
39
  properties: {
18
40
  type: 'object',
19
41
  additionalProperties: false,
@@ -59,41 +81,6 @@
59
81
  displayType: 'string'
60
82
  }
61
83
  },
62
- headerStyle: {
63
- type: 'object',
64
- description: 'Css style to applied to drawer header.',
65
- docs: {
66
- displayType: 'yaml'
67
- }
68
- },
69
- bodyStyle: {
70
- type: 'object',
71
- description: 'Css style to applied to drawer body.',
72
- docs: {
73
- displayType: 'yaml'
74
- }
75
- },
76
- contentWrapperStyle: {
77
- type: 'object',
78
- description: 'Css style to applied to content area.',
79
- docs: {
80
- displayType: 'yaml'
81
- }
82
- },
83
- maskStyle: {
84
- type: 'object',
85
- description: 'Css style to applied to drawer mask.',
86
- docs: {
87
- displayType: 'yaml'
88
- }
89
- },
90
- drawerStyle: {
91
- type: 'object',
92
- description: 'Css style to applied to drawer.',
93
- docs: {
94
- displayType: 'yaml'
95
- }
96
- },
97
84
  zIndex: {
98
85
  type: 'integer',
99
86
  default: 1000,
@@ -114,32 +101,45 @@
114
101
  type: 'boolean',
115
102
  default: true,
116
103
  description: 'Whether support press esc to close.'
117
- }
118
- }
119
- },
120
- events: {
121
- type: 'object',
122
- additionalProperties: false,
123
- properties: {
124
- onToggle: {
125
- type: 'array',
126
- description: 'Trigger actions when drawer is toggled.'
127
- },
128
- onClose: {
129
- type: 'array',
130
- description: 'Trigger actions when drawer is closed.'
131
- },
132
- onOpen: {
133
- type: 'array',
134
- description: 'Trigger actions when drawer is opened.'
135
104
  },
136
- afterClose: {
137
- type: 'array',
138
- description: 'Trigger actions after drawer is closed.'
139
- },
140
- afterOpenChange: {
141
- type: 'array',
142
- description: 'Trigger actions after drawer is opened.'
105
+ theme: {
106
+ type: 'object',
107
+ description: 'Antd design token overrides for this block. See <a href="https://ant.design/components/overview#design-token">antd design tokens</a>.',
108
+ docs: {
109
+ displayType: 'yaml',
110
+ link: 'https://ant.design/components/drawer#design-token'
111
+ },
112
+ properties: {
113
+ footerPaddingBlock: {
114
+ type: 'number',
115
+ default: 8,
116
+ description: 'Vertical padding of the footer.'
117
+ },
118
+ footerPaddingInline: {
119
+ type: 'number',
120
+ default: 16,
121
+ description: 'Horizontal padding of the footer.'
122
+ },
123
+ zIndexPopup: {
124
+ type: 'number',
125
+ default: 1000,
126
+ description: 'Z-index of the drawer.'
127
+ },
128
+ draggerSize: {
129
+ type: 'number',
130
+ default: 4,
131
+ description: 'Size of the resize handle.'
132
+ },
133
+ colorBgElevated: {
134
+ type: 'string',
135
+ description: 'Background color of the drawer.'
136
+ },
137
+ colorBgMask: {
138
+ type: 'string',
139
+ default: 'rgba(0, 0, 0, 0.45)',
140
+ description: 'Background color of the drawer mask.'
141
+ }
142
+ }
143
143
  }
144
144
  }
145
145
  }
@@ -0,0 +1,221 @@
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 React, { useCallback } from 'react';
16
+ import { Button, ConfigProvider, Dropdown, Space } from 'antd';
17
+ import { DownOutlined } from '@ant-design/icons';
18
+ import { get, type } from '@lowdefy/helpers';
19
+ import { withBlockDefaults } from '@lowdefy/block-utils';
20
+ import useItemShortcuts from '../useItemShortcuts.js';
21
+ const ANTD_COLOR_PRESETS = new Set([
22
+ 'default',
23
+ 'primary',
24
+ 'danger',
25
+ 'blue',
26
+ 'purple',
27
+ 'cyan',
28
+ 'green',
29
+ 'magenta',
30
+ 'pink',
31
+ 'red',
32
+ 'orange',
33
+ 'yellow',
34
+ 'volcano',
35
+ 'geekblue',
36
+ 'lime',
37
+ 'gold'
38
+ ]);
39
+ function getButtonProps(properties) {
40
+ if (properties.variant) {
41
+ return {
42
+ color: properties.color,
43
+ variant: properties.variant
44
+ };
45
+ }
46
+ const buttonType = properties.type ?? 'default';
47
+ if (buttonType === 'danger') {
48
+ return {
49
+ color: 'danger',
50
+ variant: 'solid'
51
+ };
52
+ }
53
+ return {
54
+ type: buttonType
55
+ };
56
+ }
57
+ function DropdownButtonBlock({ blockId, classNames = {}, components: { Icon, ShortcutBadge }, events, loading, methods, properties, rename, styles = {} }) {
58
+ const items = (properties.items ?? []).map((item, i)=>{
59
+ if (item.type === 'divider') {
60
+ return {
61
+ type: 'divider',
62
+ key: `divider-${i}`
63
+ };
64
+ }
65
+ return {
66
+ key: item.eventName ?? `item-${i}`,
67
+ label: /*#__PURE__*/ React.createElement("span", null, item.title, item.shortcut && /*#__PURE__*/ React.createElement(ShortcutBadge, {
68
+ shortcut: item.shortcut
69
+ })),
70
+ icon: item.icon ? /*#__PURE__*/ React.createElement(Icon, {
71
+ blockId: `${blockId}_icon_${i}`,
72
+ classNames: {
73
+ element: classNames.itemIcon
74
+ },
75
+ events: events,
76
+ properties: item.icon,
77
+ styles: {
78
+ element: styles.itemIcon
79
+ }
80
+ }) : undefined,
81
+ danger: item.danger,
82
+ disabled: item.disabled
83
+ };
84
+ });
85
+ const shortcutItems = (properties.items ?? []).filter((item)=>item.shortcut && item.eventName && !item.disabled).map((item)=>({
86
+ key: item.eventName,
87
+ shortcut: item.shortcut
88
+ }));
89
+ const onShortcutMatch = useCallback((key)=>{
90
+ methods.triggerEvent({
91
+ name: key
92
+ });
93
+ }, [
94
+ methods
95
+ ]);
96
+ useItemShortcuts({
97
+ items: shortcutItems,
98
+ onMatch: onShortcutMatch
99
+ });
100
+ const onClickActionName = get(rename, 'events.onClick', {
101
+ default: 'onClick'
102
+ });
103
+ const dropdownProps = {
104
+ menu: {
105
+ items,
106
+ onClick: ({ key })=>methods.triggerEvent({
107
+ name: key
108
+ })
109
+ },
110
+ trigger: [
111
+ properties.trigger ?? 'click'
112
+ ],
113
+ placement: properties.placement ?? 'bottomRight',
114
+ arrow: properties.arrow,
115
+ disabled: properties.disabled,
116
+ popupClassName: classNames.menu,
117
+ popupStyle: styles.menu,
118
+ onOpenChange: (open)=>methods.triggerEvent({
119
+ name: get(rename, 'events.onOpenChange', {
120
+ default: 'onOpenChange'
121
+ }),
122
+ event: {
123
+ open
124
+ }
125
+ })
126
+ };
127
+ const { color: buttonColor, variant, type: buttonType } = getButtonProps(properties);
128
+ const isPresetColor = ANTD_COLOR_PRESETS.has(properties.color);
129
+ const resolvedColor = isPresetColor ? buttonColor : properties.color ? 'primary' : buttonColor;
130
+ const buttonIcon = properties.icon && /*#__PURE__*/ React.createElement(Icon, {
131
+ blockId: `${blockId}_icon`,
132
+ classNames: {
133
+ element: classNames.icon
134
+ },
135
+ events: events,
136
+ properties: properties.icon,
137
+ styles: {
138
+ element: styles.icon
139
+ }
140
+ });
141
+ const theme = properties.theme;
142
+ const { button: buttonTheme, ...dropdownTheme } = type.isObject(theme) ? theme : {};
143
+ function renderContent() {
144
+ if (properties.split) {
145
+ return /*#__PURE__*/ React.createElement(Space.Compact, {
146
+ id: blockId,
147
+ className: classNames.element,
148
+ style: styles.element
149
+ }, /*#__PURE__*/ React.createElement(Button, {
150
+ color: resolvedColor,
151
+ variant: variant,
152
+ type: buttonType,
153
+ size: properties.size,
154
+ shape: properties.shape,
155
+ ghost: properties.ghost,
156
+ danger: properties.danger,
157
+ disabled: properties.disabled || get(events, `${onClickActionName}.loading`) || loading,
158
+ loading: get(events, `${onClickActionName}.loading`),
159
+ className: classNames.button,
160
+ style: styles.button,
161
+ icon: buttonIcon,
162
+ onClick: ()=>methods.triggerEvent({
163
+ name: onClickActionName
164
+ })
165
+ }, properties.title), /*#__PURE__*/ React.createElement(Dropdown, dropdownProps, /*#__PURE__*/ React.createElement(Button, {
166
+ color: resolvedColor,
167
+ variant: variant,
168
+ type: buttonType,
169
+ size: properties.size,
170
+ ghost: properties.ghost,
171
+ danger: properties.danger,
172
+ disabled: properties.disabled,
173
+ icon: /*#__PURE__*/ React.createElement(DownOutlined, null)
174
+ })));
175
+ }
176
+ return /*#__PURE__*/ React.createElement(Dropdown, {
177
+ id: blockId,
178
+ className: classNames.element,
179
+ style: styles.element,
180
+ ...dropdownProps
181
+ }, /*#__PURE__*/ React.createElement(Button, {
182
+ color: resolvedColor,
183
+ variant: variant,
184
+ type: buttonType,
185
+ size: properties.size,
186
+ shape: properties.shape,
187
+ ghost: properties.ghost,
188
+ danger: properties.danger,
189
+ disabled: properties.disabled,
190
+ className: classNames.button,
191
+ style: styles.button,
192
+ icon: buttonIcon
193
+ }, properties.title));
194
+ }
195
+ // Build ConfigProvider theme with both Dropdown and Button tokens
196
+ const themeConfig = {};
197
+ if (type.isObject(dropdownTheme) && Object.keys(dropdownTheme).length > 0) {
198
+ themeConfig.Dropdown = dropdownTheme;
199
+ }
200
+ if (type.isObject(buttonTheme)) {
201
+ themeConfig.Button = buttonTheme;
202
+ }
203
+ const hasTheme = Object.keys(themeConfig).length > 0;
204
+ const hasCustomColor = properties.color && !isPresetColor;
205
+ if (hasTheme || hasCustomColor) {
206
+ const providerTheme = {};
207
+ if (hasTheme) {
208
+ providerTheme.components = themeConfig;
209
+ }
210
+ if (hasCustomColor) {
211
+ providerTheme.token = {
212
+ colorPrimary: properties.color
213
+ };
214
+ }
215
+ return /*#__PURE__*/ React.createElement(ConfigProvider, {
216
+ theme: providerTheme
217
+ }, renderContent());
218
+ }
219
+ return renderContent();
220
+ }
221
+ export default withBlockDefaults(DropdownButtonBlock);
@@ -0,0 +1,30 @@
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 { createBlockHelper, escapeId } from '@lowdefy/e2e-utils';
16
+ import { expect } from '@playwright/test';
17
+ const locator = (page, blockId)=>page.locator(`#bl-${escapeId(blockId)}`);
18
+ export default createBlockHelper({
19
+ locator,
20
+ do: {
21
+ open: (page, blockId)=>locator(page, blockId).locator('button').first().click(),
22
+ clickItem: (_page, _blockId, title)=>_page.locator(`.ant-dropdown-menu-item:has-text("${title}")`).click(),
23
+ clickSplitArrow: (page, blockId)=>locator(page, blockId).locator('.ant-space-compact button').last().click()
24
+ },
25
+ expect: {
26
+ menuVisible: (_page)=>expect(_page.locator('.ant-dropdown').first()).toBeVisible(),
27
+ menuHidden: (_page)=>expect(_page.locator('.ant-dropdown').first()).toBeHidden(),
28
+ text: (page, blockId, text)=>expect(locator(page, blockId).locator('button').first()).toHaveText(text)
29
+ }
30
+ });