refactor: 将data-source,dep,schema,utils收敛到core,将form,table,stage,design,util收敛到editor

This commit is contained in:
roymondchen 2024-09-04 17:25:33 +08:00 committed by roymondchen
parent c3bc1035ad
commit 34fc0a15b9
212 changed files with 634 additions and 778 deletions

View File

@ -11,9 +11,9 @@
"import": "./dist/tmagic-core.js",
"require": "./dist/tmagic-core.umd.cjs"
},
"./dist/style.css": {
"import": "./dist/style.css",
"require": "./dist/style.css"
"./resetcss.css": {
"import": "./resetcss.css",
"require": "./resetcss.css"
},
"./*": "./*"
},
@ -37,6 +37,10 @@
"vue"
],
"dependencies": {
"@tmagic/data-source": "workspace:*",
"@tmagic/dep": "workspace:*",
"@tmagic/schema": "workspace:*",
"@tmagic/utils": "workspace:*",
"events": "^3.3.0",
"lodash-es": "^4.17.21"
},
@ -48,9 +52,6 @@
"vite": "^5.3.5"
},
"peerDependencies": {
"@tmagic/data-source": "workspace:*",
"@tmagic/schema": "workspace:*",
"@tmagic/utils": "workspace:*",
"typescript": "*"
},
"peerDependenciesMeta": {

View File

@ -18,6 +18,11 @@
import App from './App';
export * from '@tmagic/data-source';
export * from '@tmagic/dep';
export * from '@tmagic/schema';
export * from '@tmagic/utils';
export { default as EventHelper } from './EventHelper';
export * from './utils';

View File

@ -16,6 +16,7 @@
* limitations under the License.
*/
import { JsEngine } from '@tmagic/schema';
import { isNumber } from '@tmagic/utils';
import type { default as TMagicNode } from './Node';
@ -57,8 +58,6 @@ export const fillBackgroundImage = (value: string) => {
return value;
};
export const isNumber = (value: string) => /^(-?\d+)(\.\d+)?$/.test(value);
export const getTransform = (value: Record<string, string>, jsEngine: JsEngine) => {
if (!value) return [];

View File

@ -33,15 +33,12 @@
"data-source"
],
"dependencies": {
"@tmagic/dep": "workspace:*",
"deep-state-observer": "^5.5.13",
"events": "^3.3.0",
"lodash-es": "^4.17.21"
},
"peerDependencies": {
"@tmagic/core": "workspace:*",
"@tmagic/schema": "workspace:*",
"@tmagic/utils": "workspace:*",
"typescript": "*"
},
"peerDependenciesMeta": {

View File

@ -20,9 +20,8 @@ import EventEmitter from 'events';
import { cloneDeep } from 'lodash-es';
import type { default as TMagicApp } from '@tmagic/core';
import type { DataSourceSchema, DisplayCond, Id, MNode, NODE_CONDS_KEY } from '@tmagic/schema';
import { compiledNode } from '@tmagic/utils';
import type { DataSourceSchema, default as TMagicApp, DisplayCond, Id, MNode, NODE_CONDS_KEY } from '@tmagic/core';
import { compiledNode } from '@tmagic/core';
import { SimpleObservedData } from './observed-data/SimpleObservedData';
import { DataSource, HttpDataSource } from './data-sources';

View File

@ -18,7 +18,7 @@
import { union } from 'lodash-es';
import type { default as TMagicApp } from '@tmagic/core';
import { getDepNodeIds, getNodes, isPage } from '@tmagic/utils';
import { getDepNodeIds, getNodes, isPage } from '@tmagic/core';
import DataSourceManager from './DataSourceManager';
import type { ChangeEvent, DataSourceManagerData } from './types';

View File

@ -19,9 +19,8 @@ import EventEmitter from 'events';
import { cloneDeep } from 'lodash-es';
import type { default as TMagicApp } from '@tmagic/core';
import type { CodeBlockContent, DataSchema, DataSourceSchema } from '@tmagic/schema';
import { getDefaultValueFromFields } from '@tmagic/utils';
import type { CodeBlockContent, DataSchema, DataSourceSchema, default as TMagicApp } from '@tmagic/core';
import { getDefaultValueFromFields } from '@tmagic/core';
import { ObservedData } from '@data-source/observed-data/ObservedData';
import { SimpleObservedData } from '@data-source/observed-data/SimpleObservedData';

View File

@ -15,8 +15,8 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { HttpOptions, RequestFunction } from '@tmagic/schema';
import { getValueByKeyPath } from '@tmagic/utils';
import type { HttpOptions, RequestFunction } from '@tmagic/core';
import { getValueByKeyPath } from '@tmagic/core';
import { DataSourceOptions, HttpDataSourceSchema } from '@data-source/types';

View File

@ -1,6 +1,5 @@
import { isDataSourceCondTarget, isDataSourceTarget, Target, Watcher } from '@tmagic/dep';
import type { DataSourceSchema, MNode } from '@tmagic/schema';
import { DSL_NODE_KEY_COPY_PREFIX } from '@tmagic/utils';
import type { DataSourceSchema, MNode } from '@tmagic/core';
import { DSL_NODE_KEY_COPY_PREFIX, isDataSourceCondTarget, isDataSourceTarget, Target, Watcher } from '@tmagic/core';
const cache = new Map();

View File

@ -15,7 +15,6 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export { default as DataSourceManager } from './DataSourceManager';
export * from './data-sources';
export * from './createDataSourceManager';

View File

@ -1,6 +1,6 @@
import { EventEmitter } from 'events';
import { getValueByKeyPath, setValueByKeyPath } from '@tmagic/utils';
import { getValueByKeyPath, setValueByKeyPath } from '@tmagic/core';
import { ObservedData } from './ObservedData';

View File

@ -1,5 +1,4 @@
import type { default as TMagicApp } from '@tmagic/core';
import type { DataSourceSchema, HttpOptions, RequestFunction } from '@tmagic/schema';
import type { DataSourceSchema, default as TMagicApp, HttpOptions, RequestFunction } from '@tmagic/core';
import type DataSource from './data-sources/Base';
import type HttpDataSource from './data-sources/Http';

View File

@ -1,7 +1,6 @@
import { cloneDeep } from 'lodash-es';
import type { DepData, DisplayCond, DisplayCondItem, MApp, MNode, MPage, MPageFragment } from '@tmagic/schema';
import { NODE_CONDS_KEY } from '@tmagic/schema';
import type { DepData, DisplayCond, DisplayCondItem, MApp, MNode, MPage, MPageFragment } from '@tmagic/core';
import {
compiledCond,
compiledNode,
@ -10,8 +9,9 @@ import {
getValueByKeyPath,
isPage,
isPageFragment,
NODE_CONDS_KEY,
replaceChildNode,
} from '@tmagic/utils';
} from '@tmagic/core';
import type { AsyncDataSourceResolveResult, DataSourceManagerData } from './types';

View File

@ -1,11 +1,10 @@
import { describe, expect, test } from 'vitest';
import App from '@tmagic/core';
import { NodeType } from '@tmagic/schema';
import TMagicApp, { NodeType } from '@tmagic/core';
import { DataSource, DataSourceManager } from '@data-source/index';
const app = new App({
const app = new TMagicApp({
config: {
type: NodeType.ROOT,
id: '1',

View File

@ -1,17 +1,9 @@
import { describe, expect, test } from 'vitest';
import { MApp, NodeType } from '@tmagic/schema';
import TMagicApp, { type MApp, NodeType } from '@tmagic/core';
import { createDataSourceManager, DataSourceManager } from '@data-source/index';
class Core {
public dsl?: MApp;
constructor(options: any) {
this.dsl = options.config;
}
}
const dsl: MApp = {
type: NodeType.ROOT,
id: 'app_1',
@ -46,13 +38,14 @@ const dsl: MApp = {
},
],
methods: [],
events: [],
},
],
};
describe('createDataSourceManager', () => {
test('instance', () => {
const manager = createDataSourceManager(new Core({ config: dsl }));
const manager = createDataSourceManager(new TMagicApp({ config: dsl }));
expect(manager).toBeInstanceOf(DataSourceManager);
});
});

View File

@ -29,7 +29,7 @@
<script setup lang="ts">
import { computed, ref, watchEffect } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { AutocompleteProps } from './types';
defineOptions({
@ -38,7 +38,7 @@ defineOptions({
const props = defineProps<AutocompleteProps>();
const ui = getConfig('components')?.autocomplete;
const ui = getDesignConfig('components')?.autocomplete;
const uiComponent = ui?.component || 'el-autocomplete';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { BadgeProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<BadgeProps>();
const ui = getConfig('components')?.badge;
const ui = getDesignConfig('components')?.badge;
const uiComponent = ui?.component || 'el-badge';
const uiProps = computed(() => ui?.props(props) || props);

View File

@ -9,7 +9,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { ButtonProps } from './types';
defineOptions({
@ -18,7 +18,7 @@ defineOptions({
const props = defineProps<ButtonProps>();
const ui = getConfig('components')?.button;
const ui = getDesignConfig('components')?.button;
const uiComponent = ui?.component || 'el-button';

View File

@ -13,7 +13,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { CardProps } from './types';
defineOptions({
@ -22,7 +22,7 @@ defineOptions({
const props = defineProps<CardProps>();
const ui = getConfig('components')?.card;
const ui = getDesignConfig('components')?.card;
const uiComponent = ui?.component || 'el-card';

View File

@ -12,7 +12,7 @@
<script setup lang="ts">
import { computed, ref } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import { CascaderProps } from './types';
defineOptions({
@ -21,7 +21,7 @@ defineOptions({
const props = defineProps<CascaderProps>();
const ui = getConfig('components')?.cascader;
const ui = getDesignConfig('components')?.cascader;
const uiComponent = ui?.component || 'el-cascader';

View File

@ -15,7 +15,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { CheckboxProps } from './types';
defineOptions({
@ -27,7 +27,7 @@ const props = withDefaults(defineProps<CheckboxProps>(), {
falseValue: undefined,
});
const ui = getConfig('components')?.checkbox;
const ui = getDesignConfig('components')?.checkbox;
const uiComponent = ui?.component || 'el-checkbox';

View File

@ -13,7 +13,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { CheckboxGroupProps } from './types';
defineOptions({
@ -22,7 +22,7 @@ defineOptions({
const props = defineProps<CheckboxGroupProps>();
const ui = getConfig('components')?.checkboxGroup;
const ui = getDesignConfig('components')?.checkboxGroup;
const uiComponent = ui?.component || 'el-checkbox-group';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { ColProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<ColProps>();
const ui = getConfig('components')?.col;
const ui = getDesignConfig('components')?.col;
const uiComponent = ui?.component || 'el-col';

View File

@ -13,7 +13,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { CollapseProps } from './types';
defineOptions({
@ -22,7 +22,7 @@ defineOptions({
const props = defineProps<CollapseProps>();
const ui = getConfig('components')?.collapse;
const ui = getDesignConfig('components')?.collapse;
const uiComponent = ui?.component || 'el-collapse';

View File

@ -19,7 +19,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { CollapseItemProps } from './types';
defineOptions({
@ -28,7 +28,7 @@ defineOptions({
const props = defineProps<CollapseItemProps>();
const ui = getConfig('components')?.collapseItem;
const ui = getDesignConfig('components')?.collapseItem;
const uiComponent = ui?.component || 'el-collapse-item';

View File

@ -12,7 +12,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { ColorPickerProps } from './types';
defineOptions({
@ -24,7 +24,7 @@ const props = withDefaults(defineProps<ColorPickerProps>(), {
disabled: false,
});
const ui = getConfig('components')?.colorPicker;
const ui = getDesignConfig('components')?.colorPicker;
const uiComponent = ui?.component || 'el-color-picker';

View File

@ -12,7 +12,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { DatePickerProps } from './types';
defineOptions({
@ -23,7 +23,7 @@ const props = withDefaults(defineProps<DatePickerProps>(), {
type: 'date',
});
const ui = getConfig('components')?.datePicker;
const ui = getDesignConfig('components')?.datePicker;
const uiComponent = ui?.component || 'el-date-picker';

View File

@ -17,7 +17,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { DialogProps } from './types';
defineOptions({
@ -28,7 +28,7 @@ const props = defineProps<DialogProps>();
const emit = defineEmits(['close', 'update:modelValue']);
const ui = getConfig('components')?.dialog;
const ui = getDesignConfig('components')?.dialog;
const uiComponent = ui?.component || 'el-dialog';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { DividerProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<DividerProps>();
const ui = getConfig('components')?.divider;
const ui = getDesignConfig('components')?.divider;
const uiComponent = ui?.component || 'el-divider';

View File

@ -25,7 +25,7 @@
<script setup lang="ts">
import { computed, ref } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { DrawerProps } from './types';
defineOptions({
@ -36,7 +36,7 @@ const props = defineProps<DrawerProps>();
const emit = defineEmits(['open', 'opened', 'close', 'closed', 'update:modelValue']);
const ui = getConfig('components')?.drawer;
const ui = getDesignConfig('components')?.drawer;
const uiComponent = ui?.component || 'el-drawer';

View File

@ -11,7 +11,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { DropdownProps } from './types';
defineOptions({
@ -20,7 +20,7 @@ defineOptions({
const props = defineProps<DropdownProps>();
const ui = getConfig('components')?.dropdown;
const ui = getDesignConfig('components')?.dropdown;
const uiComponent = ui?.component || 'el-dropdown';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { DropdownItemProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<DropdownItemProps>();
const ui = getConfig('components')?.dropdownItem;
const ui = getDesignConfig('components')?.dropdownItem;
const uiComponent = ui?.component || 'el-dropdown-item';

View File

@ -5,13 +5,13 @@
</template>
<script setup lang="ts">
import { getConfig } from './config';
import { getDesignConfig } from './config';
defineOptions({
name: 'TMDropdownMenu',
});
const ui = getConfig('components')?.dropdownMenu;
const ui = getDesignConfig('components')?.dropdownMenu;
const uiComponent = ui?.component || 'el-dropdown-menu';
</script>

View File

@ -13,7 +13,7 @@
<script setup lang="ts">
import { computed, ref } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { FormProps } from './types';
defineOptions({
@ -22,7 +22,7 @@ defineOptions({
const props = defineProps<FormProps>();
const ui = getConfig('components')?.form;
const ui = getDesignConfig('components')?.form;
const uiComponent = ui?.component || 'el-form';

View File

@ -10,7 +10,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { FormItemProps } from './types';
defineOptions({
@ -19,7 +19,7 @@ defineOptions({
const props = defineProps<FormItemProps>();
const ui = getConfig('components')?.formItem;
const ui = getDesignConfig('components')?.formItem;
const uiComponent = ui?.component || 'el-form-item';

View File

@ -5,14 +5,14 @@
</template>
<script setup lang="ts">
import { getConfig } from './config';
import { getDesignConfig } from './config';
import { IconProps } from './types';
defineOptions({
name: 'TMIcon',
});
const ui = getConfig('components')?.icon;
const ui = getDesignConfig('components')?.icon;
const uiComponent = ui?.component || 'el-icon';
defineProps<IconProps>();
</script>

View File

@ -26,7 +26,7 @@
<script setup lang="ts">
import { computed, ref } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { InputProps } from './types';
defineOptions({
@ -35,7 +35,7 @@ defineOptions({
const props = defineProps<InputProps>();
const ui = getConfig('components')?.input;
const ui = getDesignConfig('components')?.input;
const uiComponent = ui?.component || 'el-input';

View File

@ -12,7 +12,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { InputNumberProps } from './types';
defineOptions({
@ -21,7 +21,7 @@ defineOptions({
const props = defineProps<InputNumberProps>();
const ui = getConfig('components')?.inputNumber;
const ui = getDesignConfig('components')?.inputNumber;
const uiComponent = ui?.component || 'el-input-number';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { OptionProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<OptionProps>();
const ui = getConfig('components')?.option;
const ui = getDesignConfig('components')?.option;
const uiComponent = ui?.component || 'el-option';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed, ref } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { OptionGroupProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<OptionGroupProps>();
const ui = getConfig('components')?.optionGroup;
const ui = getDesignConfig('components')?.optionGroup;
const uiComponent = ui?.component || 'el-option-group';

View File

@ -12,7 +12,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { PaginationProps } from './types';
defineOptions({
@ -23,7 +23,7 @@ const props = defineProps<PaginationProps>();
const emit = defineEmits(['size-change', 'current-change']);
const ui = getConfig('components')?.pagination;
const ui = getDesignConfig('components')?.pagination;
const uiComponent = ui?.component || 'el-pagination';

View File

@ -190,57 +190,3 @@ onBeforeUnmount(() => {
destroy();
});
</script>
<style lang="scss">
.tmagic-design-popper {
min-width: 150px;
line-height: 1.4;
background-color: #fff;
box-shadow: 0px 0px 12px rgba(0, 0, 0, 0.12);
color: #606266;
border: 1px solid #e4e7ed;
border-radius: 4px;
font-size: 14px;
overflow-wrap: break-word;
box-sizing: border-box;
padding: 10px;
&:focus {
outline: none;
}
}
.tmagic-design-popper[data-popper-placement^='top'] > .tmagic-design-popper-arrow {
bottom: -4px;
}
.tmagic-design-popper[data-popper-placement^='bottom'] > .tmagic-design-popper-arrow {
top: -4px;
}
.tmagic-design-popper[data-popper-placement^='left'] > .tmagic-design-popper-arrow {
right: -4px;
}
.tmagic-design-popper[data-popper-placement^='right'] > .tmagic-design-popper-arrow {
left: -4px;
}
.tmagic-design-popper-arrow,
.tmagic-design-popper-arrow::before {
position: absolute;
width: 8px;
height: 8px;
background: inherit;
}
.tmagic-design-popper-arrow {
visibility: hidden;
}
.tmagic-design-popper-arrow::before {
visibility: visible;
content: '';
transform: rotate(45deg);
}
</style>

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { RadioProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<RadioProps>();
const ui = getConfig('components')?.radio;
const ui = getDesignConfig('components')?.radio;
const uiComponent = ui?.component || 'el-radio';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { RadioButtonProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<RadioButtonProps>();
const ui = getConfig('components')?.radioButton;
const ui = getDesignConfig('components')?.radioButton;
const uiComponent = ui?.component || 'el-radio-button';

View File

@ -13,7 +13,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { RadioGroupProps } from './types';
defineOptions({
@ -22,7 +22,7 @@ defineOptions({
const props = defineProps<RadioGroupProps>();
const ui = getConfig('components')?.radioGroup;
const ui = getDesignConfig('components')?.radioGroup;
const uiComponent = ui?.component || 'el-radio-group';

View File

@ -5,11 +5,11 @@
</template>
<script setup lang="ts">
import { getConfig } from './config';
import { getDesignConfig } from './config';
defineOptions({
name: 'TMRow',
});
const uiComponent = getConfig('components')?.row.component || 'el-row';
const uiComponent = getDesignConfig('components')?.row.component || 'el-row';
</script>

View File

@ -5,13 +5,13 @@
</template>
<script setup lang="ts">
import { getConfig } from './config';
import { getDesignConfig } from './config';
defineOptions({
name: 'TMScrollbar',
});
const ui = getConfig('components')?.scrollbar;
const ui = getDesignConfig('components')?.scrollbar;
const uiComponent = ui?.component || 'el-scrollbar';
</script>

View File

@ -16,7 +16,7 @@
<script setup lang="ts">
import { computed, nextTick, ref, watch } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { SelectProps } from './types';
defineOptions({
@ -27,7 +27,7 @@ const props = defineProps<SelectProps>();
const emit = defineEmits(['change', 'update:modelValue', 'visibleHandler']);
const ui = getConfig('components')?.select;
const ui = getDesignConfig('components')?.select;
const uiComponent = ui?.component || 'el-select';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { StepProps } from './types';
defineOptions({
@ -22,7 +22,7 @@ const clickHandler = (...args: any[]) => {
emit('click', ...args);
};
const ui = getConfig('components')?.step;
const ui = getDesignConfig('components')?.step;
const uiComponent = ui?.component || 'el-step';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { StepsProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<StepsProps>();
const ui = getConfig('components')?.steps;
const ui = getDesignConfig('components')?.steps;
const uiComponent = ui?.component || 'el-steps';

View File

@ -15,7 +15,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { SwitchProps } from './types';
defineOptions({
@ -24,7 +24,7 @@ defineOptions({
const props = defineProps<SwitchProps>();
const ui = getConfig('components')?.switch;
const ui = getDesignConfig('components')?.switch;
const uiComponent = ui?.component || 'el-switch';

View File

@ -13,7 +13,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { TabPaneProps } from './types';
defineOptions({
@ -22,7 +22,7 @@ defineOptions({
const props = defineProps<TabPaneProps>();
const ui = getConfig('components')?.tabPane;
const ui = getDesignConfig('components')?.tabPane;
const uiComponent = ui?.component || 'el-tab-pane';

View File

@ -16,7 +16,7 @@
<script setup lang="ts">
import { computed, ref, watchEffect } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { TableProps } from './types';
defineOptions({
@ -27,7 +27,7 @@ const props = withDefaults(defineProps<TableProps>(), {
data: () => [],
});
const ui = getConfig('components')?.table;
const ui = getDesignConfig('components')?.table;
const uiComponent = ui?.component || 'el-table';

View File

@ -10,7 +10,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { TableColumnProps } from './types';
defineOptions({
@ -19,7 +19,7 @@ defineOptions({
const props = defineProps<TableColumnProps>();
const ui = getConfig('components')?.tableColumn;
const ui = getDesignConfig('components')?.tableColumn;
const uiComponent = ui?.component || 'el-table-column';

View File

@ -17,7 +17,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { TabsProps } from './types';
defineOptions({
@ -26,7 +26,7 @@ defineOptions({
const props = defineProps<TabsProps>();
const ui = getConfig('components')?.tabs;
const ui = getDesignConfig('components')?.tabs;
const uiComponent = ui?.component || 'el-tabs';

View File

@ -7,7 +7,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { TagProps } from './types';
defineOptions({
@ -16,7 +16,7 @@ defineOptions({
const props = defineProps<TagProps>();
const ui = getConfig('components')?.tag;
const ui = getDesignConfig('components')?.tag;
const uiComponent = ui?.component || 'el-tag';

View File

@ -12,7 +12,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { TimePickerProps } from './types';
defineOptions({
@ -21,7 +21,7 @@ defineOptions({
const props = defineProps<TimePickerProps>();
const ui = getConfig('components')?.timePicker;
const ui = getDesignConfig('components')?.timePicker;
const uiComponent = ui?.component || 'el-time-picker';

View File

@ -10,7 +10,7 @@
<script setup lang="ts">
import { computed } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { TooltipProps } from './types';
defineOptions({
@ -19,7 +19,7 @@ defineOptions({
const props = defineProps<TooltipProps>();
const ui = getConfig('components')?.tooltip;
const ui = getDesignConfig('components')?.tooltip;
const uiComponent = ui?.component || 'el-tooltip';

View File

@ -22,7 +22,7 @@
<script setup lang="ts">
import { computed, ref } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { TreeProps } from './types';
defineOptions({
@ -31,7 +31,7 @@ defineOptions({
const props = defineProps<TreeProps>();
const ui = getConfig('components')?.tree;
const ui = getDesignConfig('components')?.tree;
const uiComponent = ui?.component || 'el-tree';

View File

@ -11,7 +11,7 @@
<script setup lang="ts">
import { computed, ref } from 'vue';
import { getConfig } from './config';
import { getDesignConfig } from './config';
import type { UploadProps } from './types';
defineOptions({
@ -25,7 +25,7 @@ const emit = defineEmits(['change']);
const changeHandler = (...args: any[]) => {
emit('change', ...args);
};
const ui = getConfig('components')?.upload;
const ui = getDesignConfig('components')?.upload;
const uiComponent = ui?.component || 'el-upload';

View File

@ -16,14 +16,14 @@
* limitations under the License.
*/
import { PluginOptions } from './types';
import { DesignPluginOptions } from './types';
let $MAGIC_DESIGN: PluginOptions = {};
let $MAGIC_DESIGN: DesignPluginOptions = {};
const setConfig = (options: PluginOptions): void => {
const setDesignConfig = (options: DesignPluginOptions): void => {
$MAGIC_DESIGN = options;
};
const getConfig = <K extends keyof PluginOptions>(key: K) => $MAGIC_DESIGN[key];
const getDesignConfig = <K extends keyof DesignPluginOptions>(key: K) => $MAGIC_DESIGN[key];
export { getConfig, setConfig };
export { getDesignConfig, setDesignConfig };

View File

@ -1,8 +1,10 @@
import type { App, Ref } from 'vue';
import { computed, ref, unref } from 'vue';
import { setConfig } from './config';
import { PluginOptions, TMagicMessage, TMagicMessageBox } from './types';
import { setDesignConfig } from './config';
import { DesignPluginOptions, TMagicMessage, TMagicMessageBox } from './types';
import './theme/index.scss';
export * from './types';
export * from './config';
@ -107,7 +109,7 @@ export let useZIndex = (zIndexOverrides?: Ref<number>) => {
};
export default {
install(app: App, options: PluginOptions) {
install(app: App, options: DesignPluginOptions) {
if (options.message) {
tMagicMessage.error = options.message?.error;
tMagicMessage.success = options.message?.success;
@ -132,6 +134,6 @@ export default {
}
app.config.globalProperties.$MAGIC_DESIGN = options;
setConfig(options);
setDesignConfig(options);
},
};

View File

@ -0,0 +1 @@
@import "./popover.scss";

View File

@ -0,0 +1,55 @@
.tmagic-design-popper {
min-width: 150px;
line-height: 1.4;
background-color: #fff;
box-shadow: 0px 0px 12px rgba(0, 0, 0, 0.12);
color: #606266;
border: 1px solid #e4e7ed;
border-radius: 4px;
font-size: 14px;
overflow-wrap: break-word;
box-sizing: border-box;
padding: 10px;
&:focus {
outline: none;
}
}
.tmagic-design-popper[data-popper-placement^="top"]
> .tmagic-design-popper-arrow {
bottom: -4px;
}
.tmagic-design-popper[data-popper-placement^="bottom"]
> .tmagic-design-popper-arrow {
top: -4px;
}
.tmagic-design-popper[data-popper-placement^="left"]
> .tmagic-design-popper-arrow {
right: -4px;
}
.tmagic-design-popper[data-popper-placement^="right"]
> .tmagic-design-popper-arrow {
left: -4px;
}
.tmagic-design-popper-arrow,
.tmagic-design-popper-arrow::before {
position: absolute;
width: 8px;
height: 8px;
background: inherit;
}
.tmagic-design-popper-arrow {
visibility: hidden;
}
.tmagic-design-popper-arrow::before {
visibility: visible;
content: "";
transform: rotate(45deg);
}

View File

@ -46,7 +46,7 @@ export interface CascaderProps {
disabled?: boolean;
clearable?: boolean;
filterable?: boolean;
options?: CascaderOption[];
options?: CascaderPropsOption[];
size?: FieldSize;
/** 弹出内容的自定义类名 */
popperClass?: string;
@ -372,13 +372,13 @@ export interface UploadProps {
disabled?: boolean;
}
export interface CascaderOption {
export interface CascaderPropsOption {
/** 指定选项的值为选项对象的某个属性值 */
value: any;
/** 指定选项标签为选项对象的某个属性值 */
label: string;
/** 指定选项的子选项为选项对象的某个属性值 */
children?: CascaderOption[];
children?: CascaderPropsOption[];
}
export interface IconProps {
@ -706,7 +706,7 @@ export interface Components {
};
}
export interface PluginOptions {
export interface DesignPluginOptions {
message?: TMagicMessage;
messageBox?: TMagicMessageBox;
components?: Components;

View File

@ -49,8 +49,11 @@
],
"dependencies": {
"@element-plus/icons-vue": "^2.3.1",
"@tmagic/dep": "workspace:*",
"@tmagic/design": "workspace:*",
"@tmagic/form": "workspace:*",
"@tmagic/stage": "workspace:*",
"@tmagic/table": "workspace:*",
"@tmagic/utils": "workspace:*",
"buffer": "^6.0.3",
"color": "^3.1.3",
"emmet-monaco-es": "^5.3.0",
@ -79,11 +82,6 @@
},
"peerDependencies": {
"@tmagic/core": "workspace:*",
"@tmagic/design": "workspace:*",
"@tmagic/form": "workspace:*",
"@tmagic/schema": "workspace:*",
"@tmagic/stage": "workspace:*",
"@tmagic/utils": "workspace:*",
"monaco-editor": "^0.48.0",
"typescript": "*",
"vue": "^3.4.35"

View File

@ -119,7 +119,7 @@ import { EventEmitter } from 'events';
import { provide } from 'vue';
import type { MApp } from '@tmagic/schema';
import type { MApp } from '@tmagic/core';
import Framework from './layouts/Framework.vue';
import TMagicNavMenu from './layouts/NavMenu.vue';

View File

@ -61,9 +61,9 @@
<script lang="ts" setup>
import { computed, inject, Ref, ref } from 'vue';
import type { CodeBlockContent } from '@tmagic/core';
import { TMagicButton, TMagicDialog, tMagicMessage, tMagicMessageBox, TMagicTag } from '@tmagic/design';
import { ColumnConfig, FormConfig, FormState, MFormBox } from '@tmagic/form';
import type { CodeBlockContent } from '@tmagic/schema';
import { type FormConfig, type FormState, MFormBox, type TableColumnConfig } from '@tmagic/form';
import FloatingBox from '@editor/components/FloatingBox.vue';
import { useEditorContentHeight } from '@editor/hooks/use-editor-content-height';
@ -71,7 +71,7 @@ import { useNextFloatBoxPosition } from '@editor/hooks/use-next-float-box-positi
import { useWindowRect } from '@editor/hooks/use-window-rect';
import CodeEditor from '@editor/layouts/CodeEditor.vue';
import type { Services } from '@editor/type';
import { getConfig } from '@editor/utils/config';
import { getEditorConfig } from '@editor/utils/config';
defineOptions({
name: 'MEditorCodeBlockEditor',
@ -110,7 +110,7 @@ const diffChange = () => {
difVisible.value = false;
};
const defaultParamColConfig: ColumnConfig = {
const defaultParamColConfig: TableColumnConfig = {
type: 'row',
label: '参数类型',
items: [
@ -197,7 +197,7 @@ const functionConfig = computed<FormConfig>(() => [
onChange: (formState: FormState | undefined, code: string) => {
try {
// js
getConfig('parseDSL')(code);
getEditorConfig('parseDSL')(code);
return code;
} catch (error: any) {

View File

@ -24,7 +24,7 @@
<script setup lang="ts">
import { provide } from 'vue';
import type { Id } from '@tmagic/schema';
import type { Id } from '@tmagic/core';
import type { LayerNodeStatus, TreeNodeData } from '@editor/type';

View File

@ -65,7 +65,7 @@
import { computed, inject } from 'vue';
import { ArrowDown, ArrowRight } from '@element-plus/icons-vue';
import type { Id } from '@tmagic/schema';
import type { Id } from '@tmagic/core';
import MIcon from '@editor/components/Icon.vue';
import type { LayerNodeStatus, TreeNodeData } from '@editor/type';

View File

@ -1,6 +1,5 @@
import type { EventOption } from '@tmagic/core';
import type { DataSourceSchema, EventOption, Id, MApp, MNode } from '@tmagic/core';
import type { FormConfig, FormState } from '@tmagic/form';
import type { DataSourceSchema, Id, MApp, MNode } from '@tmagic/schema';
import StageCore, {
CONTAINER_HIGHLIGHT_CLASS_NAME,
ContainerHighlightType,

View File

@ -8,7 +8,7 @@ import serialize from 'serialize-javascript';
import type { FieldProps, FormItem } from '@tmagic/form';
import { getConfig } from '@editor/utils/config';
import { getEditorConfig } from '@editor/utils/config';
defineOptions({
name: 'MFieldsCodeLink',
@ -70,7 +70,7 @@ const changeHandler = (v: Record<string, any>) => {
if (!props.name || !props.model) return;
try {
const parseDSL = getConfig('parseDSL');
const parseDSL = getEditorConfig('parseDSL');
props.model[props.name] = parseDSL(`(${v[props.name]})`);
emit('change', props.model[props.name]);
} catch (e) {

View File

@ -19,10 +19,10 @@
import { computed, inject, watch } from 'vue';
import { isEmpty } from 'lodash-es';
import { HookCodeType, HookType } from '@tmagic/core';
import { TMagicCard } from '@tmagic/design';
import type { FieldProps, FormItem } from '@tmagic/form';
import { FormState, MContainer } from '@tmagic/form';
import { HookCodeType, HookType } from '@tmagic/schema';
import type { Services } from '@editor/type';

View File

@ -39,9 +39,9 @@ import { computed, inject, ref, watch } from 'vue';
import { Edit, View } from '@element-plus/icons-vue';
import { isEmpty, map } from 'lodash-es';
import type { Id } from '@tmagic/core';
import { TMagicButton } from '@tmagic/design';
import { createValues, type FieldProps, filterFunction, type FormState, MContainer } from '@tmagic/form';
import type { Id } from '@tmagic/schema';
import CodeParams from '@editor/components/CodeParams.vue';
import MIcon from '@editor/components/Icon.vue';

View File

@ -29,7 +29,7 @@
<script setup lang="ts">
import { computed, inject } from 'vue';
import { getConfig as getDesignConfig, TMagicSelect } from '@tmagic/design';
import { getDesignConfig, TMagicSelect } from '@tmagic/design';
import type { FieldProps } from '@tmagic/form';
import type { CondOpSelectConfig, Services } from '@editor/type';

View File

@ -69,15 +69,9 @@
import { computed, inject, ref, watch } from 'vue';
import { Edit, View } from '@element-plus/icons-vue';
import {
getConfig as getDesignConfig,
TMagicButton,
TMagicCascader,
TMagicSelect,
TMagicTooltip,
} from '@tmagic/design';
import { DataSourceFieldType } from '@tmagic/core';
import { getDesignConfig, TMagicButton, TMagicCascader, TMagicSelect, TMagicTooltip } from '@tmagic/design';
import { type FilterFunction, filterFunction, type FormState, type SelectOption } from '@tmagic/form';
import { DataSourceFieldType } from '@tmagic/schema';
import { DATA_SOURCE_FIELDS_SELECT_VALUE_PREFIX } from '@tmagic/utils';
import MIcon from '@editor/components/Icon.vue';

View File

@ -42,9 +42,9 @@
import { computed, inject, ref, resolveComponent, watch } from 'vue';
import { Coin } from '@element-plus/icons-vue';
import { DataSchema } from '@tmagic/core';
import { TMagicButton, tMagicMessage, TMagicTooltip } from '@tmagic/design';
import type { FieldProps, FormState } from '@tmagic/form';
import { DataSchema } from '@tmagic/schema';
import { DATA_SOURCE_FIELDS_SELECT_VALUE_PREFIX } from '@tmagic/utils';
import MIcon from '@editor/components/Icon.vue';

View File

@ -49,9 +49,9 @@
<script setup lang="ts">
import { inject, Ref, ref } from 'vue';
import type { DataSchema } from '@tmagic/core';
import { TMagicButton, tMagicMessage, tMagicMessageBox } from '@tmagic/design';
import { type FieldProps, type FormConfig, type FormState, MFormBox } from '@tmagic/form';
import type { DataSchema } from '@tmagic/schema';
import { type ColumnConfig, MagicTable } from '@tmagic/table';
import { getDefaultValueFromFields } from '@tmagic/utils';

View File

@ -1,12 +1,12 @@
<template>
<component
v-if="disabled || isFocused"
:is="getConfig('components')?.autocomplete.component || 'el-autocomplete'"
:is="getDesignConfig('components')?.autocomplete.component || 'el-autocomplete'"
class="tmagic-design-auto-complete"
ref="autocomplete"
v-model="state"
v-bind="
getConfig('components')?.autocomplete.props({
getDesignConfig('components')?.autocomplete.props({
disabled,
size,
fetchSuggestions: querySearch,
@ -51,9 +51,9 @@
import { computed, inject, nextTick, ref, watch } from 'vue';
import { Coin } from '@element-plus/icons-vue';
import { getConfig, TMagicAutocomplete, TMagicTag } from '@tmagic/design';
import type { DataSchema, DataSourceSchema } from '@tmagic/core';
import { getDesignConfig, TMagicAutocomplete, TMagicTag } from '@tmagic/design';
import type { FieldProps, FormItem } from '@tmagic/form';
import type { DataSchema, DataSourceSchema } from '@tmagic/schema';
import { getKeysArray, isNumber } from '@tmagic/utils';
import Icon from '@editor/components/Icon.vue';

View File

@ -35,9 +35,9 @@
import { computed, inject, ref } from 'vue';
import { Edit, View } from '@element-plus/icons-vue';
import type { Id } from '@tmagic/core';
import { TMagicButton, TMagicTooltip } from '@tmagic/design';
import { createValues, type FieldProps, filterFunction, type FormState, MContainer } from '@tmagic/form';
import type { Id } from '@tmagic/schema';
import CodeParams from '@editor/components/CodeParams.vue';
import MIcon from '@editor/components/Icon.vue';

View File

@ -21,9 +21,9 @@
</template>
<script setup lang="ts">
import type { CodeBlockContent } from '@tmagic/core';
import { TMagicButton } from '@tmagic/design';
import type { FieldProps } from '@tmagic/form';
import type { CodeBlockContent } from '@tmagic/schema';
import { type ColumnConfig, MagicTable } from '@tmagic/table';
import CodeBlockEditor from '@editor/components/CodeBlockEditor.vue';

View File

@ -31,9 +31,9 @@
<script setup lang="ts">
import { inject, Ref, ref } from 'vue';
import type { MockSchema } from '@tmagic/core';
import { TMagicButton, tMagicMessageBox, TMagicSwitch } from '@tmagic/design';
import { type FieldProps, type FormConfig, type FormState, MFormBox } from '@tmagic/form';
import type { MockSchema } from '@tmagic/schema';
import { type ColumnConfig, MagicTable } from '@tmagic/table';
import { getDefaultValueFromFields } from '@tmagic/utils';

View File

@ -15,6 +15,7 @@
<script lang="ts" setup>
import { computed, inject } from 'vue';
import type { DisplayCond } from '@tmagic/core';
import {
type FieldProps,
type FilterFunction,
@ -23,7 +24,6 @@ import {
type GroupListConfig,
MGroupList,
} from '@tmagic/form';
import type { DisplayCond } from '@tmagic/schema';
import type { Services } from '@editor/type';
import { getCascaderOptionsFromFields } from '@editor/utils';

View File

@ -53,11 +53,11 @@ import { computed, inject } from 'vue';
import { Delete } from '@element-plus/icons-vue';
import { has } from 'lodash-es';
import type { EventOption } from '@tmagic/core';
import type { EventOption, MComponent, MContainer } from '@tmagic/core';
import { ActionType } from '@tmagic/core';
import { TMagicButton } from '@tmagic/design';
import type { CascaderOption, ChildConfig, FieldProps, FormState, PanelConfig } from '@tmagic/form';
import { MContainer as MFormContainer, MPanel } from '@tmagic/form';
import { ActionType, type MComponent, type MContainer } from '@tmagic/schema';
import { DATA_SOURCE_FIELDS_CHANGE_EVENT_PREFIX } from '@tmagic/utils';
import type { CodeSelectColConfig, DataSourceMethodSelectConfig, EventSelectConfig, Services } from '@editor/type';

View File

@ -19,8 +19,8 @@
import { computed, inject } from 'vue';
import { Edit } from '@element-plus/icons-vue';
import { Id, NodeType } from '@tmagic/core';
import { FieldProps } from '@tmagic/form';
import { Id, NodeType } from '@tmagic/schema';
import Icon from '@editor/components/Icon.vue';
import type { PageFragmentSelectConfig, Services } from '@editor/type';

View File

@ -45,9 +45,9 @@ import { computed, inject, ref } from 'vue';
import { Close, Delete } from '@element-plus/icons-vue';
import { throttle } from 'lodash-es';
import type { Id } from '@tmagic/core';
import { TMagicButton, TMagicTooltip } from '@tmagic/design';
import type { FieldProps, FormItem, FormState } from '@tmagic/form';
import type { Id } from '@tmagic/schema';
import { getIdFromEl } from '@tmagic/utils';
import { type Services, UI_SELECT_MODE_EVENT_NAME } from '@editor/type';

View File

@ -1,8 +1,8 @@
import { nextTick, ref } from 'vue';
import { cloneDeep } from 'lodash-es';
import type { CodeBlockContent } from '@tmagic/core';
import { tMagicMessage } from '@tmagic/design';
import type { CodeBlockContent } from '@tmagic/schema';
import CodeBlockEditor from '@editor/components/CodeBlockEditor.vue';
import type { CodeBlockService } from '@editor/services/codeBlock';

View File

@ -1,6 +1,6 @@
import { computed, ref } from 'vue';
import type { DataSourceSchema } from '@tmagic/schema';
import type { DataSourceSchema } from '@tmagic/core';
import DataSourceConfigPanel from '@editor/layouts/sidebar/data-source/DataSourceConfigPanel.vue';
import type { DataSourceService } from '@editor/services/dataSource';

View File

@ -1,11 +1,11 @@
import { nextTick, ref } from 'vue';
import { cloneDeep } from 'lodash-es';
import type { CodeBlockContent, DataSourceSchema } from '@tmagic/core';
import { tMagicMessage } from '@tmagic/design';
import type { CodeBlockContent, DataSourceSchema } from '@tmagic/schema';
import CodeBlockEditor from '@editor/components/CodeBlockEditor.vue';
import { getConfig } from '@editor/utils/config';
import { getEditorConfig } from '@editor/utils/config';
export const useDataSourceMethod = () => {
const codeConfig = ref<CodeBlockContent>();
@ -81,7 +81,7 @@ export const useDataSourceMethod = () => {
if (values.content) {
// 在保存的时候转换代码内容
const parseDSL = getConfig('parseDSL');
const parseDSL = getEditorConfig('parseDSL');
if (typeof values.content === 'string') {
values.content = parseDSL<(...args: any[]) => any>(values.content);
}

View File

@ -1,6 +1,6 @@
import { type Ref, ref } from 'vue';
import type { Id, MNode } from '@tmagic/schema';
import type { Id, MNode } from '@tmagic/core';
import type { LayerNodeStatus, TreeNodeData } from '@editor/type';
import { traverseNode } from '@editor/utils';

View File

@ -1,6 +1,6 @@
import { ComputedRef, ref, watch } from 'vue';
import type { Id, MNode } from '@tmagic/schema';
import type { Id, MNode } from '@tmagic/core';
import { LayerNodeStatus, TreeNodeData } from '@editor/type';
import { traverseNode } from '@editor/utils';

View File

@ -1,6 +1,6 @@
import { computed, onBeforeUnmount, watch } from 'vue';
import type { MNode } from '@tmagic/schema';
import type { MNode } from '@tmagic/core';
import StageCore, { GuidesType, RemoveEventData, SortEventData, UpdateEventData } from '@tmagic/stage';
import { getIdFromEl } from '@tmagic/utils';

View File

@ -17,6 +17,12 @@
*/
import { App } from 'vue';
import type { DesignPluginOptions } from '@tmagic/design';
import designPlugin from '@tmagic/design';
import type { FormInstallOptions } from '@tmagic/form';
import formPlugin from '@tmagic/form';
import tablePlugin from '@tmagic/table';
import Code from './fields/Code.vue';
import CodeLink from './fields/CodeLink.vue';
import CodeSelect from './fields/CodeSelect.vue';
@ -35,16 +41,25 @@ import KeyValue from './fields/KeyValue.vue';
import PageFragmentSelect from './fields/PageFragmentSelect.vue';
import uiSelect from './fields/UISelect.vue';
import CodeEditor from './layouts/CodeEditor.vue';
import { setConfig } from './utils/config';
import { setEditorConfig } from './utils/config';
import Editor from './Editor.vue';
import type { InstallOptions } from './type';
import type { EditorInstallOptions } from './type';
import './theme/index.scss';
export * from '@tmagic/form';
export { default as formPlugin } from '@tmagic/form';
export * from '@tmagic/table';
export { default as tablePlugin } from '@tmagic/table';
export * from '@tmagic/stage';
export { default as StageCore } from '@tmagic/stage';
export * from '@tmagic/design';
export { default as designPlugin } from '@tmagic/design';
export * from '@tmagic/utils';
export type { OnDrag } from 'gesto';
export { DepTargetType } from '@tmagic/dep';
export type { MoveableOptions } from '@tmagic/stage';
export { DepTargetType } from '@tmagic/core';
export * from './type';
export * from './hooks';
export * from './utils';
@ -91,18 +106,23 @@ export { default as PageFragmentSelect } from './fields/PageFragmentSelect.vue';
export { default as DisplayConds } from './fields/DisplayConds.vue';
export { default as CondOpSelect } from './fields/CondOpSelect.vue';
const defaultInstallOpt: InstallOptions = {
const defaultInstallOpt: EditorInstallOptions = {
// eslint-disable-next-line no-eval
parseDSL: (dsl: string) => eval(dsl),
};
export default {
install: (app: App, opt?: Partial<InstallOptions>): void => {
install: (app: App, opt?: Partial<EditorInstallOptions | DesignPluginOptions | FormInstallOptions>): void => {
const option = Object.assign(defaultInstallOpt, opt || {});
app.use(designPlugin, opt || {});
app.use(formPlugin, opt || {});
app.use(tablePlugin);
// eslint-disable-next-line no-param-reassign
app.config.globalProperties.$TMAGIC_EDITOR = option;
setConfig(option);
setEditorConfig(option);
app.component(`${Editor.name || 'MEditor'}`, Editor);
app.component('magic-code-editor', CodeEditor);
app.component('m-fields-ui-select', uiSelect);

View File

@ -1,7 +1,16 @@
import { onBeforeUnmount, reactive, toRaw, watch } from 'vue';
import { cloneDeep } from 'lodash-es';
import type { EventOption } from '@tmagic/core';
import type {
CodeBlockContent,
DataSourceSchema,
EventOption,
Id,
MApp,
MNode,
MPage,
MPageFragment,
} from '@tmagic/core';
import {
createCodeBlockTarget,
createDataSourceCondTarget,
@ -9,8 +18,7 @@ import {
createDataSourceTarget,
DepTargetType,
Target,
} from '@tmagic/dep';
import type { CodeBlockContent, DataSourceSchema, Id, MApp, MNode, MPage, MPageFragment } from '@tmagic/schema';
} from '@tmagic/core';
import { isPage } from '@tmagic/utils';
import PropsPanel from './layouts/PropsPanel.vue';

View File

@ -22,7 +22,7 @@
import { inject, toRaw } from 'vue';
import { Plus } from '@element-plus/icons-vue';
import { NodeType } from '@tmagic/schema';
import { NodeType } from '@tmagic/core';
import MIcon from '@editor/components/Icon.vue';
import type { Services } from '@editor/type';

View File

@ -23,7 +23,7 @@ import serialize from 'serialize-javascript';
import { TMagicButton } from '@tmagic/design';
import MIcon from '@editor/components/Icon.vue';
import { getConfig } from '@editor/utils/config';
import { getEditorConfig } from '@editor/utils/config';
import monaco from '@editor/utils/monaco-editor';
defineOptions({
@ -76,7 +76,7 @@ const toString = (v: string | any, language: string): string => {
return value;
};
const parse = (v: string | any, language: string): any => {
const parseCode = (v: string | any, language: string): any => {
if (typeof v !== 'string') {
return v;
}
@ -85,7 +85,7 @@ const parse = (v: string | any, language: string): any => {
return JSON.parse(v);
}
return getConfig('parseDSL')(v);
return getEditorConfig('parseDSL')(v);
};
let vsEditor: monaco.editor.IStandaloneCodeEditor | null = null;
@ -149,7 +149,7 @@ const init = async () => {
e.stopPropagation();
const newValue = getEditorValue();
values.value = newValue;
emit('save', props.parse ? parse(newValue, props.language) : newValue);
emit('save', props.parse ? parseCode(newValue, props.language) : newValue);
}
});
@ -158,7 +158,7 @@ const init = async () => {
const newValue = getEditorValue();
if (values.value !== newValue) {
values.value = newValue;
emit('save', props.parse ? parse(newValue, props.language) : newValue);
emit('save', props.parse ? parseCode(newValue, props.language) : newValue);
}
});
}

View File

@ -65,7 +65,7 @@ import { TMagicScrollbar } from '@tmagic/design';
import SplitView from '@editor/components/SplitView.vue';
import type { FrameworkSlots, GetColumnWidth, PageBarSortOptions, Services } from '@editor/type';
import { getConfig } from '@editor/utils/config';
import { getEditorConfig } from '@editor/utils/config';
import PageBar from './page-bar/PageBar.vue';
import AddPageBox from './AddPageBox.vue';
@ -156,7 +156,7 @@ onBeforeUnmount(() => {
const saveCode = (value: string) => {
try {
const parseDSL = getConfig('parseDSL');
const parseDSL = getEditorConfig('parseDSL');
editorService?.set('root', parseDSL(value));
} catch (e: any) {
console.error(e);

View File

@ -10,7 +10,7 @@
import { computed, inject, markRaw, onBeforeUnmount, onMounted, ref } from 'vue';
import { Back, Delete, FullScreen, Grid, Memo, Right, ScaleToOriginal, ZoomIn, ZoomOut } from '@element-plus/icons-vue';
import { NodeType } from '@tmagic/schema';
import { NodeType } from '@tmagic/core';
import ToolButton from '@editor/components/ToolButton.vue';
import { ColumnLayout, MenuBarData, MenuButton, MenuComponent, MenuItem, Services } from '@editor/type';

View File

@ -41,10 +41,10 @@
import { computed, getCurrentInstance, inject, onBeforeUnmount, onMounted, ref, watchEffect } from 'vue';
import { Document as DocumentIcon } from '@element-plus/icons-vue';
import type { MNode } from '@tmagic/core';
import { TMagicButton } from '@tmagic/design';
import type { FormState, FormValue } from '@tmagic/form';
import { MForm } from '@tmagic/form';
import type { MNode } from '@tmagic/schema';
import MIcon from '@editor/components/Icon.vue';
import { useEditorContentHeight } from '@editor/hooks/use-editor-content-height';

Some files were not shown because too many files have changed in this diff Show More