@luck-design-biz/luckda 0.0.22 → 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 (251) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +40 -49
  3. package/es/components/Builder/index.js +4 -4
  4. package/es/components/LdAutoForm/index.js +7 -9
  5. package/es/components/LdCard/index.js +5 -6
  6. package/es/components/LdCard/model.js +1 -1
  7. package/es/components/LdCom/index.js +2 -2
  8. package/es/components/LdFormList/index.js +19 -17
  9. package/es/components/LdGrid/index.js +11 -12
  10. package/es/components/LdGrid/model.js +1 -1
  11. package/es/components/LdGridForm/index.js +10 -10
  12. package/es/components/LdGridForm/index.less +7 -7
  13. package/es/components/LdInfoPanel/index.js +2 -2
  14. package/es/components/LdRuntimeCom/index.js +42 -0
  15. package/es/components/LdTree/index.js +3 -4
  16. package/es/components/LdTree/index.less +36 -36
  17. package/es/helper/FromItems.js +1 -1
  18. package/es/helper/action.js +8 -8
  19. package/es/helper/form.js +16 -16
  20. package/es/helper/index.less +7 -7
  21. package/es/helper/ldBuilder.js +1 -1
  22. package/es/helper/ldComBuild.js +4 -4
  23. package/es/index.js +10 -9
  24. package/es/lowcode/constants/api-url.js +2 -0
  25. package/es/lowcode/constants/event-topics.js +23 -0
  26. package/es/lowcode/constants/index.js +12 -0
  27. package/es/lowcode/engine/factory/DataFactory.js +1 -0
  28. package/es/lowcode/engine/meta/button.props.default.json +8 -0
  29. package/es/lowcode/engine/meta/cardlist.props.default.json +10 -0
  30. package/es/lowcode/engine/meta/components/button.json +104 -0
  31. package/es/lowcode/engine/meta/components/card-list.json +143 -0
  32. package/es/lowcode/engine/meta/components/drawer.json +143 -0
  33. package/es/lowcode/engine/meta/components/form.json +116 -0
  34. package/es/lowcode/engine/meta/components/iframe.json +31 -0
  35. package/es/lowcode/engine/meta/components/image.json +113 -0
  36. package/es/lowcode/engine/meta/components/imex.json +81 -0
  37. package/es/lowcode/engine/meta/components/jsx.json +24 -0
  38. package/es/lowcode/engine/meta/components/layout.json +107 -0
  39. package/es/lowcode/engine/meta/components/link.json +111 -0
  40. package/es/lowcode/engine/meta/components/modal.json +120 -0
  41. package/es/lowcode/engine/meta/components/section.json +107 -0
  42. package/es/lowcode/engine/meta/components/split.json +71 -0
  43. package/es/lowcode/engine/meta/components/table.json +161 -0
  44. package/es/lowcode/engine/meta/components/tabs.json +140 -0
  45. package/es/lowcode/engine/meta/components/text.json +65 -0
  46. package/es/lowcode/engine/meta/components/tree.json +156 -0
  47. package/es/lowcode/engine/meta/components-list.json +122 -0
  48. package/es/lowcode/engine/meta/drawer.props.default.json +10 -0
  49. package/es/lowcode/engine/meta/form.props.default.json +5 -0
  50. package/es/lowcode/engine/meta/iframe.props.default.json +3 -0
  51. package/es/lowcode/engine/meta/image.props.default.json +8 -0
  52. package/es/lowcode/engine/meta/imex.props.default.json +4 -0
  53. package/es/lowcode/engine/meta/jsx.props.default.json +1 -0
  54. package/es/lowcode/engine/meta/layout.props.default.json +5 -0
  55. package/es/lowcode/engine/meta/link.props.default.json +6 -0
  56. package/es/lowcode/engine/meta/modal.props.default.json +11 -0
  57. package/es/lowcode/engine/meta/section.props.default.json +9 -0
  58. package/es/lowcode/engine/meta/split.props.default.json +5 -0
  59. package/es/lowcode/engine/meta/table.props.default.json +10 -0
  60. package/es/lowcode/engine/meta/tabs.props.default.json +10 -0
  61. package/es/lowcode/engine/meta/text.props.default.json +4 -0
  62. package/es/lowcode/engine/meta/tree.props.default.json +9 -0
  63. package/es/lowcode/engine/provider/ContextProvider.js +164 -0
  64. package/es/lowcode/engine/provider/EventBusProvider.js +120 -0
  65. package/es/lowcode/engine/tools/dataProcess.js +188 -0
  66. package/es/lowcode/engine/tools/helper.js +4 -0
  67. package/es/lowcode/engine/tools/lcid.js +16 -0
  68. package/es/lowcode/index.js +3 -0
  69. package/es/lowcode/painter/Components.js +104 -0
  70. package/es/lowcode/painter/Design.js +97 -0
  71. package/es/lowcode/painter/I18n.js +5 -0
  72. package/es/lowcode/painter/Outline.js +202 -0
  73. package/es/lowcode/painter/Panel.js +8 -0
  74. package/es/lowcode/painter/Ribbon.js +136 -0
  75. package/es/lowcode/painter/components/PanelItem.js +20 -0
  76. package/es/lowcode/painter/components/RuleInput.js +105 -0
  77. package/es/lowcode/painter/index.js +19 -0
  78. package/es/lowcode/painter/panel-section/LayoutRatio.js +123 -0
  79. package/es/lowcode/painter/panel-section/Radio.js +58 -0
  80. package/es/lowcode/painter/style/components.less +90 -0
  81. package/es/lowcode/painter/style/design.less +38 -0
  82. package/es/lowcode/painter/style/index.less +7 -0
  83. package/es/lowcode/painter/style/layout-ratio.less +51 -0
  84. package/es/lowcode/painter/style/outline.less +26 -0
  85. package/es/lowcode/painter/style/panel-item.less +21 -0
  86. package/es/lowcode/painter/style/panel.less +5 -0
  87. package/es/lowcode/painter/style/radio.less +24 -0
  88. package/es/lowcode/painter/style/ribbon.less +4 -0
  89. package/es/lowcode/painter/style/rule-input.less +13 -0
  90. package/es/lowcode/view/Canvas.js +135 -0
  91. package/es/lowcode/view/Loading.js +23 -0
  92. package/es/lowcode/view/Page.js +55 -0
  93. package/es/lowcode/view/index.js +18 -0
  94. package/es/lowcode/view/lc-components/Box/index.js +21 -0
  95. package/es/lowcode/view/lc-components/Button/index.js +37 -0
  96. package/es/lowcode/view/lc-components/CardList/index.js +20 -0
  97. package/es/lowcode/view/lc-components/Dialog/index.js +50 -0
  98. package/es/lowcode/view/lc-components/Dialog/index.less +3 -0
  99. package/es/lowcode/view/lc-components/Drawer/index.js +46 -0
  100. package/es/lowcode/view/lc-components/Form/index.js +20 -0
  101. package/es/lowcode/view/lc-components/Iframe/index.js +20 -0
  102. package/es/lowcode/view/lc-components/ImEx/index.js +20 -0
  103. package/es/lowcode/view/lc-components/Image/index.js +20 -0
  104. package/es/lowcode/view/lc-components/JSX/index.js +20 -0
  105. package/es/lowcode/view/lc-components/Layout/index.js +24 -0
  106. package/es/lowcode/view/lc-components/Link/index.js +20 -0
  107. package/es/lowcode/view/lc-components/Section/index.js +34 -0
  108. package/es/lowcode/view/lc-components/Split/index.js +21 -0
  109. package/es/lowcode/view/lc-components/Table/index.js +23 -0
  110. package/es/lowcode/view/lc-components/Tabs/index.js +21 -0
  111. package/es/lowcode/view/lc-components/Text/index.js +23 -0
  112. package/es/lowcode/view/lc-components/Tree/index.js +20 -0
  113. package/es/lowcode/view/lc-components/Wrapper.js +45 -0
  114. package/es/lowcode/view/style/canvas.less +5 -0
  115. package/es/lowcode/view/style/loading.less +84 -0
  116. package/es/lowcode/view/style/page.less +6 -0
  117. package/es/services.js +1 -1
  118. package/es/upload/Form/gridForm.js +29 -7
  119. package/es/upload/Form/index.js +1 -1
  120. package/es/upload/Form/index.less +7 -7
  121. package/es/upload/FormItem/index.js +30 -18
  122. package/es/upload/index.js +3 -3
  123. package/es/utils/action.js +1 -1
  124. package/es/utils/form.js +26 -26
  125. package/es/utils/grid.js +22 -26
  126. package/es/utils/index.js +3 -3
  127. package/lib/components/Builder/index.js +3 -5
  128. package/lib/components/LdAutoForm/index.js +5 -8
  129. package/lib/components/LdCard/index.js +5 -7
  130. package/lib/components/LdCom/index.js +6 -11
  131. package/lib/components/LdFormList/index.js +15 -13
  132. package/lib/components/LdGrid/index.js +10 -12
  133. package/lib/components/LdGridForm/index.js +6 -7
  134. package/lib/components/LdGridForm/index.less +7 -7
  135. package/lib/components/LdInfoPanel/index.js +2 -3
  136. package/lib/components/LdPop/index.js +2 -4
  137. package/lib/components/LdRuntimeCom/index.js +49 -0
  138. package/lib/components/LdTree/index.js +2 -4
  139. package/lib/components/LdTree/index.less +36 -36
  140. package/lib/helper/FromItems.js +15 -29
  141. package/lib/helper/action.js +9 -11
  142. package/lib/helper/form.js +18 -20
  143. package/lib/helper/index.less +7 -7
  144. package/lib/helper/ldBuilder.js +1 -2
  145. package/lib/helper/ldComBuild.js +7 -11
  146. package/lib/index.js +9 -1
  147. package/lib/lowcode/constants/api-url.js +8 -0
  148. package/lib/lowcode/constants/event-topics.js +29 -0
  149. package/lib/lowcode/constants/index.js +18 -0
  150. package/lib/lowcode/engine/factory/DataFactory.js +3 -0
  151. package/lib/lowcode/engine/meta/button.props.default.json +8 -0
  152. package/lib/lowcode/engine/meta/cardlist.props.default.json +10 -0
  153. package/lib/lowcode/engine/meta/components/button.json +104 -0
  154. package/lib/lowcode/engine/meta/components/card-list.json +143 -0
  155. package/lib/lowcode/engine/meta/components/drawer.json +143 -0
  156. package/lib/lowcode/engine/meta/components/form.json +116 -0
  157. package/lib/lowcode/engine/meta/components/iframe.json +31 -0
  158. package/lib/lowcode/engine/meta/components/image.json +113 -0
  159. package/lib/lowcode/engine/meta/components/imex.json +81 -0
  160. package/lib/lowcode/engine/meta/components/jsx.json +24 -0
  161. package/lib/lowcode/engine/meta/components/layout.json +107 -0
  162. package/lib/lowcode/engine/meta/components/link.json +111 -0
  163. package/lib/lowcode/engine/meta/components/modal.json +120 -0
  164. package/lib/lowcode/engine/meta/components/section.json +107 -0
  165. package/lib/lowcode/engine/meta/components/split.json +71 -0
  166. package/lib/lowcode/engine/meta/components/table.json +161 -0
  167. package/lib/lowcode/engine/meta/components/tabs.json +140 -0
  168. package/lib/lowcode/engine/meta/components/text.json +65 -0
  169. package/lib/lowcode/engine/meta/components/tree.json +156 -0
  170. package/lib/lowcode/engine/meta/components-list.json +122 -0
  171. package/lib/lowcode/engine/meta/drawer.props.default.json +10 -0
  172. package/lib/lowcode/engine/meta/form.props.default.json +5 -0
  173. package/lib/lowcode/engine/meta/iframe.props.default.json +3 -0
  174. package/lib/lowcode/engine/meta/image.props.default.json +8 -0
  175. package/lib/lowcode/engine/meta/imex.props.default.json +4 -0
  176. package/lib/lowcode/engine/meta/jsx.props.default.json +1 -0
  177. package/lib/lowcode/engine/meta/layout.props.default.json +5 -0
  178. package/lib/lowcode/engine/meta/link.props.default.json +6 -0
  179. package/lib/lowcode/engine/meta/modal.props.default.json +11 -0
  180. package/lib/lowcode/engine/meta/section.props.default.json +9 -0
  181. package/lib/lowcode/engine/meta/split.props.default.json +5 -0
  182. package/lib/lowcode/engine/meta/table.props.default.json +10 -0
  183. package/lib/lowcode/engine/meta/tabs.props.default.json +10 -0
  184. package/lib/lowcode/engine/meta/text.props.default.json +4 -0
  185. package/lib/lowcode/engine/meta/tree.props.default.json +9 -0
  186. package/lib/lowcode/engine/provider/ContextProvider.js +172 -0
  187. package/lib/lowcode/engine/provider/EventBusProvider.js +128 -0
  188. package/lib/lowcode/engine/tools/dataProcess.js +201 -0
  189. package/lib/lowcode/engine/tools/helper.js +11 -0
  190. package/lib/lowcode/engine/tools/lcid.js +22 -0
  191. package/lib/lowcode/index.js +20 -0
  192. package/lib/lowcode/painter/Components.js +112 -0
  193. package/lib/lowcode/painter/Design.js +105 -0
  194. package/lib/lowcode/painter/I18n.js +12 -0
  195. package/lib/lowcode/painter/Outline.js +210 -0
  196. package/lib/lowcode/painter/Panel.js +16 -0
  197. package/lib/lowcode/painter/Ribbon.js +151 -0
  198. package/lib/lowcode/painter/components/PanelItem.js +26 -0
  199. package/lib/lowcode/painter/components/RuleInput.js +112 -0
  200. package/lib/lowcode/painter/index.js +26 -0
  201. package/lib/lowcode/painter/panel-section/LayoutRatio.js +131 -0
  202. package/lib/lowcode/painter/panel-section/Radio.js +65 -0
  203. package/lib/lowcode/painter/style/components.less +90 -0
  204. package/lib/lowcode/painter/style/design.less +38 -0
  205. package/lib/lowcode/painter/style/index.less +7 -0
  206. package/lib/lowcode/painter/style/layout-ratio.less +51 -0
  207. package/lib/lowcode/painter/style/outline.less +26 -0
  208. package/lib/lowcode/painter/style/panel-item.less +21 -0
  209. package/lib/lowcode/painter/style/panel.less +5 -0
  210. package/lib/lowcode/painter/style/radio.less +24 -0
  211. package/lib/lowcode/painter/style/ribbon.less +4 -0
  212. package/lib/lowcode/painter/style/rule-input.less +13 -0
  213. package/lib/lowcode/view/Canvas.js +150 -0
  214. package/lib/lowcode/view/Loading.js +30 -0
  215. package/lib/lowcode/view/Page.js +63 -0
  216. package/lib/lowcode/view/index.js +25 -0
  217. package/lib/lowcode/view/lc-components/Box/index.js +29 -0
  218. package/lib/lowcode/view/lc-components/Button/index.js +45 -0
  219. package/lib/lowcode/view/lc-components/CardList/index.js +28 -0
  220. package/lib/lowcode/view/lc-components/Dialog/index.js +58 -0
  221. package/lib/lowcode/view/lc-components/Dialog/index.less +3 -0
  222. package/lib/lowcode/view/lc-components/Drawer/index.js +54 -0
  223. package/lib/lowcode/view/lc-components/Form/index.js +28 -0
  224. package/lib/lowcode/view/lc-components/Iframe/index.js +28 -0
  225. package/lib/lowcode/view/lc-components/ImEx/index.js +28 -0
  226. package/lib/lowcode/view/lc-components/Image/index.js +28 -0
  227. package/lib/lowcode/view/lc-components/JSX/index.js +28 -0
  228. package/lib/lowcode/view/lc-components/Layout/index.js +32 -0
  229. package/lib/lowcode/view/lc-components/Link/index.js +28 -0
  230. package/lib/lowcode/view/lc-components/Section/index.js +42 -0
  231. package/lib/lowcode/view/lc-components/Split/index.js +29 -0
  232. package/lib/lowcode/view/lc-components/Table/index.js +31 -0
  233. package/lib/lowcode/view/lc-components/Tabs/index.js +29 -0
  234. package/lib/lowcode/view/lc-components/Text/index.js +31 -0
  235. package/lib/lowcode/view/lc-components/Tree/index.js +28 -0
  236. package/lib/lowcode/view/lc-components/Wrapper.js +52 -0
  237. package/lib/lowcode/view/style/canvas.less +5 -0
  238. package/lib/lowcode/view/style/loading.less +84 -0
  239. package/lib/lowcode/view/style/page.less +6 -0
  240. package/lib/upload/Form/gridForm.js +27 -6
  241. package/lib/upload/Form/index.js +1 -2
  242. package/lib/upload/Form/index.less +7 -7
  243. package/lib/upload/FormItem/index.js +30 -19
  244. package/lib/upload/GridCell/index.js +1 -2
  245. package/lib/utils/form.js +26 -29
  246. package/lib/utils/grid.js +23 -28
  247. package/lowcode.js +1 -0
  248. package/package.json +157 -78
  249. package/upload.js +1 -1
  250. package/utils.js +1 -1
  251. package/README.zh-CN.md +0 -51
