diff --git a/README.md b/README.md
index 959c6ba..91cb825 100644
--- a/README.md
+++ b/README.md
@@ -90,6 +90,10 @@ JSON.stringify(
.replace(/\"/g, "'")
```
+## 部分功能演示
+
+[![RHfBbn.gif](https://z3.ax1x.com/2021/07/07/RHfBbn.gif)](https://imgtu.com/i/RHfBbn)
+
## 浏览器支持
本地开发推荐使用`Chrome 80+` 浏览器
diff --git a/components.d.ts b/components.d.ts
index 12076a7..5fab99d 100644
--- a/components.d.ts
+++ b/components.d.ts
@@ -13,10 +13,7 @@ declare module 'vue' {
ElDropdown: typeof import('element-plus/es/el-dropdown')['default']
ElDropdownItem: typeof import('element-plus/es/el-dropdown-item')['default']
ElDropdownMenu: typeof import('element-plus/es/el-dropdown-menu')['default']
- ElForm: typeof import('element-plus/es/el-form')['default']
- ElFormItem: typeof import('element-plus/es/el-form-item')['default']
ElHeader: typeof import('element-plus/es/el-header')['default']
- ElInput: typeof import('element-plus/es/el-input')['default']
ElMain: typeof import('element-plus/es/el-main')['default']
ElPopconfirm: typeof import('element-plus/es/el-popconfirm')['default']
ElPopover: typeof import('element-plus/es/el-popover')['default']
diff --git a/package.json b/package.json
index 814fd10..f3be8a3 100644
--- a/package.json
+++ b/package.json
@@ -20,12 +20,12 @@
"prepare": "husky install"
},
"dependencies": {
- "@vant/touch-emulator": "^1.3.0",
- "@vueuse/core": "^5.0.3",
- "@vueuse/integrations": "^5.0.3",
+ "@vant/touch-emulator": "^1.3.1",
+ "@vueuse/core": "^5.1.3",
+ "@vueuse/integrations": "^5.1.3",
"animate.css": "^4.1.1",
"axios": "^0.21.1",
- "dayjs": "^1.10.5",
+ "dayjs": "^1.10.6",
"dexie": "^3.0.3",
"element-plus": "1.0.2-beta.54",
"lodash": "^4.17.21",
@@ -44,8 +44,8 @@
"@commitlint/cli": "^12.1.4",
"@commitlint/config-conventional": "^12.1.4",
"@types/node": "^16.0.0",
- "@typescript-eslint/eslint-plugin": "^4.28.1",
- "@typescript-eslint/parser": "^4.28.1",
+ "@typescript-eslint/eslint-plugin": "^4.28.2",
+ "@typescript-eslint/parser": "^4.28.2",
"@vitejs/plugin-legacy": "^1.4.3",
"@vitejs/plugin-vue": "^1.2.4",
"@vitejs/plugin-vue-jsx": "^1.1.6",
@@ -58,9 +58,9 @@
"eslint-config-prettier": "^8.3.0",
"eslint-plugin-import": "^2.23.4",
"eslint-plugin-prettier": "^3.4.0",
- "eslint-plugin-vue": "^7.12.1",
+ "eslint-plugin-vue": "^7.13.0",
"gh-pages": "^3.2.3",
- "husky": "^7.0.0",
+ "husky": "^7.0.1",
"lint-staged": "^11.0.0",
"prettier": "^2.3.2",
"pretty-quick": "^3.1.1",
@@ -70,11 +70,11 @@
"stylelint-config-standard": "^22.0.0",
"stylelint-order": "^4.1.0",
"typescript": "^4.3.5",
- "vite": "2.3.8",
- "vite-plugin-components": "^0.12.0",
+ "vite": "2.4.1",
+ "vite-plugin-components": "^0.12.2",
"vite-plugin-style-import": "^1.0.1",
- "vite-plugin-windicss": "^1.2.0",
- "vue-eslint-parser": "^7.7.2",
+ "vite-plugin-windicss": "^1.2.4",
+ "vue-eslint-parser": "^7.8.0",
"vue-tsc": "^0.2.0",
"windicss": "^3.1.4"
},
diff --git a/preview/views/comp-render.tsx b/preview/views/comp-render.tsx
index 29bdde9..317431e 100644
--- a/preview/views/comp-render.tsx
+++ b/preview/views/comp-render.tsx
@@ -1,13 +1,13 @@
/*
* @Author: 卜启缘
* @Date: 2021-05-04 05:36:58
- * @LastEditTime: 2021-07-04 17:21:34
+ * @LastEditTime: 2021-07-06 23:51:26
* @LastEditors: 卜启缘
* @Description:
* @FilePath: \vite-vue3-lowcode\preview\views\comp-render.tsx
*/
import { defineComponent, PropType } from 'vue'
-import type { VisualEditorBlockData, VisualEditorConfig } from '@/visual-editor/visual-editor.utils'
+import type { VisualEditorBlockData } from '@/visual-editor/visual-editor.utils'
import { visualConfig } from '@/visual.config'
export default defineComponent({
@@ -21,7 +21,7 @@ export default defineComponent({
setup(props) {
return () =>
visualConfig.componentMap[props.element.componentKey].render({
- size: {},
+ styles: props.element.styles || {},
props: props.element.props || {},
model: {},
block: props.element,
diff --git a/src/packages/base-widgets/button/index.tsx b/src/packages/base-widgets/button/index.tsx
index 5042e67..9f5afef 100644
--- a/src/packages/base-widgets/button/index.tsx
+++ b/src/packages/base-widgets/button/index.tsx
@@ -12,18 +12,13 @@ export default {
moduleName: 'baseWidgets',
label: '按钮',
preview: () => ,
- render: ({ props, block, size }) => {
+ render: ({ props, block, styles }) => {
const { registerRef } = useGlobalProperties()
return (
-
+
+
+
)
},
resize: {
diff --git a/src/packages/base-widgets/checkbox/index.tsx b/src/packages/base-widgets/checkbox/index.tsx
index 4e5d11c..a18f628 100644
--- a/src/packages/base-widgets/checkbox/index.tsx
+++ b/src/packages/base-widgets/checkbox/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-07-04 16:50:19
+ * @LastEditTime: 2021-07-07 10:54:50
* @LastEditors: 卜启缘
* @Description: 表单项类型 - 复选框
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\checkbox\index.tsx
@@ -32,7 +32,7 @@ export default {
),
- render: ({ size, block, props }) => {
+ render: ({ styles, block, props }) => {
const { registerRef } = useGlobalProperties()
const state = reactive({
@@ -41,29 +41,28 @@ export default {
})
return (
- (
- registerRef(el, block._vid)}
- {...props}
- v-model={state.checkList}
- >
- {props.options?.map((item) => (
-
- {item.label}
-
- ))}
-
- )
- }}
- />
+
+ (
+ registerRef(el, block._vid)}
+ {...props}
+ v-model={state.checkList}
+ >
+ {props.options?.map((item) => (
+
+ {item.label}
+
+ ))}
+
+ )
+ }}
+ />
+
)
},
props: {
diff --git a/src/packages/base-widgets/datetimePicker/index.tsx b/src/packages/base-widgets/datetimePicker/index.tsx
index 9308cec..463a58e 100644
--- a/src/packages/base-widgets/datetimePicker/index.tsx
+++ b/src/packages/base-widgets/datetimePicker/index.tsx
@@ -26,7 +26,7 @@ export default {
moduleName: 'baseWidgets',
label: '表单项类型 - 时间选择器',
preview: () => ,
- render: ({ size, block, props }) => {
+ render: ({ styles, block, props }) => {
const { registerRef } = useGlobalProperties()
const { attrs } = getCurrentInstance()!
@@ -46,16 +46,13 @@ export default {
}
const PopupPicker = () => (
- <>
+
(state.showPicker = true)}
- style={{
- width: size.width ? `${size.width}px` : null
- }}
name={Array.isArray(props.name) ? [...props.name].pop() : props.name}
v-slots={{
input: () =>
@@ -76,7 +73,7 @@ export default {
onCancel={() => (state.showPicker = false)}
/>
- >
+
)
return
diff --git a/src/packages/base-widgets/divider/index.tsx b/src/packages/base-widgets/divider/index.tsx
index 7648c86..6ccce6c 100644
--- a/src/packages/base-widgets/divider/index.tsx
+++ b/src/packages/base-widgets/divider/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-06-25 08:49:31
+ * @LastEditTime: 2021-07-07 21:10:10
* @LastEditors: 卜启缘
* @Description: 分割线
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\divider\index.tsx
@@ -21,20 +21,23 @@ export default {
moduleName: 'baseWidgets',
label: '分割线',
preview: () => 文本,
- render: ({ props, block }) => {
+ render: ({ props, block, styles }) => {
const { registerRef } = useGlobalProperties()
const style = {
+ width: '100%',
color: props['text-color'],
borderColor: props['divider-color']
}
return (
- registerRef(el, block._vid)} {...props} style={style}>
- {{
- default: () => props.text
- }}
-
+
+
registerRef(el, block._vid)} {...props} style={style}>
+ {{
+ default: () => props.text
+ }}
+
+
)
},
props: {
diff --git a/src/packages/base-widgets/image/index.tsx b/src/packages/base-widgets/image/index.tsx
index 01d613c..c05ec40 100644
--- a/src/packages/base-widgets/image/index.tsx
+++ b/src/packages/base-widgets/image/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-07-04 16:53:22
+ * @LastEditTime: 2021-07-07 10:56:20
* @LastEditors: 卜启缘
* @Description: 图片组件
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\image\index.tsx
@@ -30,10 +30,14 @@ export default {
),
- render: ({ props, block }) => {
+ render: ({ props, block, styles }) => {
const { registerRef } = useGlobalProperties()
- return registerRef(el, block._vid)} {...props} />
+ return (
+
+ registerRef(el, block._vid)} {...props} />
+
+ )
},
props: {
src: createEditorInputProp({
diff --git a/src/packages/base-widgets/input/index.tsx b/src/packages/base-widgets/input/index.tsx
index e2407ec..4c8b81f 100644
--- a/src/packages/base-widgets/input/index.tsx
+++ b/src/packages/base-widgets/input/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-05-04 05:36:58
- * @LastEditTime: 2021-07-03 09:45:56
+ * @LastEditTime: 2021-07-07 10:56:39
* @LastEditors: 卜启缘
* @Description: 表单项类型 - 输入框
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\input\index.tsx
@@ -18,7 +18,7 @@ export default {
preview: () => (
),
- render: ({ model, size, block, props, custom }) => {
+ render: ({ model, styles, block, props, custom }) => {
const { registerRef } = useGlobalProperties()
let rules = []
@@ -27,18 +27,17 @@ export default {
} catch (e) {}
return (
- registerRef(el, block._vid)}
- {...custom}
- {...props}
- {...model.default}
- v-model={props.modelValue}
- name={Array.isArray(props.name) ? [...props.name].pop() : props.name}
- rules={rules}
- style={{
- width: size.width ? `${size.width}px` : null
- }}
- />
+
+ registerRef(el, block._vid)}
+ {...custom}
+ {...props}
+ {...model.default}
+ v-model={props.modelValue}
+ name={Array.isArray(props.name) ? [...props.name].pop() : props.name}
+ rules={rules}
+ />
+
)
},
events: [
diff --git a/src/packages/base-widgets/nav-bar/index.tsx b/src/packages/base-widgets/nav-bar/index.tsx
index 9f40a34..abe6e4a 100644
--- a/src/packages/base-widgets/nav-bar/index.tsx
+++ b/src/packages/base-widgets/nav-bar/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-05-04 05:36:58
- * @LastEditTime: 2021-07-04 16:54:00
+ * @LastEditTime: 2021-07-07 10:56:56
* @LastEditors: 卜启缘
* @Description: 导航栏
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\nav-bar\index.tsx
@@ -19,19 +19,13 @@ export default {
preview: () => (
),
- render: ({ props, size, block, custom }) => {
+ render: ({ props, styles, block, custom }) => {
const { registerRef } = useGlobalProperties()
return (
- registerRef(el, block._vid)}
- placeholder
- {...custom}
- {...props}
- style={{
- width: size.width ? `${size.width}px` : null
- }}
- />
+
+ registerRef(el, block._vid)} placeholder {...custom} {...props} />
+
)
},
props: {
diff --git a/src/packages/base-widgets/notice-bar/index.tsx b/src/packages/base-widgets/notice-bar/index.tsx
index 7655b22..a8bc467 100644
--- a/src/packages/base-widgets/notice-bar/index.tsx
+++ b/src/packages/base-widgets/notice-bar/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-14 12:24:12
- * @LastEditTime: 2021-07-04 16:54:32
+ * @LastEditTime: 2021-07-07 18:49:16
* @LastEditors: 卜启缘
* @Description:
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\notice-bar\index.tsx
@@ -22,10 +22,14 @@ export default {
text={'在代码阅读过程中人们说脏话的频率是衡量代码质量的唯一标准。'}
/>
),
- render: ({ block, props }) => {
+ render: ({ block, props, styles }) => {
const { registerRef } = useGlobalProperties()
- return registerRef(el, block._vid)} {...props} />
+ return (
+
+ registerRef(el, block._vid)} style={{ width: '100%' }} {...props} />
+
+ )
},
events: [
{ label: '点击通知栏时触发', value: 'click' },
diff --git a/src/packages/base-widgets/picker/index.tsx b/src/packages/base-widgets/picker/index.tsx
index fe58153..d5701bf 100644
--- a/src/packages/base-widgets/picker/index.tsx
+++ b/src/packages/base-widgets/picker/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-07-05 10:18:29
+ * @LastEditTime: 2021-07-07 10:57:41
* @LastEditors: 卜启缘
* @Description: 表单项类型 - 选择器
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\picker\index.tsx
@@ -22,7 +22,7 @@ export default {
moduleName: 'baseWidgets',
label: '表单项类型 - 选择器',
preview: () => ,
- render: ({ size, block, props }) => {
+ render: ({ styles, block, props }) => {
const { registerRef } = useGlobalProperties()
const { attrs } = getCurrentInstance()!
@@ -49,16 +49,13 @@ export default {
}
const PopupPicker = () => (
- <>
+
(state.showPicker = true)}
- style={{
- width: size.width ? `${size.width}px` : null
- }}
name={Array.isArray(props.name) ? [...props.name].pop() : props.name}
>
{{
@@ -81,7 +78,7 @@ export default {
onCancel={() => (state.showPicker = false)}
/>
- >
+
)
return
diff --git a/src/packages/base-widgets/process/index.tsx b/src/packages/base-widgets/process/index.tsx
index fbafa0c..e99eb68 100644
--- a/src/packages/base-widgets/process/index.tsx
+++ b/src/packages/base-widgets/process/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-12 22:18:48
- * @LastEditTime: 2021-07-04 17:00:12
+ * @LastEditTime: 2021-07-07 10:58:10
* @LastEditors: 卜启缘
* @Description: 进度条
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\process\index.tsx
@@ -20,10 +20,14 @@ export default {
moduleName: 'baseWidgets',
label: '进度条',
preview: () => ,
- render: ({ props }) => {
+ render: ({ props, styles }) => {
const RenderProgress = () =>
- return
+ return (
+
+
+
+ )
},
props: {
percentage: createEditorInputNumberProp({ label: '进度百分比', defaultValue: 50 }),
diff --git a/src/packages/base-widgets/radio/index.tsx b/src/packages/base-widgets/radio/index.tsx
index 7317cdc..9457881 100644
--- a/src/packages/base-widgets/radio/index.tsx
+++ b/src/packages/base-widgets/radio/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-07-04 17:00:24
+ * @LastEditTime: 2021-07-07 10:59:56
* @LastEditors: 卜启缘
* @Description: 表单项类型 - 单选框
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\radio\index.tsx
@@ -27,33 +27,32 @@ export default {
two
),
- render: ({ size, block, props }) => {
+ render: ({ styles, block, props }) => {
const { registerRef } = useGlobalProperties()
return (
- (
- registerRef(el, block._vid)}
- {...props}
- v-model={props.modelValue}
- >
- {props.options?.map((item) => (
-
- {item.label}
-
- ))}
-
- )
- }}
- />
+
+ (
+ registerRef(el, block._vid)}
+ {...props}
+ v-model={props.modelValue}
+ >
+ {props.options?.map((item) => (
+
+ {item.label}
+
+ ))}
+
+ )
+ }}
+ />
+
)
},
props: {
diff --git a/src/packages/base-widgets/rate/index.tsx b/src/packages/base-widgets/rate/index.tsx
index e095d73..dcd473e 100644
--- a/src/packages/base-widgets/rate/index.tsx
+++ b/src/packages/base-widgets/rate/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-07-03 09:38:17
+ * @LastEditTime: 2021-07-07 11:00:22
* @LastEditors: 卜启缘
* @Description: 表单项类型 - 评分
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\rate\index.tsx
@@ -29,27 +29,26 @@ export default {
v-slots={{ input: () => }}
>
),
- render: ({ size, block, props }) => {
+ render: ({ styles, block, props }) => {
const { registerRef } = useGlobalProperties()
return (
- (
- registerRef(el, block._vid)}
- {...props}
- v-model={props.modelValue}
- >
- )
- }}
- />
+
+ (
+ registerRef(el, block._vid)}
+ {...props}
+ v-model={props.modelValue}
+ >
+ )
+ }}
+ />
+
)
},
props: {
diff --git a/src/packages/base-widgets/slider/index.tsx b/src/packages/base-widgets/slider/index.tsx
index 66b954c..a407765 100644
--- a/src/packages/base-widgets/slider/index.tsx
+++ b/src/packages/base-widgets/slider/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-07-03 09:38:29
+ * @LastEditTime: 2021-07-07 11:00:37
* @LastEditors: 卜启缘
* @Description: 表单项类型 - 滑块
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\slider\index.tsx
@@ -29,27 +29,26 @@ export default {
v-slots={{ input: () => }}
>
),
- render: ({ size, block, props }) => {
+ render: ({ styles, block, props }) => {
const { registerRef } = useGlobalProperties()
return (
- (
- registerRef(el, block._vid)}
- {...props}
- v-model={props.modelValue}
- >
- )
- }}
- />
+
+ (
+ registerRef(el, block._vid)}
+ {...props}
+ v-model={props.modelValue}
+ >
+ )
+ }}
+ />
+
)
},
props: {
diff --git a/src/packages/base-widgets/stepper/index.tsx b/src/packages/base-widgets/stepper/index.tsx
index 2ae7b7d..ff117c7 100644
--- a/src/packages/base-widgets/stepper/index.tsx
+++ b/src/packages/base-widgets/stepper/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-07-03 09:38:50
+ * @LastEditTime: 2021-07-07 11:00:52
* @LastEditors: 卜启缘
* @Description: '表单项类型 - 步进器
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\stepper\index.tsx
@@ -30,27 +30,26 @@ export default {
v-slots={{ input: () => }}
>
),
- render: ({ size, block, props }) => {
+ render: ({ styles, block, props }) => {
const { registerRef } = useGlobalProperties()
return (
- (
- registerRef(el, block._vid)}
- {...props}
- v-model={props.modelValue}
- >
- )
- }}
- />
+
+ (
+ registerRef(el, block._vid)}
+ {...props}
+ v-model={props.modelValue}
+ >
+ )
+ }}
+ />
+
)
},
props: {
diff --git a/src/packages/base-widgets/swipe/index.tsx b/src/packages/base-widgets/swipe/index.tsx
index 056883c..4373bc3 100644
--- a/src/packages/base-widgets/swipe/index.tsx
+++ b/src/packages/base-widgets/swipe/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-14 12:24:12
- * @LastEditTime: 2021-07-04 17:01:36
+ * @LastEditTime: 2021-07-07 11:01:14
* @LastEditors: 卜启缘
* @Description: 轮播图组件
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\swipe\index.tsx
@@ -29,23 +29,25 @@ export default {
4
),
- render: ({ block, props }) => {
+ render: ({ block, props, styles }) => {
const { registerRef } = useGlobalProperties()
return (
- registerRef(el, block._vid)}
- {...props}
- style={{ height: `${props.height}px` }}
- >
- {props.images?.map((item) => (
- <>
-
-
-
- >
- ))}
-
+
+
registerRef(el, block._vid)}
+ {...props}
+ style={{ height: `${props.height}px` }}
+ >
+ {props.images?.map((item) => (
+ <>
+
+
+
+ >
+ ))}
+
+
)
},
props: createFieldProps(),
diff --git a/src/packages/base-widgets/switch/index.tsx b/src/packages/base-widgets/switch/index.tsx
index 5a0dd52..f0915c4 100644
--- a/src/packages/base-widgets/switch/index.tsx
+++ b/src/packages/base-widgets/switch/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-07-04 17:02:06
+ * @LastEditTime: 2021-07-07 11:01:29
* @LastEditors: 卜启缘
* @Description: 表单项类型 - 开关
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\switch\index.tsx
@@ -24,27 +24,26 @@ export default {
preview: () => (
}} />
),
- render: ({ size, block, props }) => {
+ render: ({ styles, block, props }) => {
const { registerRef } = useGlobalProperties()
return (
- (
- registerRef(el, block._vid)}
- {...props}
- v-model={props.modelValue}
- />
- )
- }}
- />
+
+ (
+ registerRef(el, block._vid)}
+ {...props}
+ v-model={props.modelValue}
+ />
+ )
+ }}
+ />
+
)
},
props: {
diff --git a/src/packages/base-widgets/text/index.tsx b/src/packages/base-widgets/text/index.tsx
index a3a9930..7b9a7de 100644
--- a/src/packages/base-widgets/text/index.tsx
+++ b/src/packages/base-widgets/text/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-06-25 08:51:29
+ * @LastEditTime: 2021-07-07 11:01:54
* @LastEditors: 卜启缘
* @Description: 文本
* @FilePath: \vite-vue3-lowcode\src\packages\base-widgets\text\index.tsx
@@ -21,7 +21,7 @@ export default {
moduleName: 'baseWidgets',
label: '文本',
preview: () => 预览文本,
- render: ({ props, block }) => {
+ render: ({ props, block, styles }) => {
const { registerRef } = useGlobalProperties()
return (
@@ -30,7 +30,8 @@ export default {
style={{
color: props.color,
fontSize: `${parseFloat(props.size)}px`,
- fontFamily: props.font
+ fontFamily: props.font,
+ ...styles
}}
>
{props.text || '默认文本'}
diff --git a/src/packages/container-component/form/index.tsx b/src/packages/container-component/form/index.tsx
index 49b083b..15e35ef 100644
--- a/src/packages/container-component/form/index.tsx
+++ b/src/packages/container-component/form/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 09:45:21
- * @LastEditTime: 2021-06-27 18:01:21
+ * @LastEditTime: 2021-07-07 21:23:23
* @LastEditors: 卜启缘
* @Description:
* @FilePath: \vite-vue3-lowcode\src\packages\container-component\form\index.tsx
@@ -27,7 +27,7 @@ export default {
),
- render: function ({ props, custom, block }) {
+ render: function ({ props, styles, block }) {
const { slots } = getCurrentInstance()!
const { registerRef } = useGlobalProperties()
@@ -36,9 +36,16 @@ export default {
}
return (
-
+
+
+
)
},
resize: {
diff --git a/src/packages/container-component/layout/index.module.scss b/src/packages/container-component/layout/index.module.scss
index d2b2ac6..edc4be0 100644
--- a/src/packages/container-component/layout/index.module.scss
+++ b/src/packages/container-component/layout/index.module.scss
@@ -6,5 +6,6 @@
* @update: 2021/5/2 16:15
*/
.van-row {
+ width: 100%;
padding: 2px;
}
diff --git a/src/packages/container-component/layout/index.tsx b/src/packages/container-component/layout/index.tsx
index d207c32..77ef8f6 100644
--- a/src/packages/container-component/layout/index.tsx
+++ b/src/packages/container-component/layout/index.tsx
@@ -2,7 +2,7 @@ import { Col, Row } from 'vant'
import { renderSlot, getCurrentInstance } from 'vue'
import { createEditorInputProp, createEditorSelectProp } from '@/visual-editor/visual-editor.props'
import type { VisualEditorComponent } from '@/visual-editor/visual-editor.utils'
-import styles from './index.module.scss'
+import styleModule from './index.module.scss'
import { useGlobalProperties } from '@/hooks/useGlobalProperties'
interface SlotItem {
@@ -36,7 +36,7 @@ export default {
span: 8
),
- render: function ({ props, size, block, custom }) {
+ render: function ({ props, styles, block, custom }) {
const { slots } = getCurrentInstance()!
const { registerRef } = useGlobalProperties()
@@ -51,27 +51,25 @@ export default {
}
return (
- registerRef(el, block._vid)}
- {...custom}
- {...props}
- style={{
- height: size.height ? `${size.height}px` : null,
- width: size.width ? `${size.width}px` : null
- }}
- class={styles.vanRow}
- >
- {Object.values(Object.keys(props.slots).length ? props.slots : createSlots('12:12'))
- ?.filter((item) => typeof item !== 'string')
- .map((spanItem: SlotItem, spanIndex) => {
- slotsTemp[block._vid][`slot${spanIndex}`] = spanItem
- return (
- <>
- {renderSlot(slots, `slot${spanIndex}`)}
- >
- )
- })}
-
+
+ registerRef(el, block._vid)}
+ {...custom}
+ {...props}
+ class={styleModule.vanRow}
+ >
+ {Object.values(Object.keys(props.slots).length ? props.slots : createSlots('12:12'))
+ ?.filter((item) => typeof item !== 'string')
+ .map((spanItem: SlotItem, spanIndex) => {
+ slotsTemp[block._vid][`slot${spanIndex}`] = spanItem
+ return (
+ <>
+ {renderSlot(slots, `slot${spanIndex}`)}
+ >
+ )
+ })}
+
+
)
},
resize: {
diff --git a/src/visual-editor/components/common/format-input-number/index.module.scss b/src/visual-editor/components/common/format-input-number/index.module.scss
new file mode 100644
index 0000000..b0b36f2
--- /dev/null
+++ b/src/visual-editor/components/common/format-input-number/index.module.scss
@@ -0,0 +1,7 @@
+.format-input-number {
+ :global {
+ .el-input-group__append {
+ padding: 0 10px;
+ }
+ }
+}
diff --git a/src/visual-editor/components/common/format-input-number/index.tsx b/src/visual-editor/components/common/format-input-number/index.tsx
new file mode 100644
index 0000000..dd025fc
--- /dev/null
+++ b/src/visual-editor/components/common/format-input-number/index.tsx
@@ -0,0 +1,75 @@
+/*
+ * @Author: 卜启缘
+ * @Date: 2021-07-06 22:14:13
+ * @LastEditTime: 2021-07-07 16:32:50
+ * @LastEditors: 卜启缘
+ * @Description:
+ * @FilePath: \vite-vue3-lowcode\src\visual-editor\components\common\format-input-number\index.tsx
+ */
+import { defineComponent } from 'vue'
+import { ElInput } from 'element-plus'
+import type { PropType } from 'vue'
+import { useVModel } from '@vueuse/core'
+import styles from './index.module.scss'
+
+export const FormatInputNumber = defineComponent({
+ props: {
+ modelValue: {
+ type: [String] as PropType,
+ default: ''
+ },
+ symbol: {
+ // 符号
+ type: String as PropType,
+ default: 'px'
+ },
+ max: {
+ type: [Number],
+ default: 100
+ },
+ min: {
+ type: [Number],
+ default: 0
+ }
+ },
+ emits: ['update:modelValue'],
+ setup(props, { attrs }) {
+ const modelValue = useVModel(props, 'modelValue')
+
+ const onInput = (val) => {
+ let num = parseFloat(`${val}`.replace(/[^0-9]/gi, ''))
+ num = Number.isNaN(num) ? 0 : num
+ num = Math.max(props.min, num)
+ num = Math.min(props.max, num)
+ modelValue.value = num + props.symbol
+ }
+
+ const increment = () => {
+ onInput(parseFloat(modelValue.value) + 1)
+ }
+
+ const cutdown = () => {
+ onInput(Math.max(props.min, parseFloat(modelValue.value) - 1))
+ }
+
+ return () => (
+
+ )
+ }
+})
diff --git a/src/visual-editor/components/header/index.vue b/src/visual-editor/components/header/index.vue
index cb20fb5..d0084df 100644
--- a/src/visual-editor/components/header/index.vue
+++ b/src/visual-editor/components/header/index.vue
@@ -107,7 +107,7 @@ export default defineComponent({
.logo {
width: 60px;
height: 60px;
- background-image: url('../../../assets/logo.png');
+ background-image: url('@/assets/logo.png');
background-repeat: no-repeat;
background-size: contain;
}
diff --git a/src/visual-editor/components/left-aside/components/base-widgets/index.tsx b/src/visual-editor/components/left-aside/components/base-widgets/index.tsx
index fb4876a..4500462 100644
--- a/src/visual-editor/components/left-aside/components/base-widgets/index.tsx
+++ b/src/visual-editor/components/left-aside/components/base-widgets/index.tsx
@@ -1,7 +1,7 @@
/*
* @Author: 卜启缘
* @Date: 2021-06-01 13:22:14
- * @LastEditTime: 2021-07-04 21:36:26
+ * @LastEditTime: 2021-07-06 20:32:39
* @LastEditors: 卜启缘
* @Description: 基础组件
* @FilePath: \vite-vue3-lowcode\src\visual-editor\components\left-aside\components\base-widgets\index.tsx
@@ -29,7 +29,7 @@ export default defineComponent({
console.log('当前拖拽的组件:', comp)
const newComp = cloneDeep(comp)
newComp._vid = Date.now()
- return createNewBlock({ left: 0, top: 0, component: newComp })
+ return createNewBlock(newComp)
}
return () => (
diff --git a/src/visual-editor/components/left-aside/components/container-component/index.tsx b/src/visual-editor/components/left-aside/components/container-component/index.tsx
index ce52853..dc9aa2f 100644
--- a/src/visual-editor/components/left-aside/components/container-component/index.tsx
+++ b/src/visual-editor/components/left-aside/components/container-component/index.tsx
@@ -28,7 +28,7 @@ export default defineComponent({
console.log('当前拖拽的组件:', comp)
const newComp = cloneDeep(comp)
newComp._vid = Date.now()
- return createNewBlock({ left: 0, top: 0, component: newComp })
+ return createNewBlock(newComp)
}
return () => (
diff --git a/src/visual-editor/components/left-aside/components/data-source/data-fetch.vue b/src/visual-editor/components/left-aside/components/data-source/data-fetch.vue
index 0b6ae32..0b1beff 100644
--- a/src/visual-editor/components/left-aside/components/data-source/data-fetch.vue
+++ b/src/visual-editor/components/left-aside/components/data-source/data-fetch.vue
@@ -1,7 +1,7 @@
-
+
@@ -30,9 +30,16 @@ import DataFetch from './data-fetch.vue'
diff --git a/src/visual-editor/components/left-aside/components/page-tree/index.vue b/src/visual-editor/components/left-aside/components/page-tree/index.vue
index 5a0cead..bd2f4ff 100644
--- a/src/visual-editor/components/left-aside/components/page-tree/index.vue
+++ b/src/visual-editor/components/left-aside/components/page-tree/index.vue
@@ -47,33 +47,14 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-