diff --git a/src/base.css b/src/base.css
index f521ca7..399e6ac 100644
--- a/src/base.css
+++ b/src/base.css
@@ -382,3 +382,46 @@ body {
opacity: 1;
}
}
+
+/** flex多行容器 */
+.flex-column-container {
+ display: flex;
+ flex-direction: column;
+ flex-wrap: nowrap;
+}
+
+/** flex多列容器 */
+.flex-row-container {
+ display: flex;
+ flex-direction: row;
+ flex-wrap: nowrap;
+}
+
+/** flex自动填充 */
+.flex-item-fill {
+ flex-grow: 1;
+ overflow: hidden;
+}
+
+/** flex固定大小 */
+.flex-item-fixed {
+ flex-shrink: 0;
+}
+
+/** flex主轴上对齐方式 */
+.flex-justify-content-center {
+ justify-content: center;
+}
+
+/** flex交叉轴上对齐方式 */
+.flex-align-items-center {
+ align-items: center;
+}
+
+/** 内容居中 */
+.content-center {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+}
+
diff --git a/src/editor/propEditors/InOutCenterEditor.vue b/src/editor/propEditors/InOutCenterEditor.vue
new file mode 100644
index 0000000..73a96c3
--- /dev/null
+++ b/src/editor/propEditors/InOutCenterEditor.vue
@@ -0,0 +1,282 @@
+
+
+
+
+
+
+
diff --git a/src/editor/widgets/property/PropertyPanelConstant.ts b/src/editor/widgets/property/PropertyPanelConstant.ts
index f713f55..9197a78 100644
--- a/src/editor/widgets/property/PropertyPanelConstant.ts
+++ b/src/editor/widgets/property/PropertyPanelConstant.ts
@@ -3,6 +3,7 @@ import type { DataFormProps } from "@/components/data-form/DataFormTypes.ts";
import type { PropertyFieldSetter } from "@/core/base/PropertyTypes.ts";
import { dataFormInputComponents } from "@/components/data-form/DataFormConstant.ts";
import TransformEditor from "@/editor/propEditors/TransformEditor.vue";
+import InOutCenterEditor from "@/editor/propEditors/InOutCenterEditor.vue";
const defDataFormProps: DataFormProps = {
columnCount: 1,
@@ -12,6 +13,7 @@ const defDataFormProps: DataFormProps = {
};
dataFormInputComponents.TransformEditor = markRaw(TransformEditor);
+dataFormInputComponents.InOutCenterEditor = markRaw(InOutCenterEditor);
const basicFieldsSetter: Array = [
{
@@ -48,11 +50,10 @@ const basicFieldsSetter: Array = [
dataPath: 'tf', input: 'TransformEditor',
inputProps: {},
},
- // {
- // dataPath: 'dt', input: 'InOutCenterEditor',
- // inputProps: {
- // },
- // },
+ {
+ dataPath: 'dt', input: 'InOutCenterEditor',
+ inputProps: {},
+ },
];
diff --git a/src/modules/charger/ChargerMeta.ts b/src/modules/charger/ChargerMeta.ts
deleted file mode 100644
index cbf8f74..0000000
--- a/src/modules/charger/ChargerMeta.ts
+++ /dev/null
@@ -1,49 +0,0 @@
-import type { IMeta } from '@/core/base/IMeta.ts'
-
-export default [
- { field: 'uuid', editor: 'UUID', label: 'uuid', readonly: true, category: 'basic' },
- { field: 'name', editor: 'TextInput', label: '名称', category: 'basic' },
- { field: 'dt.label', editor: 'TextInput', label: '标签', category: 'basic' },
- { editor: 'TransformEditor', category: 'basic' },
- { field: 'dt.color', editor: 'Color', label: '颜色', category: 'basic' },
- { editor: '-', category: 'basic' },
-
- { field: 'dt.chargerWidth', editor: 'NumberInput', label: '充电桩宽度', category: 'basic' },
- { field: 'dt.chargerDepth', editor: 'NumberInput', label: '充电桩深度', category: 'basic' },
- /**
- * dt.bays 5列3层货架示例
- * {
- * dt: {
- * rackDepth: 1.1, // 货架深度
- * levelCount: 3, // 总层数
- * bayCount: 5, // 总列数
- * hideFloor: false, // 隐藏底板
- * extendColumns: true, // 扩展挡板
- * columnSpacing: 1, // 支脚跨越
- * bays: [ // 每列的配置
- * {
- * bayWidth: 1.6, // 列的宽度
- * levelHeight: [ 1.4, 1.4, 1.4 ] // 每层的高度
- * },
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * ]
- * }
- * }
- *
- *
- *
- *
- *
- *
- *
- */
-
-
- { field: 'tf', editor: 'InOutCenterEditor', category: 'basic' },
- { field: 'dt.selectable', editor: 'Switch', label: '可选中', category: 'basic' },
- { field: 'dt.protected', editor: 'Switch', label: '受保护', category: 'basic' },
- { field: 'visible', editor: 'Switch', label: '可见', category: 'basic' }
-] as IMeta
diff --git a/src/modules/charger/ChargerPropertySetter.ts b/src/modules/charger/ChargerPropertySetter.ts
new file mode 100644
index 0000000..ec222bc
--- /dev/null
+++ b/src/modules/charger/ChargerPropertySetter.ts
@@ -0,0 +1,20 @@
+import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
+import { basicFieldsSetter } from "@/editor/widgets/property/PropertyPanelConstant.ts";
+
+const propertySetter: PropertySetter = {
+ flatten: {
+ fields: [
+ ...basicFieldsSetter,
+ {
+ dataPath: 'dt.chargerWidth', label: '充电桩宽度', input: 'InputNumber',
+ inputProps: {},
+ },
+ {
+ dataPath: 'dt.chargerDepth', label: '充电桩深度', input: 'InputNumber',
+ inputProps: {},
+ },
+ ],
+ },
+};
+
+export default propertySetter;
diff --git a/src/modules/charger/index.ts b/src/modules/charger/index.ts
index 1085ad5..3a29a70 100644
--- a/src/modules/charger/index.ts
+++ b/src/modules/charger/index.ts
@@ -1,15 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import ChargerRenderer from './ChargerRenderer.ts'
import ChargerEntity from './ChargerEntity.ts'
-import ChargerMeta from './ChargerMeta.ts'
import ChargerInteraction from './ChargerInteraction.ts'
+import propertySetter from "@/modules/charger/ChargerPropertySetter.ts";
export const ITEM_TYPE_NAME = 'charger'
export default defineModule({
- name: ITEM_TYPE_NAME,
- renderer: new ChargerRenderer(ITEM_TYPE_NAME),
- interaction: new ChargerInteraction(ITEM_TYPE_NAME),
- meta: ChargerMeta,
- entity: ChargerEntity
+ name: ITEM_TYPE_NAME,
+ renderer: new ChargerRenderer(ITEM_TYPE_NAME),
+ interaction: new ChargerInteraction(ITEM_TYPE_NAME),
+ setter: propertySetter,
+ entity: ChargerEntity,
})
diff --git a/src/modules/clx/ClxMeta.ts b/src/modules/clx/ClxMeta.ts
deleted file mode 100644
index 24ad4fc..0000000
--- a/src/modules/clx/ClxMeta.ts
+++ /dev/null
@@ -1,49 +0,0 @@
-import type { IMeta } from '@/core/base/IMeta.ts'
-
-export default [
- { field: 'uuid', editor: 'UUID', label: 'uuid', readonly: true, category: 'basic' },
- { field: 'name', editor: 'TextInput', label: '名称', category: 'basic' },
- { field: 'dt.label', editor: 'TextInput', label: '标签', category: 'basic' },
- { editor: 'TransformEditor', category: 'basic' },
- { field: 'dt.color', editor: 'Color', label: '颜色', category: 'basic' },
- { editor: '-', category: 'basic' },
-
- { field: 'dt.clxWidth', editor: 'NumberInput', label: 'CLX宽度', category: 'basic' },
- { field: 'dt.clxDepth', editor: 'NumberInput', label: 'CLX深度', category: 'basic' },
- /**
- * dt.bays 5列3层货架示例
- * {
- * dt: {
- * rackDepth: 1.1, // 货架深度
- * levelCount: 3, // 总层数
- * bayCount: 5, // 总列数
- * hideFloor: false, // 隐藏底板
- * extendColumns: true, // 扩展挡板
- * columnSpacing: 1, // 支脚跨越
- * bays: [ // 每列的配置
- * {
- * bayWidth: 1.6, // 列的宽度
- * levelHeight: [ 1.4, 1.4, 1.4 ] // 每层的高度
- * },
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * ]
- * }
- * }
- *
- *
- *
- *
- *
- *
- *
- */
-
-
- { field: 'tf', editor: 'InOutCenterEditor', category: 'basic' },
- { field: 'dt.selectable', editor: 'Switch', label: '可选中', category: 'basic' },
- { field: 'dt.protected', editor: 'Switch', label: '受保护', category: 'basic' },
- { field: 'visible', editor: 'Switch', label: '可见', category: 'basic' }
-] as IMeta
diff --git a/src/modules/clx/ClxPropertySetter.ts b/src/modules/clx/ClxPropertySetter.ts
new file mode 100644
index 0000000..5390c94
--- /dev/null
+++ b/src/modules/clx/ClxPropertySetter.ts
@@ -0,0 +1,20 @@
+import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
+import { basicFieldsSetter } from "@/editor/widgets/property/PropertyPanelConstant.ts";
+
+const propertySetter: PropertySetter = {
+ flatten: {
+ fields: [
+ ...basicFieldsSetter,
+ {
+ dataPath: 'dt.clxWidth', label: 'CLX宽度', input: 'InputNumber',
+ inputProps: {},
+ },
+ {
+ dataPath: 'dt.clxDepth', label: 'CLX深度', input: 'InputNumber',
+ inputProps: {},
+ },
+ ],
+ },
+};
+
+export default propertySetter;
diff --git a/src/modules/clx/index.ts b/src/modules/clx/index.ts
index 6e816eb..2c45f6c 100644
--- a/src/modules/clx/index.ts
+++ b/src/modules/clx/index.ts
@@ -1,15 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import ClxRenderer from './ClxRenderer.ts'
import ClxEntity from './ClxEntity.ts'
-import ClxMeta from './ClxMeta.ts'
import ClxInteraction from './ClxInteraction.ts'
+import propertySetter from "@/modules/clx/ClxPropertySetter.ts";
export const ITEM_TYPE_NAME = 'clx'
export default defineModule({
- name: ITEM_TYPE_NAME,
- renderer: new ClxRenderer(ITEM_TYPE_NAME),
- interaction: new ClxInteraction(ITEM_TYPE_NAME),
- meta: ClxMeta,
- entity: ClxEntity
+ name: ITEM_TYPE_NAME,
+ renderer: new ClxRenderer(ITEM_TYPE_NAME),
+ interaction: new ClxInteraction(ITEM_TYPE_NAME),
+ setter: propertySetter,
+ entity: ClxEntity
})
diff --git a/src/modules/ptr/PtrMeta.ts b/src/modules/ptr/PtrMeta.ts
deleted file mode 100644
index 4fede36..0000000
--- a/src/modules/ptr/PtrMeta.ts
+++ /dev/null
@@ -1,49 +0,0 @@
-import type { IMeta } from '@/core/base/IMeta.ts'
-
-export default [
- { field: 'uuid', editor: 'UUID', label: 'uuid', readonly: true, category: 'basic' },
- { field: 'name', editor: 'TextInput', label: '名称', category: 'basic' },
- { field: 'dt.label', editor: 'TextInput', label: '标签', category: 'basic' },
- { editor: 'TransformEditor', category: 'basic' },
- { field: 'dt.color', editor: 'Color', label: '颜色', category: 'basic' },
- { editor: '-', category: 'basic' },
-
- { field: 'dt.ptrWidth', editor: 'NumberInput', label: 'PTR宽度', category: 'basic' },
- { field: 'dt.ptrDepth', editor: 'NumberInput', label: 'PTR深度', category: 'basic' },
- /**
- * dt.bays 5列3层货架示例
- * {
- * dt: {
- * rackDepth: 1.1, // 货架深度
- * levelCount: 3, // 总层数
- * bayCount: 5, // 总列数
- * hideFloor: false, // 隐藏底板
- * extendColumns: true, // 扩展挡板
- * columnSpacing: 1, // 支脚跨越
- * bays: [ // 每列的配置
- * {
- * bayWidth: 1.6, // 列的宽度
- * levelHeight: [ 1.4, 1.4, 1.4 ] // 每层的高度
- * },
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
- * ]
- * }
- * }
- *
- *
- *
- *
- *
- *
- *
- */
-
-
- { field: 'tf', editor: 'InOutCenterEditor', category: 'basic' },
- { field: 'dt.selectable', editor: 'Switch', label: '可选中', category: 'basic' },
- { field: 'dt.protected', editor: 'Switch', label: '受保护', category: 'basic' },
- { field: 'visible', editor: 'Switch', label: '可见', category: 'basic' }
-] as IMeta