@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,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
+ }