@@ -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,135 @@
1
+ import _regeneratorRuntime from "@babel/runtime/helpers/esm/regeneratorRuntime";
2
+ import _asyncToGenerator from "@babel/runtime/helpers/esm/asyncToGenerator";
3
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
4
+ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
5
+ var _excluded = ["props", "children"];
6
+ import React, { useRef, useState } from 'react';
7
+ import { dynamic } from 'umi';
8
+ import { useMemoizedFn, useDeepCompareLayoutEffect } from 'ahooks';
9
+ import { reduce } from 'lodash';
10
+ import Wrapper from "./lc-components/Wrapper";
11
+ import { CELL_KEY } from "../constants";
12
+ import styles from "./style/canvas.less";
13
+ var PAGE_CELL = [CELL_KEY.PAGE_HEADER, CELL_KEY.PAGE_CONTENT, CELL_KEY.PAGE_FOOTER];
14
+ var Canvas = function Canvas(_ref) {
15
+ var dataSource = _ref.dataSource;
16
+ console.log('dataSource', dataSource);
17
+ var headerRef = useRef();
18
+ var contentRef = useRef();
19
+ var footerRef = useRef();
20
+ var _useState = useState(null),
21
+ _useState2 = _slicedToArray(_useState, 2),
22
+ header = _useState2[0],
23
+ setHeader = _useState2[1];
24
+ var _useState3 = useState(null),
25
+ _useState4 = _slicedToArray(_useState3, 2),
26
+ content = _useState4[0],
27
+ setContent = _useState4[1];
28
+ var _useState5 = useState(null),
29
+ _useState6 = _slicedToArray(_useState5, 2),
30
+ footer = _useState6[0],
31
+ setFooter = _useState6[1];
32
+ var _useState7 = useState(null),
33
+ _useState8 = _slicedToArray(_useState7, 2),
34
+ modal = _useState8[0],
35
+ setModal = _useState8[1];
36
+ var render = useMemoizedFn(function (_ref2) {
37
+ var props = _ref2.props,
38
+ children = _ref2.children,
39
+ childrenMap = _objectWithoutProperties(_ref2, _excluded);
40
+ if (props && !PAGE_CELL.includes(props.id)) {
41
+ var Comp = dynamic({
42
+ loader: function () {
43
+ var _loader = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
44
+ var _yield$import, _Comp;
45
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
46
+ while (1) switch (_context.prev = _context.next) {
47
+ case 0:
48
+ _context.next = 2;
49
+ return import("./lc-components/".concat(props.type));
50
+ case 2:
51
+ _yield$import = _context.sent;
52
+ _Comp = _yield$import.default;
53
+ return _context.abrupt("return", _Comp);
54
+ case 5:
55
+ case "end":
56
+ return _context.stop();
57
+ }
58
+ }, _callee);
59
+ }));
60
+ function loader() {
61
+ return _loader.apply(this, arguments);
62
+ }
63
+ return loader;
64
+ }()
65
+ });
66
+ return /*#__PURE__*/React.createElement(Comp, {
67
+ id: props.id,
68
+ lcdata: props
69
+ }, (children || []).map(function (_id) {
70
+ return render(childrenMap[_id]);
71
+ }));
72
+ }
73
+ return (children || []).map(function (_id) {
74
+ return render(childrenMap[_id]);
75
+ });
76
+ });
77
+ useDeepCompareLayoutEffect(function () {
78
+ setHeader(render(dataSource[CELL_KEY.PAGE_HEADER]));
79
+ }, [dataSource[CELL_KEY.PAGE_HEADER]]);
80
+ useDeepCompareLayoutEffect(function () {
81
+ setContent(render(dataSource[CELL_KEY.PAGE_CONTENT]));
82
+ }, [dataSource[CELL_KEY.PAGE_CONTENT]]);
83
+ useDeepCompareLayoutEffect(function () {
84
+ setFooter(render(dataSource[CELL_KEY.PAGE_FOOTER]));
85
+ }, [dataSource[CELL_KEY.PAGE_FOOTER]]);
86
+ useDeepCompareLayoutEffect(function () {
87
+ var pageModal = reduce(dataSource.children, function (result, _id) {
88
+ if (!PAGE_CELL.includes(_id)) {
89
+ result[_id] = dataSource[_id];
90
+ if (!result.children) {
91
+ result.children = [];
92
+ }
93
+ result.children.push(_id);
94
+ }
95
+ return result;
96
+ }, {});
97
+ setModal(render(pageModal));
98
+ }, [dataSource.children]);
99
+ return /*#__PURE__*/React.createElement("div", {
100
+ id: "page-canvas",
101
+ className: styles['lc-view-canvas']
102
+ }, /*#__PURE__*/React.createElement(Wrapper, {
103
+ id: CELL_KEY.PAGE_HEADER,
104
+ getTargetDom: function getTargetDom() {
105
+ return headerRef.current;
106
+ }
107
+ }, /*#__PURE__*/React.createElement("div", {
108
+ ref: headerRef,
109
+ style: {
110
+ width: '100%',
111
+ height: 120,
112
+ backgroundColor: '#d3f261'
113
+ }
114
+ }, header)), /*#__PURE__*/React.createElement(Wrapper, {
115
+ id: CELL_KEY.PAGE_CONTENT,
116
+ getTargetDom: function getTargetDom() {
117
+ return contentRef.current;
118
+ }
119
+ }, /*#__PURE__*/React.createElement("div", {
120
+ ref: contentRef
121
+ }, content)), /*#__PURE__*/React.createElement(Wrapper, {
122
+ id: CELL_KEY.PAGE_HEADER,
123
+ getTargetDom: function getTargetDom() {
124
+ return footerRef.current;
125
+ }
126
+ }, /*#__PURE__*/React.createElement("div", {
127
+ ref: footerRef,
128
+ style: {
129
+ width: '100%',
130
+ height: 80,
131
+ backgroundColor: '#69c0ff'
132
+ }
133
+ }, footer)), modal);
134
+ };
135
+ export default Canvas;
@@ -0,0 +1,23 @@
1
+ import React from 'react';
2
+ import classNames from 'classnames';
3
+ import styles from "./style/loading.less";
4
+ var Loading = function Loading() {
5
+ return /*#__PURE__*/React.createElement("div", {
6
+ className: styles['lc-painter-loading']
7
+ }, /*#__PURE__*/React.createElement("div", {
8
+ className: styles['cube']
9
+ }, /*#__PURE__*/React.createElement("div", {
10
+ className: classNames(styles['side'], styles['side1'])
11
+ }), /*#__PURE__*/React.createElement("div", {
12
+ className: classNames(styles['side'], styles['side2'])
13
+ }), /*#__PURE__*/React.createElement("div", {
14
+ className: classNames(styles['side'], styles['side3'])
15
+ }), /*#__PURE__*/React.createElement("div", {
16
+ className: classNames(styles['side'], styles['side4'])
17
+ }), /*#__PURE__*/React.createElement("div", {
18
+ className: classNames(styles['side'], styles['side5'])
19
+ }), /*#__PURE__*/React.createElement("div", {
20
+ className: classNames(styles['side'], styles['side6'])
21
+ })));
22
+ };
23
+ export default Loading;
@@ -0,0 +1,55 @@
1
+ import _extends from "@babel/runtime/helpers/esm/extends";
2
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
3
+ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
4
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
5
+ var _excluded = ["pageCode", "className"];
6
+ import React, { useRef, useEffect, forwardRef } from 'react';
7
+ import { useMemoizedFn, useBoolean } from 'ahooks';
8
+ import classNames from 'classnames';
9
+ import { useLDContext } from "../engine/provider/ContextProvider";
10
+ import Loading from "./Loading";
11
+ import Wrapper from "./lc-components/Wrapper";
12
+ import Canvas from "./Canvas";
13
+ import { decompress, compress } from "../engine/tools/dataProcess";
14
+ import { CELL_KEY } from "../constants";
15
+ import styles from "./style/page.less";
16
+ var mock = function mock(_pageCode) {
17
+ return new Promise(function (resolve) {
18
+ setTimeout(function () {
19
+ var data = 'ᯡࠣ䂼྆ڑÙ⁅䁆䞠䌣䰪ぞ婈Ø䀦䉑Ŝ持䀥ດ⠦榠⍼Ⲉᗣᠱ嵜䐠׆Ⱐॼ哘ᄳࡠ֕惂ᬠ౪Ӕ沥尡㸴Ƭ䎰嫀䗠ވ䀻▯ἰ湬⥒ᓡᰀ᪡㱲璻䞠ೣⰊ焥⍂へ僸簠ⷌ)䔠ԂࠡⰠಢ㍬[婿ԯဧデ匒<̰N䁞椌狲⎣℁ࡈ琤ᶡ৅桎睑砢◛㶤ს㕍Ʃ䅌欫㊓㢛粠᙭⃀㤠ȉᑤզ愕ۦ厁䷅ᜧ㱯䀦密䭋氠㞘㵵朞礒⺛㺕婐㰵占マ១犚弐x㙁䘸㮱劐ش೮䈈J毟䈦Ⳙీฺ㐠槬⁽Ჰ栰帿࿠٠䂠㐳楂唏៣爭ᡘℼ撘䑼㴷ᨀ᭖䶀㠤嫯䐢䌵n皹᪑ᣬ䭅曢冪富ધ䤲瘠೯嗰ᾕ㍿䎋㪣⣷⟕䃎䌪㟨媽⽸㝐墎㲂暘抮ⴳ₂†ٳõᶢ㹕ㄢà㵠g❌L檪䠨晴⸨ⶱ淛္≢曈廳ܥ䁀⊸ᱥႫ帲墛ᷯ猦↕埄㩀磫ῠ琉Ẁ崆㴮梌棖巶翖㈈䏕䒒⪭掩犕὚唹䠽䊗ࣾᅡ爌䩛㓧࿠ⲑ㲥Ꮸ®㏾❰僷戦熂濛紎玈㋻్羜㺗㸌᠁猑℄畛㶋泧₀¥毗䚼⬦Сღ䀮劶☔⟫㢯਎㵏Ⰺ渍཮װ爊㱏ᘇ給㮄̋ᐆ͈䇑෫˅ࠢ⑰樼↫⦉ࡋᖃ䌍ࠤ效✿䃫༼䂁ߏ籈涎㑽ᗎ甥ᙉ抸咈ǰ䪠ˢᛦ儏ⰲ㐹೺浦☉Ȱ䗁䤘ⲇ沞ⵑ梾䣡炕߄哾ߢ^ສࣀ旔▨॒⍨夿੒ᠷ䦩焲╨ᥖ❒—囓恦 ⊱ᯮ㥝ဤ羊}璀̰塎㎥⥸ᗸၠ㢿΀⨾⋠㮾≴璺碠⋄喵૊哵䃝礔۔垵䫚囵棜ゥ὜᠙⣖䞮ွ⌵哄ω䀵Ⳇ捜䐯䤪ㅦ⡊㕦欐硤娪Ф⥪㥥⢊㽸䔙ᓯચɳ嫬怷ʚ‫橔²ᵼ嚻᝻৷剛䆃塯彁Ⱟ䈕㺿啴૰˻磡ᠯ㻿喀亾䮲眝囕ົṖ⛘䵕曍ᐠ';
20
+ resolve(data);
21
+ }, 400);
22
+ });
23
+ };
24
+ var LCPage = /*#__PURE__*/forwardRef(function (_ref2, ref) {
25
+ var pageCode = _ref2.pageCode,
26
+ className = _ref2.className,
27
+ props = _objectWithoutProperties(_ref2, _excluded);
28
+ var _ref = useRef(null);
29
+ var _rootRef = ref || _ref;
30
+ var context = useLDContext();
31
+ var _useBoolean = useBoolean(true),
32
+ _useBoolean2 = _slicedToArray(_useBoolean, 2),
33
+ loading = _useBoolean2[0],
34
+ setFalse = _useBoolean2[1].setFalse;
35
+ useEffect(function () {
36
+ context._pageCode.current = pageCode;
37
+ mock(pageCode).then(function (pageData) {
38
+ context._pageData.current = decompress(pageData);
39
+ setFalse();
40
+ });
41
+ }, []);
42
+ var getTargetDom = useMemoizedFn(function () {
43
+ return _rootRef.current;
44
+ });
45
+ return /*#__PURE__*/React.createElement(Wrapper, {
46
+ id: CELL_KEY.PAGE_ROOT,
47
+ getTargetDom: getTargetDom
48
+ }, /*#__PURE__*/React.createElement("div", _extends({
49
+ ref: _rootRef,
50
+ className: classNames(styles['lc-view-page'], _defineProperty({}, className, !!className))
51
+ }, props), loading ? /*#__PURE__*/React.createElement(Loading, null) : /*#__PURE__*/React.createElement(Canvas, {
52
+ dataSource: context.pageData
53
+ })));
54
+ });
55
+ export default LCPage;
@@ -0,0 +1,18 @@
1
+ import _extends from "@babel/runtime/helpers/esm/extends";
2
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
3
+ var _excluded = ["pageCode"];
4
+ import React from 'react';
5
+ import EventBusProvider from "../engine/provider/EventBusProvider";
6
+ import ContextProvider from "../engine/provider/ContextProvider";
7
+ import Page from "./Page";
8
+ import { RUNTIME } from "../constants/index";
9
+ var View = function View(_ref) {
10
+ var pageCode = _ref.pageCode,
11
+ props = _objectWithoutProperties(_ref, _excluded);
12
+ return /*#__PURE__*/React.createElement(EventBusProvider, {
13
+ runtime: RUNTIME.LIVE
14
+ }, /*#__PURE__*/React.createElement(ContextProvider, null, /*#__PURE__*/React.createElement(Page, _extends({
15
+ pageCode: pageCode
16
+ }, props))));
17
+ };
18
+ export default View;
@@ -0,0 +1,21 @@
1
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
2
+ var _excluded = ["id", "children"];
3
+ import React, { useRef } from 'react';
4
+ import { useMemoizedFn } from 'ahooks';
5
+ import Wrapper from "../Wrapper";
6
+ var LCBox = function LCBox(_ref) {
7
+ var id = _ref.id,
8
+ children = _ref.children,
9
+ props = _objectWithoutProperties(_ref, _excluded);
10
+ var ref = useRef();
11
+ var getTargetDom = useMemoizedFn(function () {
12
+ return ref.current;
13
+ });
14
+ return /*#__PURE__*/React.createElement(Wrapper, {
15
+ id: id,
16
+ getTargetDom: getTargetDom
17
+ }, /*#__PURE__*/React.createElement("div", {
18
+ ref: ref
19
+ }, "LCBox", children));
20
+ };
21
+ export default LCBox;
@@ -0,0 +1,37 @@
1
+ import _extends from "@babel/runtime/helpers/esm/extends";
2
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
3
+ var _excluded = ["id", "children"];
4
+ import React, { useRef } from 'react';
5
+ import { useMemoizedFn } from 'ahooks';
6
+ import { useLDContext } from "../../../engine/provider/ContextProvider";
7
+ import { Button } from 'luck-design/antd';
8
+ import Wrapper from "../Wrapper";
9
+ import { RUNTIME } from "../../../constants";
10
+ var LCButton = function LCButton(_ref) {
11
+ var id = _ref.id,
12
+ children = _ref.children,
13
+ props = _objectWithoutProperties(_ref, _excluded);
14
+ var context = useLDContext();
15
+ var ref = useRef();
16
+ var getTargetDom = useMemoizedFn(function () {
17
+ return ref.current.buttonNode;
18
+ });
19
+ var handleClick = useMemoizedFn(function (e) {
20
+ if (context.runtime !== RUNTIME.LIVE) {
21
+ e.preventDefault();
22
+ return;
23
+ }
24
+ console.log('click', context);
25
+ context.$publisher(context.topics.COMPONENT_MOUNT, {
26
+ id: id
27
+ });
28
+ });
29
+ return /*#__PURE__*/React.createElement(Wrapper, {
30
+ id: id,
31
+ getTargetDom: getTargetDom
32
+ }, /*#__PURE__*/React.createElement(Button, _extends({
33
+ ref: ref,
34
+ onClick: handleClick
35
+ }, props), "LCButton-", id));
36
+ };
37
+ export default LCButton;
@@ -0,0 +1,20 @@
1
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
2
+ var _excluded = ["id"];
3
+ import React, { useRef } from 'react';
4
+ import { useMemoizedFn } from 'ahooks';
5
+ import Wrapper from "../Wrapper";
6
+ var LCCardList = function LCCardList(_ref) {
7
+ var id = _ref.id,
8
+ props = _objectWithoutProperties(_ref, _excluded);
9
+ var ref = useRef();
10
+ var getTargetDom = useMemoizedFn(function () {
11
+ return ref.current;
12
+ });
13
+ return /*#__PURE__*/React.createElement(Wrapper, {
14
+ id: id,
15
+ getTargetDom: getTargetDom
16
+ }, /*#__PURE__*/React.createElement("div", {
17
+ ref: ref
18
+ }, "LCCardList"));
19
+ };
20
+ export default LCCardList;
@@ -0,0 +1,50 @@
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
+ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
3
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
4
+ var _excluded = ["id", "children"];
5
+ import React, { useRef, useImperativeHandle } from 'react';
6
+ import { useMemoizedFn, useBoolean } from 'ahooks';
7
+ import { Modal } from 'luck-design/antd';
8
+ import classNames from 'classnames';
9
+ import { useLDContext } from "../../../engine/provider/ContextProvider";
10
+ import { CELL_KEY, RUNTIME } from "../../../constants";
11
+ import Wrapper from "../Wrapper";
12
+ import styles from "./index.less";
13
+ var LCDialog = function LCDialog(_ref) {
14
+ var id = _ref.id,
15
+ children = _ref.children,
16
+ props = _objectWithoutProperties(_ref, _excluded);
17
+ var apiRef = useRef();
18
+ var context = useLDContext();
19
+ var _useBoolean = useBoolean(false),
20
+ _useBoolean2 = _slicedToArray(_useBoolean, 2),
21
+ open = _useBoolean2[0],
22
+ _useBoolean2$ = _useBoolean2[1],
23
+ setTrue = _useBoolean2$.setTrue,
24
+ setFalse = _useBoolean2$.setFalse,
25
+ toggle = _useBoolean2$.toggle;
26
+ var getTargetDom = useMemoizedFn(function () {
27
+ return (context.runtime === RUNTIME.DESIGN ? context.componentMap.get(CELL_KEY.PAGE_ROOT).dom : document).getElementsByClassName('ant-modal-content')[0];
28
+ });
29
+ useImperativeHandle(apiRef, function () {
30
+ return {
31
+ open: open,
32
+ doOpen: setTrue,
33
+ doClose: setFalse,
34
+ toggle: toggle
35
+ };
36
+ });
37
+ return /*#__PURE__*/React.createElement(Wrapper, {
38
+ id: id,
39
+ getTargetDom: getTargetDom,
40
+ api: apiRef
41
+ }, /*#__PURE__*/React.createElement(Modal, {
42
+ visible: open,
43
+ getContainer: context.runtime !== RUNTIME.DESIGN,
44
+ wrapClassName: classNames(styles['lc-component-modal-wrapper'], _defineProperty({}, styles['runtime-design'], context.runtime === RUNTIME.DESIGN)),
45
+ maskStyle: {
46
+ position: context.runtime !== RUNTIME.DESIGN ? 'fixed' : 'absolute'
47
+ }
48
+ }, /*#__PURE__*/React.createElement("div", null, "LCDialog-", id), children));
49
+ };
50
+ export default LCDialog;
@@ -0,0 +1,3 @@
1
+ .lc-component-modal-wrapper.runtime-design {
2
+ position: absolute !important;
3
+ }