@luck-design-biz/luckda 0.0.22-4 → 0.0.23

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 (222) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +40 -40
  3. package/es/components/Builder/index.js +1 -1
  4. package/es/components/LdFormList/index.js +4 -1
  5. package/es/components/LdGrid/index.js +4 -4
  6. package/es/components/LdGridForm/index.less +7 -7
  7. package/es/components/LdRuntimeCom/index.js +42 -0
  8. package/es/components/LdTree/index.less +36 -36
  9. package/es/helper/action.js +6 -6
  10. package/es/helper/form.js +14 -14
  11. package/es/helper/index.less +7 -7
  12. package/es/index.js +1 -0
  13. package/es/lowcode/constants/api-url.js +2 -0
  14. package/es/lowcode/constants/event-topics.js +23 -0
  15. package/es/lowcode/constants/index.js +12 -0
  16. package/es/lowcode/engine/factory/DataFactory.js +1 -0
  17. package/es/lowcode/engine/meta/button.props.default.json +8 -0
  18. package/es/lowcode/engine/meta/cardlist.props.default.json +10 -0
  19. package/es/lowcode/engine/meta/components/button.json +104 -0
  20. package/es/lowcode/engine/meta/components/card-list.json +143 -0
  21. package/es/lowcode/engine/meta/components/drawer.json +143 -0
  22. package/es/lowcode/engine/meta/components/form.json +116 -0
  23. package/es/lowcode/engine/meta/components/iframe.json +31 -0
  24. package/es/lowcode/engine/meta/components/image.json +113 -0
  25. package/es/lowcode/engine/meta/components/imex.json +81 -0
  26. package/es/lowcode/engine/meta/components/jsx.json +24 -0
  27. package/es/lowcode/engine/meta/components/layout.json +107 -0
  28. package/es/lowcode/engine/meta/components/link.json +111 -0
  29. package/es/lowcode/engine/meta/components/modal.json +120 -0
  30. package/es/lowcode/engine/meta/components/section.json +107 -0
  31. package/es/lowcode/engine/meta/components/split.json +71 -0
  32. package/es/lowcode/engine/meta/components/table.json +161 -0
  33. package/es/lowcode/engine/meta/components/tabs.json +140 -0
  34. package/es/lowcode/engine/meta/components/text.json +65 -0
  35. package/es/lowcode/engine/meta/components/tree.json +156 -0
  36. package/es/lowcode/engine/meta/components-list.json +122 -0
  37. package/es/lowcode/engine/meta/drawer.props.default.json +10 -0
  38. package/es/lowcode/engine/meta/form.props.default.json +5 -0
  39. package/es/lowcode/engine/meta/iframe.props.default.json +3 -0
  40. package/es/lowcode/engine/meta/image.props.default.json +8 -0
  41. package/es/lowcode/engine/meta/imex.props.default.json +4 -0
  42. package/es/lowcode/engine/meta/jsx.props.default.json +1 -0
  43. package/es/lowcode/engine/meta/layout.props.default.json +5 -0
  44. package/es/lowcode/engine/meta/link.props.default.json +6 -0
  45. package/es/lowcode/engine/meta/modal.props.default.json +11 -0
  46. package/es/lowcode/engine/meta/section.props.default.json +9 -0
  47. package/es/lowcode/engine/meta/split.props.default.json +5 -0
  48. package/es/lowcode/engine/meta/table.props.default.json +10 -0
  49. package/es/lowcode/engine/meta/tabs.props.default.json +10 -0
  50. package/es/lowcode/engine/meta/text.props.default.json +4 -0
  51. package/es/lowcode/engine/meta/tree.props.default.json +9 -0
  52. package/es/lowcode/engine/provider/ContextProvider.js +164 -0
  53. package/es/lowcode/engine/provider/EventBusProvider.js +120 -0
  54. package/es/lowcode/engine/tools/dataProcess.js +188 -0
  55. package/es/lowcode/engine/tools/helper.js +4 -0
  56. package/es/lowcode/engine/tools/lcid.js +16 -0
  57. package/es/lowcode/index.js +3 -0
  58. package/es/lowcode/painter/Components.js +104 -0
  59. package/es/lowcode/painter/Design.js +97 -0
  60. package/es/lowcode/painter/I18n.js +5 -0
  61. package/es/lowcode/painter/Outline.js +202 -0
  62. package/es/lowcode/painter/Panel.js +8 -0
  63. package/es/lowcode/painter/Ribbon.js +136 -0
  64. package/es/lowcode/painter/components/PanelItem.js +20 -0
  65. package/es/lowcode/painter/components/RuleInput.js +105 -0
  66. package/es/lowcode/painter/index.js +19 -0
  67. package/es/lowcode/painter/panel-section/LayoutRatio.js +123 -0
  68. package/es/lowcode/painter/panel-section/Radio.js +58 -0
  69. package/es/lowcode/painter/style/components.less +90 -0
  70. package/es/lowcode/painter/style/design.less +38 -0
  71. package/es/lowcode/painter/style/index.less +7 -0
  72. package/es/lowcode/painter/style/layout-ratio.less +51 -0
  73. package/es/lowcode/painter/style/outline.less +26 -0
  74. package/es/lowcode/painter/style/panel-item.less +21 -0
  75. package/es/lowcode/painter/style/panel.less +5 -0
  76. package/es/lowcode/painter/style/radio.less +24 -0
  77. package/es/lowcode/painter/style/ribbon.less +4 -0
  78. package/es/lowcode/painter/style/rule-input.less +13 -0
  79. package/es/lowcode/view/Canvas.js +135 -0
  80. package/es/lowcode/view/Loading.js +23 -0
  81. package/es/lowcode/view/Page.js +55 -0
  82. package/es/lowcode/view/index.js +18 -0
  83. package/es/lowcode/view/lc-components/Box/index.js +21 -0
  84. package/es/lowcode/view/lc-components/Button/index.js +37 -0
  85. package/es/lowcode/view/lc-components/CardList/index.js +20 -0
  86. package/es/lowcode/view/lc-components/Dialog/index.js +50 -0
  87. package/es/lowcode/view/lc-components/Dialog/index.less +3 -0
  88. package/es/lowcode/view/lc-components/Drawer/index.js +46 -0
  89. package/es/lowcode/view/lc-components/Form/index.js +20 -0
  90. package/es/lowcode/view/lc-components/Iframe/index.js +20 -0
  91. package/es/lowcode/view/lc-components/ImEx/index.js +20 -0
  92. package/es/lowcode/view/lc-components/Image/index.js +20 -0
  93. package/es/lowcode/view/lc-components/JSX/index.js +20 -0
  94. package/es/lowcode/view/lc-components/Layout/index.js +24 -0
  95. package/es/lowcode/view/lc-components/Link/index.js +20 -0
  96. package/es/lowcode/view/lc-components/Section/index.js +34 -0
  97. package/es/lowcode/view/lc-components/Split/index.js +21 -0
  98. package/es/lowcode/view/lc-components/Table/index.js +23 -0
  99. package/es/lowcode/view/lc-components/Tabs/index.js +21 -0
  100. package/es/lowcode/view/lc-components/Text/index.js +23 -0
  101. package/es/lowcode/view/lc-components/Tree/index.js +20 -0
  102. package/es/lowcode/view/lc-components/Wrapper.js +45 -0
  103. package/es/lowcode/view/style/canvas.less +5 -0
  104. package/es/lowcode/view/style/loading.less +84 -0
  105. package/es/lowcode/view/style/page.less +6 -0
  106. package/es/upload/Form/gridForm.js +1 -1
  107. package/es/upload/Form/index.less +7 -7
  108. package/es/upload/FormItem/index.js +15 -15
  109. package/es/utils/form.js +22 -22
  110. package/es/utils/grid.js +2 -2
  111. package/lib/components/Builder/index.js +1 -1
  112. package/lib/components/LdFormList/index.js +5 -1
  113. package/lib/components/LdGrid/index.js +4 -4
  114. package/lib/components/LdGridForm/index.less +7 -7
  115. package/lib/components/LdRuntimeCom/index.js +49 -0
  116. package/lib/components/LdTree/index.less +36 -36
  117. package/lib/helper/action.js +6 -6
  118. package/lib/helper/form.js +14 -14
  119. package/lib/helper/index.less +7 -7
  120. package/lib/index.js +9 -1
  121. package/lib/lowcode/constants/api-url.js +8 -0
  122. package/lib/lowcode/constants/event-topics.js +29 -0
  123. package/lib/lowcode/constants/index.js +18 -0
  124. package/lib/lowcode/engine/factory/DataFactory.js +3 -0
  125. package/lib/lowcode/engine/meta/button.props.default.json +8 -0
  126. package/lib/lowcode/engine/meta/cardlist.props.default.json +10 -0
  127. package/lib/lowcode/engine/meta/components/button.json +104 -0
  128. package/lib/lowcode/engine/meta/components/card-list.json +143 -0
  129. package/lib/lowcode/engine/meta/components/drawer.json +143 -0
  130. package/lib/lowcode/engine/meta/components/form.json +116 -0
  131. package/lib/lowcode/engine/meta/components/iframe.json +31 -0
  132. package/lib/lowcode/engine/meta/components/image.json +113 -0
  133. package/lib/lowcode/engine/meta/components/imex.json +81 -0
  134. package/lib/lowcode/engine/meta/components/jsx.json +24 -0
  135. package/lib/lowcode/engine/meta/components/layout.json +107 -0
  136. package/lib/lowcode/engine/meta/components/link.json +111 -0
  137. package/lib/lowcode/engine/meta/components/modal.json +120 -0
  138. package/lib/lowcode/engine/meta/components/section.json +107 -0
  139. package/lib/lowcode/engine/meta/components/split.json +71 -0
  140. package/lib/lowcode/engine/meta/components/table.json +161 -0
  141. package/lib/lowcode/engine/meta/components/tabs.json +140 -0
  142. package/lib/lowcode/engine/meta/components/text.json +65 -0
  143. package/lib/lowcode/engine/meta/components/tree.json +156 -0
  144. package/lib/lowcode/engine/meta/components-list.json +122 -0
  145. package/lib/lowcode/engine/meta/drawer.props.default.json +10 -0
  146. package/lib/lowcode/engine/meta/form.props.default.json +5 -0
  147. package/lib/lowcode/engine/meta/iframe.props.default.json +3 -0
  148. package/lib/lowcode/engine/meta/image.props.default.json +8 -0
  149. package/lib/lowcode/engine/meta/imex.props.default.json +4 -0
  150. package/lib/lowcode/engine/meta/jsx.props.default.json +1 -0
  151. package/lib/lowcode/engine/meta/layout.props.default.json +5 -0
  152. package/lib/lowcode/engine/meta/link.props.default.json +6 -0
  153. package/lib/lowcode/engine/meta/modal.props.default.json +11 -0
  154. package/lib/lowcode/engine/meta/section.props.default.json +9 -0
  155. package/lib/lowcode/engine/meta/split.props.default.json +5 -0
  156. package/lib/lowcode/engine/meta/table.props.default.json +10 -0
  157. package/lib/lowcode/engine/meta/tabs.props.default.json +10 -0
  158. package/lib/lowcode/engine/meta/text.props.default.json +4 -0
  159. package/lib/lowcode/engine/meta/tree.props.default.json +9 -0
  160. package/lib/lowcode/engine/provider/ContextProvider.js +172 -0
  161. package/lib/lowcode/engine/provider/EventBusProvider.js +128 -0
  162. package/lib/lowcode/engine/tools/dataProcess.js +201 -0
  163. package/lib/lowcode/engine/tools/helper.js +11 -0
  164. package/lib/lowcode/engine/tools/lcid.js +22 -0
  165. package/lib/lowcode/index.js +20 -0
  166. package/lib/lowcode/painter/Components.js +112 -0
  167. package/lib/lowcode/painter/Design.js +105 -0
  168. package/lib/lowcode/painter/I18n.js +12 -0
  169. package/lib/lowcode/painter/Outline.js +210 -0
  170. package/lib/lowcode/painter/Panel.js +16 -0
  171. package/lib/lowcode/painter/Ribbon.js +151 -0
  172. package/lib/lowcode/painter/components/PanelItem.js +26 -0
  173. package/lib/lowcode/painter/components/RuleInput.js +112 -0
  174. package/lib/lowcode/painter/index.js +26 -0
  175. package/lib/lowcode/painter/panel-section/LayoutRatio.js +131 -0
  176. package/lib/lowcode/painter/panel-section/Radio.js +65 -0
  177. package/lib/lowcode/painter/style/components.less +90 -0
  178. package/lib/lowcode/painter/style/design.less +38 -0
  179. package/lib/lowcode/painter/style/index.less +7 -0
  180. package/lib/lowcode/painter/style/layout-ratio.less +51 -0
  181. package/lib/lowcode/painter/style/outline.less +26 -0
  182. package/lib/lowcode/painter/style/panel-item.less +21 -0
  183. package/lib/lowcode/painter/style/panel.less +5 -0
  184. package/lib/lowcode/painter/style/radio.less +24 -0
  185. package/lib/lowcode/painter/style/ribbon.less +4 -0
  186. package/lib/lowcode/painter/style/rule-input.less +13 -0
  187. package/lib/lowcode/view/Canvas.js +150 -0
  188. package/lib/lowcode/view/Loading.js +30 -0
  189. package/lib/lowcode/view/Page.js +63 -0
  190. package/lib/lowcode/view/index.js +25 -0
  191. package/lib/lowcode/view/lc-components/Box/index.js +29 -0
  192. package/lib/lowcode/view/lc-components/Button/index.js +45 -0
  193. package/lib/lowcode/view/lc-components/CardList/index.js +28 -0
  194. package/lib/lowcode/view/lc-components/Dialog/index.js +58 -0
  195. package/lib/lowcode/view/lc-components/Dialog/index.less +3 -0
  196. package/lib/lowcode/view/lc-components/Drawer/index.js +54 -0
  197. package/lib/lowcode/view/lc-components/Form/index.js +28 -0
  198. package/lib/lowcode/view/lc-components/Iframe/index.js +28 -0
  199. package/lib/lowcode/view/lc-components/ImEx/index.js +28 -0
  200. package/lib/lowcode/view/lc-components/Image/index.js +28 -0
  201. package/lib/lowcode/view/lc-components/JSX/index.js +28 -0
  202. package/lib/lowcode/view/lc-components/Layout/index.js +32 -0
  203. package/lib/lowcode/view/lc-components/Link/index.js +28 -0
  204. package/lib/lowcode/view/lc-components/Section/index.js +42 -0
  205. package/lib/lowcode/view/lc-components/Split/index.js +29 -0
  206. package/lib/lowcode/view/lc-components/Table/index.js +31 -0
  207. package/lib/lowcode/view/lc-components/Tabs/index.js +29 -0
  208. package/lib/lowcode/view/lc-components/Text/index.js +31 -0
  209. package/lib/lowcode/view/lc-components/Tree/index.js +28 -0
  210. package/lib/lowcode/view/lc-components/Wrapper.js +52 -0
  211. package/lib/lowcode/view/style/canvas.less +5 -0
  212. package/lib/lowcode/view/style/loading.less +84 -0
  213. package/lib/lowcode/view/style/page.less +6 -0
  214. package/lib/upload/Form/gridForm.js +1 -1
  215. package/lib/upload/Form/index.less +7 -7
  216. package/lib/upload/FormItem/index.js +15 -15
  217. package/lib/utils/form.js +22 -22
  218. package/lib/utils/grid.js +2 -2
  219. package/lowcode.js +1 -0
  220. package/package.json +157 -151
  221. package/upload.js +1 -1
  222. package/utils.js +1 -1
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
4
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ var _layoutRatio = _interopRequireDefault(require("../style/layout-ratio.less"));
12
+ var _utils = require("@luck-design-biz/base/utils");
13
+ var _RuleInput = _interopRequireDefault(require("../components/RuleInput"));
14
+ var _PanelItem = _interopRequireDefault(require("../components/PanelItem"));
15
+ var ratios = ['12', '6:6', '3:9', '9:3', '4:4:4', '3:6:3', '3:3:3:3', '2:2:2:2:2:2'];
16
+ var defaultRatio = '12';
17
+
18
+ /**
19
+ * 布局比例组件
20
+ *
21
+ * @param {string} value 默认值
22
+ * @param {Function} onChange 当合法数据变化时触发
23
+ * @returns
24
+ */
25
+ var LayoutRatio = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
26
+ var value = _ref.value,
27
+ onChange = _ref.onChange;
28
+ var _useState = (0, _react.useState)(value || defaultRatio),
29
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
30
+ currentRatio = _useState2[0],
31
+ setCurrentRatio = _useState2[1];
32
+ var handleInputChange = function handleInputChange(_, value) {
33
+ console.log('value', value);
34
+ if (!value) value = defaultRatio;
35
+ setCurrentRatio(value);
36
+ };
37
+ var handGridClick = function handGridClick(selectedRadio) {
38
+ // console.log('selectedRadio', selectedRadio);
39
+ setCurrentRatio(selectedRadio);
40
+ if (onChange) onChange(selectedRadio);
41
+ };
42
+ (0, _react.useImperativeHandle)(ref, function () {
43
+ return {
44
+ getValue: function getValue() {
45
+ return currentRatio;
46
+ }
47
+ };
48
+ });
49
+
50
+ // 定义验证规则
51
+ var rules = [{
52
+ func: function func(value) {
53
+ // 首先,检查value是否为字符串
54
+ if (typeof value !== 'string') return false;
55
+
56
+ // 使用正则表达式检查字符串是否只包含数字和冒号,并且不以冒号开始或结束
57
+ if (!/^[0-9]+(:[0-9]+)*$/.test(value)) return false;
58
+
59
+ // 使用冒号分割字符串,并将分割后的每个元素转换为数字
60
+ var numbers = value.split(':').map(Number);
61
+
62
+ // 计算所有数字的总和
63
+ var sum = numbers.reduce(function (acc, cur) {
64
+ return acc + cur;
65
+ }, 0);
66
+
67
+ // 判断总和是否等于12
68
+ return sum === 12;
69
+ },
70
+ err: (0, _utils.formatMessage)({
71
+ id: 'luckda.lowcode.painter.panel-section.Layoutratio.err',
72
+ label: '必须是数字或者数字加:号的组合,且数字之和必须等于12'
73
+ })
74
+ }];
75
+ var isCurrentInRatios = ratios.includes(currentRatio);
76
+ var currentItemRatios = currentRatio.split(':');
77
+ return /*#__PURE__*/_react.default.createElement("div", {
78
+ className: _layoutRatio.default['lc-painter-panel-section-layoutratio']
79
+ }, /*#__PURE__*/_react.default.createElement("div", {
80
+ className: _layoutRatio.default['ratio-view']
81
+ }, /*#__PURE__*/_react.default.createElement("div", {
82
+ className: _layoutRatio.default['gridbox-container']
83
+ }, ratios.map(function (ratio) {
84
+ var itemRatios = ratio.split(':');
85
+ var isCurrent = ratio == currentRatio;
86
+ var className = _layoutRatio.default['gridbox'];
87
+ if (isCurrent) className = className + ' ' + _layoutRatio.default['current'];
88
+ return /*#__PURE__*/_react.default.createElement("div", {
89
+ className: className,
90
+ onClick: function onClick() {
91
+ return handGridClick(ratio);
92
+ }
93
+ }, itemRatios.map(function (itemRatio) {
94
+ return /*#__PURE__*/_react.default.createElement("div", {
95
+ className: _layoutRatio.default['girditem'],
96
+ style: {
97
+ gridColumn: 'span ' + itemRatio
98
+ }
99
+ });
100
+ }));
101
+ }), !isCurrentInRatios && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
102
+ className: "".concat(_layoutRatio.default['gridbox'], " ").concat(_layoutRatio.default['current']),
103
+ onClick: function onClick() {
104
+ return handGridClick(ratio);
105
+ }
106
+ }, currentItemRatios.map(function (itemRatio) {
107
+ return /*#__PURE__*/_react.default.createElement("div", {
108
+ className: _layoutRatio.default['girditem'],
109
+ style: {
110
+ gridColumn: 'span ' + itemRatio
111
+ }
112
+ });
113
+ }))))), /*#__PURE__*/_react.default.createElement("div", {
114
+ className: _layoutRatio.default['ratio-input']
115
+ }, /*#__PURE__*/_react.default.createElement(_PanelItem.default, {
116
+ label: (0, _utils.formatMessage)({
117
+ id: 'luckda.lowcode.painter.panel-section.Layoutratio.label',
118
+ label: '列比例'
119
+ }),
120
+ component: /*#__PURE__*/_react.default.createElement(_RuleInput.default, {
121
+ placeholder: (0, _utils.formatMessage)({
122
+ id: 'luckda.lowcode.painter.panel-section.Layoutratio.placeholder',
123
+ label: '请输入列比例'
124
+ }),
125
+ rules: rules,
126
+ onValueChange: handleInputChange,
127
+ value: currentRatio
128
+ })
129
+ })));
130
+ });
131
+ var _default = exports.default = LayoutRatio;
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
4
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ var _radio = _interopRequireDefault(require("../style/radio.less"));
12
+ /**
13
+ * Radio组件允许用户从一组选项中选择一个。它接收一个`options`数组来渲染选项,以及一个可选的`onChange`回调函数,
14
+ * 当用户选择不同的选项时,`onChange`会被调用并传递当前选中的选项对象。
15
+ *
16
+ * @component
17
+ * @example
18
+ * const options = [
19
+ * { label: '小', value: 'small' },
20
+ * { label: '中', value: 'middle' },
21
+ * { label: '大', value: 'large' }
22
+ * ];
23
+ *
24
+ * function handleChange(option) {
25
+ * console.log(option);
26
+ * }
27
+ *
28
+ * <Radio options={options} onChange={handleChange} />
29
+ *
30
+ * @param {Object} props - 组件的props。
31
+ * @param {Object[]} props.options - 选项数组,每个对象都应包含`label`和`value`。
32
+ * @param {string} props.options[].label - 选项的显示文本。
33
+ * @param {string} props.options[].value - 选项的值,应唯一。
34
+ * @param {Function} [props.onChange] - 可选,当选项变化时调用的回调函数。传递当前选中的选项对象。
35
+ */
36
+ var Radio = function Radio(_ref) {
37
+ var _options$;
38
+ var options = _ref.options,
39
+ onChange = _ref.onChange;
40
+ var _useState = (0, _react.useState)((_options$ = options[0]) === null || _options$ === void 0 ? void 0 : _options$.value),
41
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
42
+ activeValue = _useState2[0],
43
+ setActiveValue = _useState2[1];
44
+
45
+ // 点击事件处理函数
46
+ var handleClick = function handleClick(option) {
47
+ // 设置当前激活的选项
48
+ setActiveValue(option.value);
49
+ if (onChange) {
50
+ onChange(option);
51
+ }
52
+ };
53
+ return /*#__PURE__*/_react.default.createElement("div", {
54
+ className: _radio.default['lc-painter-panel-section-radio']
55
+ }, options.map(function (option) {
56
+ return /*#__PURE__*/_react.default.createElement("div", {
57
+ key: option.value,
58
+ className: "".concat(_radio.default['radio-item'], " ").concat(activeValue === option.value ? 'active' : ''),
59
+ onClick: function onClick() {
60
+ return handleClick(option);
61
+ }
62
+ }, option.label);
63
+ }));
64
+ };
65
+ var _default = exports.default = Radio;
@@ -0,0 +1,90 @@
1
+ .lc-painter-components {
2
+ .components-search {
3
+ padding: 0 20px;
4
+ }
5
+
6
+ .components-content {
7
+ border-top: 1px solid #e3e3e3;
8
+ margin-top: 20px;
9
+ padding-top: 10px;
10
+ display: flex;
11
+ flex-direction: row;
12
+ flex-wrap: wrap;
13
+ justify-content: flex-start;
14
+ align-items: flex-start;
15
+
16
+ .components-wrapper {
17
+ padding: 0 20px;
18
+ flex-basis: 100%;
19
+ display: flex;
20
+ flex-direction: row;
21
+ flex-wrap: wrap;
22
+ align-items: center;
23
+ margin-bottom: 20px;
24
+
25
+ h3 {
26
+ width: 100%; // 使标题占满整行
27
+ margin-left: 0;
28
+ margin-bottom: 10px;
29
+ }
30
+ }
31
+
32
+ .components-item {
33
+ display: flex;
34
+ width: 121px;
35
+ height: 37px;
36
+ align-items: center;
37
+ justify-content: center; // 水平居中对齐
38
+ padding: 10px;
39
+ border: 1px solid #ddd;
40
+ margin-right: 10px; // 添加右边距来分隔项
41
+ margin-bottom: 10px; // 添加底边距来分隔行
42
+ border-radius: 4px;
43
+ transition: border-color 0.3s;
44
+ box-sizing: border-box; // 确保边框和填充不会增加元素的宽度
45
+
46
+ &:hover {
47
+ cursor: pointer;
48
+ border-color: #3478ff;
49
+ color: #3478ff; // 文本颜色
50
+ .icon-wrapper {
51
+ color: #3478ff; // Icon颜色(如果Icon组件接受color属性)
52
+ }
53
+ }
54
+
55
+ .icon-wrapper {
56
+ display: flex;
57
+ font-size: 12px;
58
+ align-items: center;
59
+ margin-right: 10px;
60
+ }
61
+
62
+ .text-content {
63
+ flex-grow: 1;
64
+ text-align: left;
65
+
66
+ span {
67
+ font-size: 12px;
68
+ color: #333;
69
+ white-space: nowrap; // 防止文字换行
70
+ overflow: hidden; // 隐藏溢出的文字
71
+ text-overflow: ellipsis; // 使用省略号表示溢出
72
+ }
73
+
74
+ p {
75
+ display: none; // 隐藏描述,因为在这个组件尺寸中无法显示
76
+ }
77
+ }
78
+ }
79
+ }
80
+
81
+ :global{
82
+ .ant-tabs-nav-scroll{
83
+ display: flex;
84
+ justify-content: center;
85
+ .ant-tabs-tab{
86
+ font-size: 14px!important;
87
+ }
88
+ }
89
+ }
90
+ }
@@ -0,0 +1,38 @@
1
+ .box {
2
+ position: absolute;
3
+ width: 0;
4
+ height: 0;
5
+ top: 0;
6
+ left: 0;
7
+ display: none;
8
+ pointer-events: none;
9
+ cursor: pointer;
10
+ overflow: visible;
11
+ z-index: 9999;
12
+ }
13
+
14
+ .lc-painter-design {
15
+ position: relative;
16
+ flex: 1;
17
+ height: 100%;
18
+ overflow: auto;
19
+
20
+ .simulator {
21
+ :global {
22
+ .ant-form-item {
23
+ pointer-events: none;
24
+ }
25
+ }
26
+ }
27
+
28
+ .detector {
29
+ border: 1px dashed var(--ant-primary-color);
30
+ background-color: color-mix(in sRGB, var(--ant-primary-color), transparent 95%);
31
+ .box();
32
+ }
33
+
34
+ .selector {
35
+ border: 2px solid var(--ant-primary-6);
36
+ .box();
37
+ }
38
+ }
@@ -0,0 +1,7 @@
1
+ .lc-painter {
2
+ width: 100%;
3
+ height: 100%;
4
+ position: relative;
5
+ display: flex;
6
+ background-color: #fff;
7
+ }
@@ -0,0 +1,51 @@
1
+ .lc-painter-panel-section-layoutratio {
2
+ @gridbox-width: 66px; // 定义变量
3
+ @grid-gap: 10px; // 间隔变量
4
+ @grid-items-per-row: 4; // 每行的gridbox数量
5
+
6
+ margin: 0;
7
+ align-items: center;
8
+
9
+ .ratio-view {
10
+ display: flex;
11
+ justify-content: center;
12
+ align-items: flex-start;
13
+
14
+ .gridbox-container {
15
+ width: calc(@grid-items-per-row * @gridbox-width + (@grid-items-per-row - 1) * @grid-gap);
16
+ margin: 0 auto; // 保持这个居中
17
+ display: flex;
18
+ flex-direction: row;
19
+ flex-wrap: wrap;
20
+ gap: @grid-gap;
21
+ }
22
+
23
+ .gridbox {
24
+ display: grid;
25
+ grid-template-columns: repeat(12, 1fr);
26
+ gap: 2px;
27
+ width: @gridbox-width;
28
+ height: 34px;
29
+ border-radius: 5px;
30
+ border: 1px solid rgba(0, 0, 0, 0.2);
31
+ padding: 3px;
32
+
33
+ &:hover {
34
+ cursor: pointer;
35
+ border-color: #3478ff;
36
+ }
37
+
38
+ &.current {
39
+ border-color: #3478ff;
40
+ }
41
+
42
+ .girditem {
43
+ background-color: rgb(192, 194, 196);
44
+ }
45
+ }
46
+ }
47
+
48
+ .ratio-input {
49
+ margin-top: 20px;
50
+ }
51
+ }
@@ -0,0 +1,26 @@
1
+ .lc-painter-outline {
2
+ .page-node {
3
+ cursor: pointer;
4
+ display: flex;
5
+ -webkit-box-align: center;
6
+ align-items: center;
7
+ height: 32px;
8
+ box-sizing: border-box;
9
+ position: relative;
10
+ transform: translateZ(0);
11
+ padding: 0 5px;
12
+ }
13
+ .page-node:hover,
14
+ .page-node.page-node-active {
15
+ background-color: #f6f7f8;
16
+ }
17
+
18
+ :global {
19
+ .ant-tree.ant-tree-show-line li:not(:last-child)::before {
20
+ height: calc(100% - 34px);
21
+ }
22
+ .ant-tree-switcher-noop svg {
23
+ display: none;
24
+ }
25
+ }
26
+ }
@@ -0,0 +1,21 @@
1
+ .lc-painter-components-panelitem {
2
+ display: flex;
3
+ justify-content: space-between;
4
+ gap: 20px;
5
+ align-items: center;
6
+ min-height: 28px;
7
+
8
+ .item-label {
9
+ font-size: 12px;
10
+ }
11
+
12
+ .item-component {
13
+ display: flex;
14
+ width: 215px;
15
+ }
16
+
17
+ /* 使.item-component-box的直接子元素铺满 */
18
+ .item-component > * {
19
+ flex-grow: 1;
20
+ }
21
+ }
@@ -0,0 +1,5 @@
1
+ .lc-painter-panel {
2
+ width: 320px;
3
+ height: 100%;
4
+ border-left: 1px solid #e8e8e8;
5
+ }
@@ -0,0 +1,24 @@
1
+ .lc-painter-panel-section-radio {
2
+ background-color: #f1f2f3;
3
+ border-radius: 6px;
4
+ height: 28px;
5
+ display: flex;
6
+ align-items: center;
7
+
8
+ .radio-item {
9
+ display: flex;
10
+ flex: 1;
11
+ text-align: center;
12
+ align-items: center;
13
+ justify-content: center;
14
+ height: 24px;
15
+ font-size: 12px;
16
+ margin: 2px;
17
+ border-radius: 6px;
18
+ cursor: pointer;
19
+
20
+ &.active{
21
+ background-color: #ffffff;
22
+ }
23
+ }
24
+ }
@@ -0,0 +1,4 @@
1
+ .lc-painter-ribbon {
2
+ border-right: 1px solid #e8e8e8;
3
+ font-size: 16px;
4
+ }
@@ -0,0 +1,13 @@
1
+ .lc-painter-components-ruleinput {
2
+ &.err, &.err:hover {
3
+ border-color: #ff4d4f;
4
+ color: red;
5
+ }
6
+ &.err:focus {
7
+ border-color: #ff4d4f;
8
+ border-right-width: 1px !important;
9
+ outline: 0;
10
+ -webkit-box-shadow: 0 0 0 2px rgba(245,34,45,.2);
11
+ box-shadow: 0 0 0 2px rgba(245,34,45,.2);
12
+ }
13
+ }
@@ -0,0 +1,150 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ var _interopRequireWildcard3 = require("@babel/runtime/helpers/interopRequireWildcard").default;
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _regeneratorRuntime2 = _interopRequireDefault(require("@babel/runtime/helpers/regeneratorRuntime"));
10
+ var _interopRequireWildcard2 = _interopRequireDefault(require("@babel/runtime/helpers/interopRequireWildcard"));
11
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
12
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
14
+ var _react = _interopRequireWildcard3(require("react"));
15
+ var _umi = require("umi");
16
+ var _ahooks = require("ahooks");
17
+ var _lodash = require("lodash");
18
+ var _Wrapper = _interopRequireDefault(require("./lc-components/Wrapper"));
19
+ var _constants = require("../constants");
20
+ var _canvas = _interopRequireDefault(require("./style/canvas.less"));
21
+ var _excluded = ["props", "children"];
22
+ var PAGE_CELL = [_constants.CELL_KEY.PAGE_HEADER, _constants.CELL_KEY.PAGE_CONTENT, _constants.CELL_KEY.PAGE_FOOTER];
23
+ var Canvas = function Canvas(_ref) {
24
+ var dataSource = _ref.dataSource;
25
+ console.log('dataSource', dataSource);
26
+ var headerRef = (0, _react.useRef)();
27
+ var contentRef = (0, _react.useRef)();
28
+ var footerRef = (0, _react.useRef)();
29
+ var _useState = (0, _react.useState)(null),
30
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
31
+ header = _useState2[0],
32
+ setHeader = _useState2[1];
33
+ var _useState3 = (0, _react.useState)(null),
34
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
35
+ content = _useState4[0],
36
+ setContent = _useState4[1];
37
+ var _useState5 = (0, _react.useState)(null),
38
+ _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
39
+ footer = _useState6[0],
40
+ setFooter = _useState6[1];
41
+ var _useState7 = (0, _react.useState)(null),
42
+ _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
43
+ modal = _useState8[0],
44
+ setModal = _useState8[1];
45
+ var render = (0, _ahooks.useMemoizedFn)(function (_ref2) {
46
+ var props = _ref2.props,
47
+ children = _ref2.children,
48
+ childrenMap = (0, _objectWithoutProperties2.default)(_ref2, _excluded);
49
+ if (props && !PAGE_CELL.includes(props.id)) {
50
+ var Comp = (0, _umi.dynamic)({
51
+ loader: function () {
52
+ var _loader = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee() {
53
+ var _yield$import, _Comp;
54
+ return (0, _regeneratorRuntime2.default)().wrap(function _callee$(_context) {
55
+ while (1) switch (_context.prev = _context.next) {
56
+ case 0:
57
+ _context.next = 2;
58
+ return function (specifier) {
59
+ return new Promise(function (r) {
60
+ return r(specifier);
61
+ }).then(function (s) {
62
+ return (0, _interopRequireWildcard2.default)(require(s));
63
+ });
64
+ }("./lc-components/".concat(props.type));
65
+ case 2:
66
+ _yield$import = _context.sent;
67
+ _Comp = _yield$import.default;
68
+ return _context.abrupt("return", _Comp);
69
+ case 5:
70
+ case "end":
71
+ return _context.stop();
72
+ }
73
+ }, _callee);
74
+ }));
75
+ function loader() {
76
+ return _loader.apply(this, arguments);
77
+ }
78
+ return loader;
79
+ }()
80
+ });
81
+ return /*#__PURE__*/_react.default.createElement(Comp, {
82
+ id: props.id,
83
+ lcdata: props
84
+ }, (children || []).map(function (_id) {
85
+ return render(childrenMap[_id]);
86
+ }));
87
+ }
88
+ return (children || []).map(function (_id) {
89
+ return render(childrenMap[_id]);
90
+ });
91
+ });
92
+ (0, _ahooks.useDeepCompareLayoutEffect)(function () {
93
+ setHeader(render(dataSource[_constants.CELL_KEY.PAGE_HEADER]));
94
+ }, [dataSource[_constants.CELL_KEY.PAGE_HEADER]]);
95
+ (0, _ahooks.useDeepCompareLayoutEffect)(function () {
96
+ setContent(render(dataSource[_constants.CELL_KEY.PAGE_CONTENT]));
97
+ }, [dataSource[_constants.CELL_KEY.PAGE_CONTENT]]);
98
+ (0, _ahooks.useDeepCompareLayoutEffect)(function () {
99
+ setFooter(render(dataSource[_constants.CELL_KEY.PAGE_FOOTER]));
100
+ }, [dataSource[_constants.CELL_KEY.PAGE_FOOTER]]);
101
+ (0, _ahooks.useDeepCompareLayoutEffect)(function () {
102
+ var pageModal = (0, _lodash.reduce)(dataSource.children, function (result, _id) {
103
+ if (!PAGE_CELL.includes(_id)) {
104
+ result[_id] = dataSource[_id];
105
+ if (!result.children) {
106
+ result.children = [];
107
+ }
108
+ result.children.push(_id);
109
+ }
110
+ return result;
111
+ }, {});
112
+ setModal(render(pageModal));
113
+ }, [dataSource.children]);
114
+ return /*#__PURE__*/_react.default.createElement("div", {
115
+ id: "page-canvas",
116
+ className: _canvas.default['lc-view-canvas']
117
+ }, /*#__PURE__*/_react.default.createElement(_Wrapper.default, {
118
+ id: _constants.CELL_KEY.PAGE_HEADER,
119
+ getTargetDom: function getTargetDom() {
120
+ return headerRef.current;
121
+ }
122
+ }, /*#__PURE__*/_react.default.createElement("div", {
123
+ ref: headerRef,
124
+ style: {
125
+ width: '100%',
126
+ height: 120,
127
+ backgroundColor: '#d3f261'
128
+ }
129
+ }, header)), /*#__PURE__*/_react.default.createElement(_Wrapper.default, {
130
+ id: _constants.CELL_KEY.PAGE_CONTENT,
131
+ getTargetDom: function getTargetDom() {
132
+ return contentRef.current;
133
+ }
134
+ }, /*#__PURE__*/_react.default.createElement("div", {
135
+ ref: contentRef
136
+ }, content)), /*#__PURE__*/_react.default.createElement(_Wrapper.default, {
137
+ id: _constants.CELL_KEY.PAGE_HEADER,
138
+ getTargetDom: function getTargetDom() {
139
+ return footerRef.current;
140
+ }
141
+ }, /*#__PURE__*/_react.default.createElement("div", {
142
+ ref: footerRef,
143
+ style: {
144
+ width: '100%',
145
+ height: 80,
146
+ backgroundColor: '#69c0ff'
147
+ }
148
+ }, footer)), modal);
149
+ };
150
+ var _default = exports.default = Canvas;
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _classnames = _interopRequireDefault(require("classnames"));
10
+ var _loading = _interopRequireDefault(require("./style/loading.less"));
11
+ var Loading = function Loading() {
12
+ return /*#__PURE__*/_react.default.createElement("div", {
13
+ className: _loading.default['lc-painter-loading']
14
+ }, /*#__PURE__*/_react.default.createElement("div", {
15
+ className: _loading.default['cube']
16
+ }, /*#__PURE__*/_react.default.createElement("div", {
17
+ className: (0, _classnames.default)(_loading.default['side'], _loading.default['side1'])
18
+ }), /*#__PURE__*/_react.default.createElement("div", {
19
+ className: (0, _classnames.default)(_loading.default['side'], _loading.default['side2'])
20
+ }), /*#__PURE__*/_react.default.createElement("div", {
21
+ className: (0, _classnames.default)(_loading.default['side'], _loading.default['side3'])
22
+ }), /*#__PURE__*/_react.default.createElement("div", {
23
+ className: (0, _classnames.default)(_loading.default['side'], _loading.default['side4'])
24
+ }), /*#__PURE__*/_react.default.createElement("div", {
25
+ className: (0, _classnames.default)(_loading.default['side'], _loading.default['side5'])
26
+ }), /*#__PURE__*/_react.default.createElement("div", {
27
+ className: (0, _classnames.default)(_loading.default['side'], _loading.default['side6'])
28
+ })));
29
+ };
30
+ var _default = exports.default = Loading;