feat: 统一vue ui组件,将ui中的组件独立成包

This commit is contained in:
roymondchen 2024-08-08 20:52:10 +08:00 committed by roymondchen
parent 5ed534e364
commit 3758cf8e0a
131 changed files with 1270 additions and 2447 deletions

View File

@ -1,51 +0,0 @@
<template>
<component
v-if="display"
:is="tagName"
:id="config.id"
:class="`magic-ui-component${config.className ? ` ${config.className}` : ''}`"
:style="style"
:config="config"
></component>
</template>
<script lang="ts">
import { computed, defineComponent, getCurrentInstance, inject, PropType, provide } from 'vue';
import Core from '@tmagic/core';
import { MComponent } from '@tmagic/schema';
import { toLine } from '@tmagic/utils';
export default defineComponent({
props: {
config: {
type: Object as PropType<MComponent>,
default: () => ({}),
},
},
setup(props) {
const vm = getCurrentInstance()?.proxy;
const app: Core | undefined = inject('app');
provide('hoc', vm);
return {
tagName: computed(() => `magic-ui-${toLine(props.config.type)}`),
style: computed(() => app?.transformStyle(props.config.style || {})),
display: computed(() => {
if (props.config.visible === false) return false;
if (props.config.condResult === false) return false;
const displayCfg = props.config?.display;
if (typeof displayCfg === 'function') {
return displayCfg(app);
}
return displayCfg !== false;
}),
};
},
});
</script>

View File

@ -1,64 +0,0 @@
<template>
<button class="magic-ui-button" @click="clickHandler">
<slot>
<magic-ui-text :config="textConfig"></magic-ui-text>
</slot>
</button>
</template>
<script lang="ts">
import { computed, defineComponent, getCurrentInstance, PropType, ref } from 'vue';
import type { MComponent } from '@tmagic/schema';
import useApp from '../useApp';
export default defineComponent({
props: {
config: {
type: Object as PropType<MComponent>,
default: () => ({}),
},
model: {
type: Object,
default: () => ({}),
},
},
setup(props) {
useApp(props);
const vm = getCurrentInstance()?.proxy;
const actions = ref<Function[]>([]);
const actualActions = computed(() => [
typeof props.config.preAction === 'function' ? props.config.preAction : () => true,
...actions.value,
typeof props.config.postAction === 'function' ? props.config.postAction : () => true,
]);
function pushAction(action: Function): void {
actions.value.push(action);
}
async function clickHandler(): Promise<void> {
for (const fn of actualActions.value) {
if (typeof fn === 'function') {
const ret = await fn(vm, { model: props.model });
if (ret === false) {
break;
}
}
}
}
const textConfig = computed(() => ({
type: 'text',
text: props.config?.text || '',
disabledText: props.config?.disabledText || '',
html: props.config?.html || '',
}));
return {
pushAction,
clickHandler,
textConfig,
};
},
});
</script>

View File

@ -1,52 +0,0 @@
<template>
<div
v-if="display()"
:id="config.id"
:class="`magic-ui-container magic-layout-${config.layout}${config.className ? ` ${config.className}` : ''}`"
:style="style"
>
<slot></slot>
<magic-ui-component v-for="item in config.items" :key="item.id" :config="item"></magic-ui-component>
</div>
</template>
<script lang="ts">
import { computed, defineComponent, PropType } from 'vue';
import type { MContainer } from '@tmagic/schema';
import Component from '../Component.vue';
import useApp from '../useApp';
import useCommonMethod from '../useCommonMethod';
export default defineComponent({
components: {
'magic-ui-component': Component,
},
props: {
config: {
type: Object as PropType<MContainer>,
default: () => ({}),
},
},
setup(props) {
const app = useApp(props);
return {
style: computed(() => app?.transformStyle(props.config.style || {})),
display: () => {
const displayCfg = props.config?.display;
if (typeof displayCfg === 'function') {
return displayCfg(app);
}
return displayCfg !== false;
},
...useCommonMethod(),
};
},
});
</script>

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Img from './src/index.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default Img;

View File

@ -1,29 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default [
{
text: '图片',
name: 'src',
},
{
text: '链接',
name: 'url',
type: 'data-source-input',
},
];

View File

@ -1,30 +0,0 @@
<template>
<img class="magic-ui-img" :src="config.src" @click="clickHandler" />
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import useApp from '../../useApp';
export default defineComponent({
props: {
config: {
type: Object,
default: () => ({}),
},
model: {
type: Object,
default: () => ({}),
},
},
setup(props) {
useApp(props);
return {
clickHandler() {
if (props.config.url) window.location.href = props.config.url;
},
};
},
});
</script>

View File

@ -1,54 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Button from './button';
import Container from './container';
import Img from './img';
import IteratorContainer from './iterator-container';
import Overlay from './overlay';
import Page from './page';
import PageFragment from './page-fragment';
import PageFragmentContainer from './page-fragment-container';
import QRcode from './qrcode';
import Text from './text';
export { default as TMagicUiButton } from './button';
export { default as TMagicUiContainer } from './container';
export { default as TMagicUiImg } from './img';
export { default as TMagicUiIteratorContainer } from './iterator-container';
export { default as TMagicUiPage } from './page';
export { default as TMagicUiPageFragment } from './page-fragment';
export { default as TMagicUiPageFragmentContainer } from './page-fragment-container';
export { default as TMagicUiPageText } from './text';
export { default as useApp } from './useApp';
const ui: Record<string, any> = {
page: Page,
container: Container,
button: Button,
text: Text,
img: Img,
qrcode: QRcode,
overlay: Overlay,
'page-fragment-container': PageFragmentContainer,
'page-fragment': PageFragment,
'iterator-container': IteratorContainer,
};
export default ui;

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import IteratorContainer from './src/IteratorContainer.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default IteratorContainer;

View File

@ -1,67 +0,0 @@
<template>
<div class="magic-ui-iterator-container" :id="`${config.id || ''}`" :style="style">
<Container v-for="(item, index) in configs" :key="index" :config="item"></Container>
</div>
</template>
<script lang="ts" setup>
import { computed, inject } from 'vue';
import Core from '@tmagic/core';
import type { MContainer } from '@tmagic/schema';
import Container from '../../container';
import useApp from '../../useApp';
const props = withDefaults(
defineProps<{
config: MContainer & {
type: 'iterator-container';
iteratorData: any[];
dsField: string[];
itemConfig: {
layout: string;
style: Record<string, string | number>;
};
};
model?: any;
}>(),
{
model: () => ({}),
},
);
const app: Core | undefined = inject('app');
const style = computed(() => app?.transformStyle(props.config.style || {}));
const configs = computed(() => {
let { iteratorData = [] } = props.config;
if (!Array.isArray(iteratorData)) {
iteratorData = [];
}
if (app?.platform === 'editor' && !iteratorData.length) {
iteratorData.push({});
}
return iteratorData.map((itemData) => ({
items:
app?.dataSourceManager?.compliedIteratorItems(itemData, props.config.items, props.config.dsField) ??
props.config.items,
id: '',
style: {
...props.config.itemConfig.style,
position: 'relative',
left: 0,
top: 0,
},
}));
});
useApp({
config: props.config,
methods: {},
});
</script>

View File

@ -1,113 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { DATA_SOURCE_FIELDS_SELECT_VALUE_PREFIX } from '@tmagic/utils';
export default [
{
name: 'iteratorData',
text: '数据源数据',
value: 'value',
dataSourceFieldType: ['array'],
checkStrictly: true,
type: 'data-source-field-select',
onChange: (vm: any, v: string[] = [], { model }: any) => {
if (Array.isArray(v) && v.length > 1) {
const [dsId, ...keys] = v;
model.dsField = [dsId.replace(DATA_SOURCE_FIELDS_SELECT_VALUE_PREFIX, ''), ...keys];
} else {
model.dsField = [];
}
},
},
{
name: 'dsField',
type: 'hidden',
},
{
type: 'panel',
title: '子项配置',
name: 'itemConfig',
items: [
{
name: 'layout',
text: '容器布局',
type: 'select',
defaultValue: 'absolute',
options: [
{ value: 'absolute', text: '绝对定位' },
{ value: 'relative', text: '流式布局', disabled: true },
],
},
{
type: 'fieldset',
legend: '样式',
name: 'style',
items: [
{
name: 'width',
text: '宽度',
},
{
name: 'height',
text: '高度',
},
{
text: 'overflow',
name: 'overflow',
type: 'select',
options: [
{ text: 'visible', value: 'visible' },
{ text: 'hidden', value: 'hidden' },
{ text: 'clip', value: 'clip' },
{ text: 'scroll', value: 'scroll' },
{ text: 'auto', value: 'auto' },
{ text: 'overlay', value: 'overlay' },
],
},
{
name: 'backgroundImage',
text: '背景图',
},
{
name: 'backgroundColor',
text: '背景颜色',
type: 'colorPicker',
},
{
name: 'backgroundRepeat',
text: '背景图重复',
type: 'select',
defaultValue: 'no-repeat',
options: [
{ text: 'repeat', value: 'repeat' },
{ text: 'repeat-x', value: 'repeat-x' },
{ text: 'repeat-y', value: 'repeat-y' },
{ text: 'no-repeat', value: 'no-repeat' },
{ text: 'inherit', value: 'inherit' },
],
},
{
name: 'backgroundSize',
text: '背景图大小',
defaultValue: '100% 100%',
},
],
},
],
},
];

View File

@ -1,25 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Overlay from './src/index.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export { default as event } from './src/event';
export default Overlay;

View File

@ -1,75 +0,0 @@
<template>
<magic-ui-container v-if="visible" class="magic-ui-overlay" :config="{ items: config.items }">
<slot></slot>
</magic-ui-container>
</template>
<script lang="ts">
import { defineComponent, onBeforeUnmount, ref } from 'vue';
import Core from '@tmagic/core';
import type { MContainer, MNode, MPage } from '@tmagic/schema';
import useApp from '../../useApp';
export default defineComponent({
props: {
config: {
type: Object,
default: () => ({}),
},
model: {
type: Object,
default: () => ({}),
},
},
setup(props) {
const visible = ref(false);
const app: Core | undefined = useApp(props);
const node = app?.page?.getNode(props.config.id);
const openOverlay = () => {
visible.value = true;
if (app) {
app.emit('overlay:open', node);
}
};
const closeOverlay = () => {
visible.value = false;
if (app) {
app.emit('overlay:close', node);
}
};
const editorSelectHandler = (
info: {
node: MNode;
page: MPage;
parent: MContainer;
},
path: MNode[],
) => {
if (path.find((node: MNode) => node.id === props.config.id)) {
openOverlay();
} else {
closeOverlay();
}
};
app?.page?.on('editor:select', editorSelectHandler);
onBeforeUnmount(() => {
app?.page?.off('editor:select', editorSelectHandler);
});
return {
visible,
openOverlay,
closeOverlay,
};
},
});
</script>

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import PageFragmentContainer from './src/PageFragmentContainer.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default PageFragmentContainer;

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import PageFragment from './src/PageFragment.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default PageFragment;

View File

@ -1,42 +0,0 @@
<template>
<div
:id="`${config.id || ''}`"
:class="`magic-ui-page-fragment magic-ui-container magic-layout-${config.layout}${
config.className ? ` ${config.className}` : ''
}`"
:style="style"
>
<slot></slot>
<magic-ui-component v-for="item in config.items" :key="item.id" :config="item"></magic-ui-component>
</div>
</template>
<script lang="ts">
import { computed, defineComponent, PropType } from 'vue';
import type { MPageFragment } from '@tmagic/schema';
import MComponent from '../../Component.vue';
import useApp from '../../useApp';
export default defineComponent({
components: {
'magic-ui-component': MComponent,
},
props: {
config: {
type: Object as PropType<MPageFragment>,
default: () => ({}),
},
},
setup(props) {
const app = useApp(props);
return {
style: computed(() => app?.transformStyle(props.config.style || {})),
};
},
});
</script>

View File

@ -1,46 +0,0 @@
<template>
<div
:id="config.id"
:class="`magic-ui-page magic-ui-container magic-layout-${config.layout}${
config.className ? ` ${config.className}` : ''
}`"
:style="style"
>
<slot></slot>
<magic-ui-component v-for="item in config.items" :key="item.id" :config="item"></magic-ui-component>
</div>
</template>
<script lang="ts">
import { computed, defineComponent, PropType } from 'vue';
import type { MPage } from '@tmagic/schema';
import Component from '../Component.vue';
import useApp from '../useApp';
export default defineComponent({
components: {
'magic-ui-component': Component,
},
props: {
config: {
type: Object as PropType<MPage>,
default: () => ({}),
},
},
setup(props) {
const app = useApp(props);
return {
style: computed(() => app?.transformStyle(props.config.style || {})),
refresh() {
window.location.reload();
},
};
},
});
</script>

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Qrcode from './src/index.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default Qrcode;

View File

@ -1,67 +0,0 @@
<script lang="ts">
import { computed, defineComponent, getCurrentInstance, h, inject, PropType } from 'vue';
import type { MComponent } from '@tmagic/schema';
import useApp from '../useApp';
export default defineComponent({
props: {
config: {
type: Object as PropType<MComponent>,
default: () => ({}),
},
model: {
type: Object,
default: () => ({}),
},
vars: {
type: Object,
default: () => ({}),
},
},
setup(props) {
useApp(props);
const vm = getCurrentInstance()?.proxy;
const hoc: any = inject('hoc');
const displayText = computed(() => {
let text = props.config?.text || '';
const { vars } = props;
if (hoc?.disabled && props.config?.disabledText) {
text = props.config.disabledText;
}
if (typeof text === 'function') {
return text.bind(vm)(vm, { model: props.model });
}
if (Object.prototype.toString.call(vars) === '[object Object]') {
let tmp: string = text;
Object.entries(vars).forEach(([key, value]) => {
tmp = tmp.replace(new RegExp(`{{${key}}}`, 'g'), value);
});
return tmp;
}
return text || '';
});
return {
displayText,
};
},
render() {
const className = this.config?.multiple ? 'magic-ui-text' : 'magic-ui-text magic-ui-text--single-line';
if (typeof this.$slots?.default === 'function') {
return h('p', { class: className }, [this.$slots?.default?.() || '']);
}
return h('p', {
class: className,
domProps: {
innerHTML: this.displayText,
},
});
},
});
</script>

View File

@ -1,40 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { getCurrentInstance, inject, onBeforeUnmount, onMounted } from 'vue';
import Core from '@tmagic/core';
export default (props: any) => {
const app: Core | undefined = inject('app');
const node = app?.page?.getNode(props.config.id);
const vm = getCurrentInstance()?.proxy;
node?.emit('created', vm);
onMounted(() => {
node?.emit('mounted', vm);
});
onBeforeUnmount(() => {
node?.emit('destroy', vm);
});
return app;
};

View File

@ -1,31 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { getCurrentInstance } from 'vue';
export default () => {
const vm = getCurrentInstance()?.proxy;
return {
show: () => {
vm.$set(vm.config.style, 'display', 'initial');
},
hide: () => {
vm.$set(vm.config.style, 'display', 'none');
},
};
};

View File

@ -12,9 +12,6 @@
"dist",
"types"
],
"scripts": {
"build": "node scripts/build.mjs"
},
"engines": {
"node": ">=18"
},
@ -24,14 +21,18 @@
"url": "https://github.com/Tencent/tmagic-editor.git"
},
"dependencies": {
"qrcode": "^1.5.0"
"@tmagic/vue-button": "workspace:*",
"@tmagic/vue-container": "workspace:*",
"@tmagic/vue-img": "workspace:*",
"@tmagic/vue-iterator-container": "workspace:*",
"@tmagic/vue-overlay": "workspace:*",
"@tmagic/vue-page": "workspace:*",
"@tmagic/vue-page-fragment": "workspace:*",
"@tmagic/vue-page-fragment-container": "workspace:*",
"@tmagic/vue-qrcode": "workspace:*",
"@tmagic/vue-text": "workspace:*"
},
"peerDependencies": {
"@tmagic/core": "workspace:*",
"@tmagic/schema": "workspace:*",
"@tmagic/utils": "workspace:*",
"@tmagic/vue-runtime-help": "workspace:*",
"vue": ">=3.4.27",
"typescript": "*"
},
"peerDependenciesMeta": {
@ -40,8 +41,6 @@
}
},
"devDependencies": {
"@types/qrcode": "^1.4.2",
"@vue/compiler-sfc": "^3.4.27",
"rimraf": "^3.0.2",
"vite": "^5.3.5"
}

View File

@ -1,120 +0,0 @@
import { build } from 'vite';
import vue from '@vitejs/plugin-vue';
import path from 'node:path';
import { fileURLToPath } from 'node:url';
import pkg from '../package.json' assert { type: 'json' };
const __dirname = fileURLToPath(new URL('.', import.meta.url));
const packages = [
'button',
'container',
'img',
'iterator-container',
'overlay',
'page',
'page-fragment',
'page-fragment-container',
'qrcode',
'text',
];
const commonConfig = {
optimizeDeps: {
esbuildOptions: {
define: {
global: 'globalThis',
},
},
},
build: {
cssCodeSplit: false,
sourcemap: false,
minify: false,
target: 'esnext',
rollupOptions: {
output: {
// 在 UMD 构建模式下为这些外部化的依赖提供一个全局变量
globals: {
vue: 'Vue',
},
},
},
},
};
const main = async () => {
await build({
...commonConfig,
root: path.resolve(__dirname, `../`),
build: {
...commonConfig.build,
outDir: `./dist`,
lib: {
entry: './src/index.ts',
name: 'ui',
fileName: 'index',
formats: ['es'],
},
rollupOptions: {
...commonConfig.build.rollupOptions,
// 确保外部化处理那些你不想打包进库的依赖
external(id) {
return (
Object.keys({
...(pkg.devDependencies || {}),
...(pkg.peerDependencies || {}),
}).some((k) => new RegExp(`^${k}`).test(id)) ||
`${id}`.startsWith('.') ||
(`${id}`.startsWith('/') && !id.endsWith('/index.ts'))
);
},
},
},
});
packages.map((packageName) => {
const config = {
...commonConfig,
plugins: [vue()],
root: path.resolve(__dirname, `../src/${packageName}`),
build: {
...commonConfig.build,
outDir: `../../dist/${packageName}`,
lib: {
entry: './index.ts',
name: packageName,
fileName: 'index',
formats: ['es'],
},
rollupOptions: {
...commonConfig.build.rollupOptions,
// 确保外部化处理那些你不想打包进库的依赖
external(id) {
return (
Object.keys({
...(pkg.devDependencies || {}),
...(pkg.peerDependencies || {}),
}).some((k) => new RegExp(`^${k}`).test(id)) || `${id}`.endsWith('./container')
);
},
},
},
};
return build(config);
});
};
main();

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Button from './src/index.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default Button;

View File

@ -1,25 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default [
{
text: '文本',
name: 'text',
type: 'data-source-input',
},
];

View File

@ -1,32 +0,0 @@
<template>
<button class="magic-ui-button">
<slot>
<p>{{ config?.text || '' }}</p>
</slot>
</button>
</template>
<script lang="ts" setup>
import type { MComponent } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
interface ButtonSchema extends MComponent {
type: 'button';
text: string;
}
const props = withDefaults(
defineProps<{
config: ButtonSchema;
model?: any;
}>(),
{
model: () => ({}),
},
);
useApp({
config: props.config,
methods: {},
});
</script>

View File

@ -1,28 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
text: '请输入文本内容',
multiple: true,
style: {
width: '270',
height: '37.5',
border: 0,
backgroundColor: '#fb6f00',
},
};

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Container from './src/Container.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default Container;

View File

@ -1,41 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default [
{
name: 'layout',
text: '容器布局',
type: 'select',
defaultValue: 'absolute',
options: [
{ value: 'absolute', text: '绝对定位' },
{ value: 'relative', text: '流式布局' },
],
onChange: (formState: any, v: string, { model }: any) => {
if (!model.style) return v;
if (v === 'relative') {
model.style.height = 'auto';
} else {
const el = formState.stage?.renderer?.contentWindow.document.getElementById(model.id);
if (el) {
model.style.height = el.getBoundingClientRect().height;
}
}
},
},
];

View File

@ -1,25 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
items: [],
style: {
width: '375',
height: '100',
},
};

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Img from './src/index.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default Img;

View File

@ -1,33 +0,0 @@
<template>
<img class="magic-ui-img" :src="config.src" @click="clickHandler" />
</template>
<script lang="ts" setup>
import type { MComponent } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
interface ImgSchema extends MComponent {
type: 'img';
src: string;
url: string;
}
const props = withDefaults(
defineProps<{
config: ImgSchema;
model?: any;
}>(),
{
model: () => ({}),
},
);
const clickHandler = () => {
if (props.config.url) window.location.href = props.config.url;
};
useApp({
config: props.config,
methods: {},
});
</script>

View File

@ -1,28 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
src: 'https://puui.qpic.cn/vupload/0/1573555382625_bhp0wud8l6w.png/0',
url: '',
style: {
position: 'absolute',
left: '57',
width: '176',
height: '176',
},
};

View File

@ -16,27 +16,27 @@
* limitations under the License.
*/
import Button from './button';
import Container from './container';
import Img from './img';
import IteratorContainer from './iterator-container';
import Overlay from './overlay';
import Page from './page';
import PageFragment from './page-fragment';
import PageFragmentContainer from './page-fragment-container';
import QRcode from './qrcode';
import Text from './text';
import Button from '@tmagic/vue-button';
import Container from '@tmagic/vue-container';
import Img from '@tmagic/vue-img';
import IteratorContainer from '@tmagic/vue-iterator-container';
import Overlay from '@tmagic/vue-overlay';
import Page from '@tmagic/vue-page';
import PageFragment from '@tmagic/vue-page-fragment';
import PageFragmentContainer from '@tmagic/vue-page-fragment-container';
import QRcode from '@tmagic/vue-qrcode';
import Text from '@tmagic/vue-text';
export { default as TMagicUiButton } from './button';
export { default as TMagicUiContainer } from './container';
export { default as TMagicUiImg } from './img';
export { default as TMagicUiIteratorContainer } from './iterator-container';
export { default as TMagicUiOverlay } from './overlay';
export { default as TMagicUiPage } from './page';
export { default as TMagicUiPageFragment } from './page-fragment';
export { default as TMagicUiPageFragmentContainer } from './page-fragment-container';
export { default as TMagicUiQRcode } from './qrcode';
export { default as TMagicUiText } from './text';
export { default as TMagicUiButton } from '@tmagic/vue-button';
export { default as TMagicUiContainer } from '@tmagic/vue-container';
export { default as TMagicUiImg } from '@tmagic/vue-img';
export { default as TMagicUiIteratorContainer } from '@tmagic/vue-iterator-container';
export { default as TMagicUiOverlay } from '@tmagic/vue-overlay';
export { default as TMagicUiPage } from '@tmagic/vue-page';
export { default as TMagicUiPageFragment } from '@tmagic/vue-page-fragment';
export { default as TMagicUiPageFragmentContainer } from '@tmagic/vue-page-fragment-container';
export { default as TMagicUiQRcode } from '@tmagic/vue-qrcode';
export { default as TMagicUiText } from '@tmagic/vue-text';
const ui: Record<string, any> = {
page: Page,

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import IteratorContainer from './src/IteratorContainer.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default IteratorContainer;

View File

@ -1,111 +0,0 @@
<template>
<div
class="magic-ui-iterator-container"
:data-iterator-index="dataIteratorIndex"
:data-iterator-container-id="dataIteratorContainerId"
>
<Container
v-for="(item, index) in configs"
:iterator-index="[...(dataIteratorIndex || []), index]"
:iterator-container-id="[...(dataIteratorContainerId || []), config.id]"
:key="index"
:config="item"
></Container>
</div>
</template>
<script lang="ts" setup>
import { computed, watch } from 'vue';
import type { IteratorContainer as TMagicIteratorContainer } from '@tmagic/core';
import { type Id, type MIteratorContainer, NodeType } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
import Container from '../../container';
const props = withDefaults(
defineProps<{
config: MIteratorContainer;
model?: any;
dataIteratorIndex?: number[];
dataIteratorContainerId?: Id[];
}>(),
{
model: () => ({}),
},
);
const { app } = useApp({
config: props.config,
iteratorContainerId: props.dataIteratorContainerId,
iteratorIndex: props.dataIteratorIndex,
methods: {},
});
const configs = computed(() => {
let { iteratorData = [] } = props.config;
const { id, itemConfig, dsField, items } = props.config;
if (!Array.isArray(iteratorData)) {
iteratorData = [];
}
if (app?.platform === 'editor' && !iteratorData.length) {
iteratorData.push({});
}
return iteratorData.map((itemData) => {
const condResult =
app?.platform !== 'editor'
? app?.dataSourceManager?.compliedIteratorItemConds(itemData, itemConfig, dsField) ?? true
: true;
const newItems =
app?.dataSourceManager?.compliedIteratorItems(
id,
itemData,
items,
dsField,
props.dataIteratorContainerId,
props.dataIteratorIndex,
) ?? items;
return {
items: newItems,
id: '',
type: NodeType.CONTAINER,
condResult,
style: {
...itemConfig.style,
position: 'relative',
left: 0,
top: 0,
},
};
});
});
watch(
configs,
(configs) => {
const iteratorContainerNode = app?.getNode<TMagicIteratorContainer>(
props.config.id,
props.dataIteratorContainerId,
props.dataIteratorIndex,
);
if (!iteratorContainerNode) {
return;
}
iteratorContainerNode.resetNodes();
configs.forEach((config, index) => {
iteratorContainerNode.setNodes(config.items, index);
});
},
{
immediate: true,
},
);
</script>

View File

@ -1,31 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
style: {
width: '375',
height: '100',
},
itemConfig: {
style: {
width: '100%',
height: '100%',
},
},
items: [],
};

View File

@ -1,25 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Overlay from './src/index.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export { default as event } from './src/event';
export default Overlay;

View File

@ -1,22 +0,0 @@
export default {
methods: [
{
label: '打开蒙层',
value: 'openOverlay',
},
{
label: '关闭蒙层',
value: 'closeOverlay',
},
],
events: [
{
label: '打开蒙层',
value: 'overlay:open',
},
{
label: '关闭蒙层',
value: 'overlay:close',
},
],
};

View File

@ -1 +0,0 @@
export default [];

View File

@ -1,63 +0,0 @@
<template>
<magic-ui-container v-if="visible" class="magic-ui-overlay" :config="{ items: config.items }">
<slot></slot>
</magic-ui-container>
</template>
<script lang="ts" setup>
import { onBeforeUnmount, ref } from 'vue';
import type { MContainer, MNode, MPage } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
interface OverlaySchema extends MContainer {
type: 'overlay';
}
const props = withDefaults(
defineProps<{
config: OverlaySchema;
model?: any;
}>(),
{
model: () => ({}),
},
);
const visible = ref(false);
const { app, node } = useApp({
config: props.config,
methods: {
openOverlay() {
visible.value = true;
app?.emit('overlay:open', node);
},
closeOverlay() {
visible.value = false;
app?.emit('overlay:close', node);
},
},
});
const editorSelectHandler = (
info: {
node: MNode;
page: MPage;
parent: MContainer;
},
path: MNode[],
) => {
if (path.find((node: MNode) => node.id === props.config.id)) {
node?.instance.openOverlay();
} else {
node?.instance.closeOverlay();
}
};
app?.page?.on('editor:select', editorSelectHandler);
onBeforeUnmount(() => {
app?.page?.off('editor:select', editorSelectHandler);
});
</script>

View File

@ -1,11 +0,0 @@
export default {
style: {
position: 'fixed',
width: '100%',
height: '100%',
top: 0,
left: 0,
backgroundColor: 'rgba(0, 0, 0, 0.8)',
},
items: [],
};

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import PageFragmentContainer from './src/PageFragmentContainer.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default PageFragmentContainer;

View File

@ -1,67 +0,0 @@
<template>
<div :id="`${config.id || ''}`" class="magic-ui-page-fragment-container">
<Container :config="containerConfig" :model="model"></Container>
</div>
</template>
<script lang="ts" setup>
import { computed } from 'vue';
import { type MComponent, type MNode, NodeType } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
import Container from '../../container';
const props = withDefaults(
defineProps<{
config: MComponent;
model?: any;
}>(),
{
model: () => ({}),
},
);
const { app } = useApp({
config: props.config,
methods: {},
});
const fragment = computed(() => app?.dsl?.items?.find((page) => page.id === props.config.pageFragmentId));
const containerConfig = computed(() => {
if (!fragment.value) return { items: [], id: '', type: NodeType.CONTAINER };
const { id, type, items, ...others } = fragment.value;
const itemsWithoutId = items.map((item: MNode) => {
const { id, ...otherConfig } = item;
return {
id: '',
...otherConfig,
};
});
if (app?.platform === 'editor') {
return {
...others,
items: itemsWithoutId,
id: '',
type: NodeType.CONTAINER,
};
}
return {
...others,
items,
id: '',
type: NodeType.CONTAINER,
};
});
</script>
<style scoped>
.in-editor .magic-ui-page-fragment-container {
min-width: 100px;
min-height: 100px;
}
</style>

View File

@ -1,25 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default [
{
name: 'pageFragmentId',
text: '页面片ID',
type: 'page-fragment-select',
},
];

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
style: {
width: '',
height: '',
},
};

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import PageFragment from './src/PageFragment.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default PageFragment;

View File

@ -1,25 +0,0 @@
<template>
<MContainer class="magic-ui-page-fragment" :config="config"></MContainer>
</template>
<script lang="ts" setup>
import type { MPageFragment } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
import MContainer from '../../container';
const props = withDefaults(
defineProps<{
config: MPageFragment;
model?: any;
}>(),
{
model: () => ({}),
},
);
useApp({
config: props.config,
methods: {},
});
</script>

View File

@ -1,50 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default [
{
text: '页面片标识',
name: 'name',
disabled: true,
},
{
text: '页面片标题',
name: 'title',
},
{
name: 'layout',
text: '容器布局',
type: 'select',
defaultValue: 'absolute',
options: [
{ value: 'absolute', text: '绝对定位' },
{ value: 'relative', text: '流式布局' },
],
onChange: (formState: any, v: string, { model }: any) => {
if (!model.style) return v;
if (v === 'relative') {
model.style.height = 'auto';
} else {
const el = formState.stage?.renderer?.contentWindow.document.getElementById(model.id);
if (el) {
model.style.height = el.getBoundingClientRect().height;
}
}
},
},
];

View File

@ -1,25 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
items: [],
style: {
width: '375',
height: '817',
},
};

View File

@ -1,25 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Page from './src/index.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export { default as event } from './src/event';
export default Page;

View File

@ -1,8 +0,0 @@
export default {
methods: [
{
label: '刷新页面',
value: 'refresh',
},
],
};

View File

@ -1,52 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default [
{
text: '页面标识',
name: 'name',
disabled: true,
extra: '在多页面的情况下用来指定要打开的页面',
},
{
text: '页面标题',
name: 'title',
type: 'data-source-input',
},
{
name: 'layout',
text: '容器布局',
type: 'select',
defaultValue: 'absolute',
options: [
{ value: 'absolute', text: '绝对定位' },
{ value: 'relative', text: '流式布局' },
],
onChange: (formState: any, v: string, { model }: any) => {
if (!model.style) return v;
if (v === 'relative') {
model.style.height = 'auto';
} else {
const el = formState.stage?.renderer?.contentWindow.document.getElementById(model.id);
if (el) {
model.style.height = el.getBoundingClientRect().height;
}
}
},
},
];

View File

@ -1,29 +0,0 @@
<template>
<MContainer class="magic-ui-page" :config="config"></MContainer>
</template>
<script lang="ts" setup>
import type { MPage } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
import MContainer from '../../container';
const props = withDefaults(
defineProps<{
config: MPage;
model?: any;
}>(),
{
model: () => ({}),
},
);
const refresh = () => {
window.location.reload();
};
useApp({
config: props.config,
methods: { refresh },
});
</script>

View File

@ -1,25 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
items: [],
style: {
width: '100%',
height: '100%',
},
};

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Qrcode from './src/index.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default Qrcode;

View File

@ -1,25 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default [
{
text: '链接',
name: 'url',
type: 'data-source-input',
},
];

View File

@ -1,41 +0,0 @@
<template>
<img class="magic-ui-qrcode" :src="imgUrl" />
</template>
<script lang="ts" setup>
import { ref, watch } from 'vue';
import QRCode from 'qrcode';
import type { MComponent } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
const props = withDefaults(
defineProps<{
config: MComponent;
model?: any;
}>(),
{
model: () => ({}),
},
);
const imgUrl = ref();
watch(
() => props.config.url,
(url = '') => {
QRCode.toDataURL(url, (e: any, url: string) => {
if (e) console.error(e);
imgUrl.value = url;
});
},
{
immediate: true,
},
);
useApp({
config: props.config,
methods: {},
});
</script>

View File

@ -1,27 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
url: 'https://m.film.qq.com',
style: {
position: 'absolute',
left: '57',
width: '176',
height: '176',
},
};

View File

@ -1,24 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Text from './src/index.vue';
export { default as config } from './src/formConfig';
export { default as value } from './src/initValue';
export default Text;

View File

@ -1,30 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default [
{
name: 'text',
text: '文本',
type: 'data-source-input',
},
{
name: 'multiple',
text: '多行文本',
type: 'switch',
},
];

View File

@ -1,23 +0,0 @@
<template>
<p>{{ config.text }}</p>
</template>
<script lang="ts" setup>
import type { MComponent } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
const props = withDefaults(
defineProps<{
config: MComponent & { type: 'text'; text: string };
model?: any;
}>(),
{
model: () => ({}),
},
);
useApp({
config: props.config,
methods: {},
});
</script>

View File

@ -1,27 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
type: 'text',
text: '请输入文本内容',
multiple: true,
style: {
width: '100',
height: 'auto',
},
};

View File

@ -1,45 +0,0 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/* style */
export type PartCSSStyle = {
[key in keyof CSSStyleDeclaration]?: string | number;
};
export type CSSStyleKey = keyof CSSStyleDeclaration;
export type CanModifyCSSStyleKey = Exclude<CSSStyleKey, 'length' | 'parentRule'>;
export type StyleCfg = ((p1: any, p2: any) => PartCSSStyle) | PartCSSStyle;
/* event */
export interface MEvent {
name: string;
to: number | string;
method: string;
}
export interface MEventInMap {
from: number | string;
to: number | string;
method: string;
}
export type MEventMapType = Record<string, MEventInMap[]>;
export type MEventQueueMapType = Record<string | number, MEventInMap[]>;
export interface MEventBus {
$on: (...args: any) => void;
$off: (...args: any) => void;
$once: (...args: any) => void;
$emit: (...args: any) => void;
}

339
pnpm-lock.yaml generated
View File

@ -635,34 +635,40 @@ importers:
packages/ui:
dependencies:
'@tmagic/core':
'@tmagic/vue-button':
specifier: workspace:*
version: link:../core
'@tmagic/schema':
version: link:../../vue-components/button
'@tmagic/vue-container':
specifier: workspace:*
version: link:../schema
'@tmagic/utils':
version: link:../../vue-components/container
'@tmagic/vue-img':
specifier: workspace:*
version: link:../utils
'@tmagic/vue-runtime-help':
version: link:../../vue-components/img
'@tmagic/vue-iterator-container':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
qrcode:
specifier: ^1.5.0
version: 1.5.3
version: link:../../vue-components/iterator-container
'@tmagic/vue-overlay':
specifier: workspace:*
version: link:../../vue-components/overlay
'@tmagic/vue-page':
specifier: workspace:*
version: link:../../vue-components/page
'@tmagic/vue-page-fragment':
specifier: workspace:*
version: link:../../vue-components/page-fragment
'@tmagic/vue-page-fragment-container':
specifier: workspace:*
version: link:../../vue-components/page-fragment-container
'@tmagic/vue-qrcode':
specifier: workspace:*
version: link:../../vue-components/qrcode
'@tmagic/vue-text':
specifier: workspace:*
version: link:../../vue-components/text
typescript:
specifier: '*'
version: 5.5.4
vue:
specifier: '>=3.4.27'
version: 3.4.35(typescript@5.5.4)
devDependencies:
'@types/qrcode':
specifier: ^1.4.2
version: 1.5.5
'@vue/compiler-sfc':
specifier: ^3.4.27
version: 3.4.35
rimraf:
specifier: ^3.0.2
version: 3.0.2
@ -701,31 +707,6 @@ importers:
specifier: ^18.3.0
version: 18.3.0
packages/ui-vue2:
dependencies:
'@tmagic/core':
specifier: workspace:*
version: link:../core
'@tmagic/schema':
specifier: workspace:*
version: link:../schema
'@tmagic/utils':
specifier: workspace:*
version: link:../utils
qrcode:
specifier: ^1.5.0
version: 1.5.3
typescript:
specifier: '*'
version: 5.5.4
vue:
specifier: '>=2.7.4'
version: 3.4.35(typescript@5.5.4)
devDependencies:
vue-template-compiler:
specifier: ^2.7.4
version: 2.7.16
packages/utils:
dependencies:
'@tmagic/schema':
@ -882,8 +863,8 @@ importers:
version: 5.31.3
devDependencies:
'@tmagic/cli':
specifier: 1.4.6
version: 1.4.6(typescript@5.5.4)
specifier: workspace:*
version: link:../../packages/cli
'@types/lodash-es':
specifier: ^4.17.4
version: 4.17.12
@ -982,7 +963,7 @@ importers:
specifier: '>=2.0.0 || >=3.0.0'
version: 3.4.35(typescript@5.5.4)
vue-demi:
specifier: ^0.14.7
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
devDependencies:
'@types/node':
@ -1026,8 +1007,8 @@ importers:
version: 2.7.16
devDependencies:
'@tmagic/cli':
specifier: 1.4.6
version: 1.4.6(typescript@5.5.4)
specifier: workspace:*
version: link:../../packages/cli
'@types/events':
specifier: ^3.0.0
version: 3.0.3
@ -1084,8 +1065,8 @@ importers:
version: 3.4.35(typescript@5.5.4)
devDependencies:
'@tmagic/cli':
specifier: 1.4.5
version: 1.4.5
specifier: workspace:*
version: link:../../packages/cli
'@types/node':
specifier: ^18.19.0
version: 18.19.42
@ -1123,6 +1104,223 @@ importers:
specifier: ^5.3.5
version: 5.3.5(@types/node@18.19.42)(sass@1.77.8)(terser@5.31.3)
vue-components/button:
dependencies:
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
'@vue/composition-api':
specifier: '>=1.7.2'
version: 1.7.2(vue@3.4.35(typescript@5.5.4))
typescript:
specifier: '*'
version: 5.5.4
vue:
specifier: '>=2.0.0 || >=3.0.0'
version: 3.4.35(typescript@5.5.4)
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
vue-components/container:
dependencies:
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/utils':
specifier: workspace:*
version: link:../../packages/utils
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
'@vue/composition-api':
specifier: '>=1.7.2'
version: 1.7.2(vue@3.4.35(typescript@5.5.4))
typescript:
specifier: '*'
version: 5.5.4
vue:
specifier: '>=2.0.0 || >=3.0.0'
version: 3.4.35(typescript@5.5.4)
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
vue-components/img:
dependencies:
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
'@vue/composition-api':
specifier: '>=1.7.2'
version: 1.7.2(vue@3.4.35(typescript@5.5.4))
typescript:
specifier: '*'
version: 5.5.4
vue:
specifier: '>=2.0.0 || >=3.0.0'
version: 3.4.35(typescript@5.5.4)
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
vue-components/iterator-container:
dependencies:
'@tmagic/core':
specifier: workspace:*
version: link:../../packages/core
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/utils':
specifier: workspace:*
version: link:../../packages/utils
'@tmagic/vue-container':
specifier: workspace:*
version: link:../container
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
'@vue/composition-api':
specifier: '>=1.7.2'
version: 1.7.2(vue@3.4.35(typescript@5.5.4))
typescript:
specifier: '*'
version: 5.5.4
vue:
specifier: '>=2.0.0 || >=3.0.0'
version: 3.4.35(typescript@5.5.4)
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
vue-components/overlay:
dependencies:
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/vue-container':
specifier: workspace:*
version: link:../container
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
typescript:
specifier: '*'
version: 5.5.4
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
vue-components/page:
dependencies:
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/vue-container':
specifier: workspace:*
version: link:../container
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
typescript:
specifier: '*'
version: 5.5.4
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
vue-components/page-fragment:
dependencies:
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/vue-container':
specifier: workspace:*
version: link:../container
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
typescript:
specifier: '*'
version: 5.5.4
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
vue-components/page-fragment-container:
dependencies:
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/vue-container':
specifier: workspace:*
version: link:../container
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
typescript:
specifier: '*'
version: 5.5.4
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
vue-components/qrcode:
dependencies:
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
'@vue/composition-api':
specifier: '>=1.7.2'
version: 1.7.2(vue@3.4.35(typescript@5.5.4))
qrcode:
specifier: ^1.5.0
version: 1.5.3
typescript:
specifier: '*'
version: 5.5.4
vue:
specifier: '>=2.0.0 || >=3.0.0'
version: 3.4.35(typescript@5.5.4)
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
devDependencies:
'@types/qrcode':
specifier: ^1.4.2
version: 1.5.5
vue-components/text:
dependencies:
'@tmagic/schema':
specifier: workspace:*
version: link:../../packages/schema
'@tmagic/vue-runtime-help':
specifier: workspace:*
version: link:../../runtime/vue-runtime-help
'@vue/composition-api':
specifier: '>=1.7.2'
version: 1.7.2(vue@3.4.35(typescript@5.5.4))
typescript:
specifier: '*'
version: 5.5.4
vue:
specifier: '>=2.0.0 || >=3.0.0'
version: 3.4.35(typescript@5.5.4)
vue-demi:
specifier: ^0.14.10
version: 0.14.10(@vue/composition-api@1.7.2(vue@3.4.35(typescript@5.5.4)))(vue@3.4.35(typescript@5.5.4))
packages:
'@algolia/autocomplete-core@1.9.3':
@ -2329,21 +2527,6 @@ packages:
'@sxzz/popperjs-es@2.11.7':
resolution: {integrity: sha512-Ccy0NlLkzr0Ex2FKvh2X+OyERHXJ88XJ1MXtsI9y9fGexlaXaVTPzBCRBwIxFkORuOb+uBqeu+RqnpgYTEZRUQ==}
'@tmagic/cli@1.4.5':
resolution: {integrity: sha512-k+NMTXrQsuP+DZyxghCsh0fBkBVibu2pHquhfR9FW1lb9AkB4fHYwDmoxQo3vgenFXR3CeQQPrdLBX6tTtc9dg==}
engines: {node: '>=18'}
hasBin: true
'@tmagic/cli@1.4.6':
resolution: {integrity: sha512-TBkaik3GW7TRuOHCgsLMODUuJbb+Q76BnWuUqKu2OE2KFqeAPjPXVA1BYM/59ScilM4JddCv7vdNqYidi4aE0w==}
engines: {node: '>=18'}
hasBin: true
peerDependencies:
typescript: '*'
peerDependenciesMeta:
typescript:
optional: true
'@tmagic/core@1.4.15':
resolution: {integrity: sha512-s9FTvE316yIddsCAgBuPC5w7YEmNQUbW3FeQOUHdgTZiCEns3+gWdtaa+8T9FSHrhnUbLdMQsmKux7DJm8MxuA==}
engines: {node: '>=18'}
@ -7504,28 +7687,6 @@ snapshots:
'@sxzz/popperjs-es@2.11.7': {}
'@tmagic/cli@1.4.5':
dependencies:
cac: 6.7.14
chokidar: 3.6.0
esbuild: 0.21.5
fs-extra: 11.2.0
picocolors: 1.0.1
recast: 0.23.9
tslib: 2.6.3
'@tmagic/cli@1.4.6(typescript@5.5.4)':
dependencies:
cac: 6.7.14
chokidar: 3.6.0
esbuild: 0.21.5
fs-extra: 11.2.0
picocolors: 1.0.1
recast: 0.23.9
tslib: 2.6.3
optionalDependencies:
typescript: 5.5.4
'@tmagic/core@1.4.15(@tmagic/data-source@1.4.19(@tmagic/schema@1.4.15(typescript@5.5.4))(@tmagic/utils@1.4.15(@tmagic/schema@1.4.15(typescript@5.5.4))(typescript@5.5.4))(typescript@5.5.4))(@tmagic/schema@1.4.15(typescript@5.5.4))(@tmagic/utils@1.4.15(@tmagic/schema@1.4.15(typescript@5.5.4))(typescript@5.5.4))(typescript@5.5.4)':
dependencies:
'@tmagic/data-source': 1.4.19(@tmagic/schema@1.4.15(typescript@5.5.4))(@tmagic/utils@1.4.15(@tmagic/schema@1.4.15(typescript@5.5.4))(typescript@5.5.4))(typescript@5.5.4)

View File

@ -2,3 +2,4 @@ packages:
- 'packages/*'
- 'playground'
- 'runtime/*'
- 'vue-components/*'

View File

@ -32,7 +32,7 @@
"react-dom": "^18.3.1"
},
"devDependencies": {
"@tmagic/cli": "1.4.6",
"@tmagic/cli": "workspace:*",
"@types/lodash-es": "^4.17.4",
"@types/react": "^18.3.3",
"@types/react-dom": "^18.3.0",

View File

@ -29,7 +29,7 @@
"url": "https://github.com/Tencent/tmagic-editor.git"
},
"dependencies": {
"vue-demi": "^0.14.7"
"vue-demi": "^0.14.10"
},
"peerDependencies": {
"@tmagic/core": "workspace:*",

View File

@ -31,7 +31,7 @@
"vue": "^2.7.4"
},
"devDependencies": {
"@tmagic/cli": "1.4.6",
"@tmagic/cli": "workspace:*",
"@types/events": "^3.0.0",
"axios": "^0.27.2",
"rollup": "^4.17.2",

View File

@ -3,7 +3,7 @@ import path from 'path';
import { defineConfig } from '@tmagic/cli';
export default defineConfig({
packages: [path.join(__dirname, '../../packages/ui-vue2')],
packages: [path.join(__dirname, '../../packages/ui')],
componentFileAffix: '.vue',
dynamicImport: true,
});

View File

@ -4,6 +4,7 @@
"type": "module",
"private": true,
"scripts": {
"tmagic": "tmagic entry",
"dev": "vite --config dev.vite.config.ts",
"build": "npm run build:libs && npm run build:page && npm run build:playground",
"build:page": "vite build --config build.vite.config.ts --mode page",
@ -29,7 +30,7 @@
"vue": "^3.4.35"
},
"devDependencies": {
"@tmagic/cli": "1.4.5",
"@tmagic/cli": "workspace:*",
"@types/node": "^18.19.0",
"@vitejs/plugin-legacy": "^5.4.0",
"@vitejs/plugin-vue": "^5.1.1",

View File

@ -327,6 +327,7 @@ function updatePackage(pkgRoot, version, getNewPackageName, updateDep = false) {
if (updateDep) {
updateDeps(pkg, 'dependencies', version);
updateDeps(pkg, 'peerDependencies', version);
updateDeps(pkg, 'devDependencies', version);
}
fs.writeFileSync(pkgPath, `${JSON.stringify(pkg, null, 2)}\n`);

View File

@ -0,0 +1,37 @@
{
"version": "0.0.1",
"name": "@tmagic/vue-button",
"type": "module",
"main": "src/index.ts",
"files": [
"src"
],
"engines": {
"node": ">=18"
},
"repository": {
"type": "git",
"url": "https://github.com/Tencent/tmagic-editor.git"
},
"dependencies": {
"vue-demi": "^0.14.10"
},
"peerDependencies": {
"@tmagic/schema": "workspace:*",
"@tmagic/vue-runtime-help": "workspace:*",
"@vue/composition-api": ">=1.7.2",
"typescript": "*",
"vue": ">=2.0.0 || >=3.0.0"
},
"peerDependenciesMeta": {
"@vue/composition-api": {
"optional": true
},
"@tmagic/schema": {
"optional": true
},
"typescript": {
"optional": true
}
}
}

View File

@ -0,0 +1,4 @@
export default {
methods: [],
events: [],
};

View File

@ -16,9 +16,10 @@
* limitations under the License.
*/
import Button from './Button.vue';
import Button from './index.vue';
export { default as config } from './formConfig';
export { default as value } from './initValue';
export { default as event } from './event';
export default Button;

View File

@ -0,0 +1,39 @@
<template>
<button class="magic-ui-button">
<slot>
<p>{{ config?.text || '' }}</p>
</slot>
</button>
</template>
<script lang="ts">
import { defineComponent, type PropType } from 'vue-demi';
import type { MComponent } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
interface ButtonSchema extends MComponent {
type: 'button';
text: string;
}
export default defineComponent({
props: {
config: {
type: Object as PropType<ButtonSchema>,
required: true,
},
model: {
type: Object,
default: () => ({}),
},
},
setup(props) {
useApp({
config: props.config,
methods: {},
});
},
});
</script>

View File

@ -0,0 +1,38 @@
{
"version": "0.0.1",
"name": "@tmagic/vue-container",
"type": "module",
"main": "src/index.ts",
"files": [
"src"
],
"engines": {
"node": ">=18"
},
"repository": {
"type": "git",
"url": "https://github.com/Tencent/tmagic-editor.git"
},
"dependencies": {
"vue-demi": "^0.14.10"
},
"peerDependencies": {
"@tmagic/schema": "workspace:*",
"@tmagic/utils": "workspace:*",
"@tmagic/vue-runtime-help": "workspace:*",
"@vue/composition-api": ">=1.7.2",
"typescript": "*",
"vue": ">=2.0.0 || >=3.0.0"
},
"peerDependenciesMeta": {
"typescript": {
"optional": true
},
"@vue/composition-api": {
"optional": true
},
"@tmagic/schema": {
"optional": true
}
}
}

View File

@ -26,25 +26,28 @@
</div>
</template>
<script lang="ts" setup>
import { computed } from 'vue';
<script lang="ts">
import { computed, defineComponent, type PropType } from 'vue-demi';
import type { Id, MContainer, UiComponentProps } from '@tmagic/schema';
import type { Id, MContainer } from '@tmagic/schema';
import { IS_DSL_NODE_KEY, toLine } from '@tmagic/utils';
import { useApp } from '@tmagic/vue-runtime-help';
const props = withDefaults(
defineProps<
UiComponentProps<MContainer> & {
iteratorIndex?: number[];
iteratorContainerId?: Id[];
}
>(),
{
model: () => ({}),
export default defineComponent({
props: {
config: {
type: Object as PropType<MContainer>,
required: true,
},
iteratorIndex: Array as PropType<number[]>,
iteratorContainerId: Array as PropType<Id[]>,
model: {
type: Object,
default: () => ({}),
},
},
);
setup(props) {
const { display, app } = useApp({
config: props.config,
methods: {},
@ -60,4 +63,15 @@ const className = computed(() => {
}
return list.join(' ');
});
return {
app,
className,
IS_DSL_NODE_KEY,
display,
toLine,
};
},
});
</script>

View File

@ -0,0 +1,4 @@
export default {
methods: [],
events: [],
};

View File

@ -20,5 +20,6 @@ import Container from './Container.vue';
export { default as config } from './formConfig';
export { default as value } from './initValue';
export { default as event } from './event';
export default Container;

View File

@ -0,0 +1,37 @@
{
"version": "0.0.1",
"name": "@tmagic/vue-img",
"type": "module",
"main": "src/index.ts",
"files": [
"src"
],
"engines": {
"node": ">=18"
},
"repository": {
"type": "git",
"url": "https://github.com/Tencent/tmagic-editor.git"
},
"dependencies": {
"vue-demi": "^0.14.10"
},
"peerDependencies": {
"@tmagic/schema": "workspace:*",
"@tmagic/vue-runtime-help": "workspace:*",
"@vue/composition-api": ">=1.7.2",
"typescript": "*",
"vue": ">=2.0.0 || >=3.0.0"
},
"peerDependenciesMeta": {
"@vue/composition-api": {
"optional": true
},
"@tmagic/schema": {
"optional": true
},
"typescript": {
"optional": true
}
}
}

View File

@ -0,0 +1,4 @@
export default {
methods: [],
events: [],
};

View File

@ -0,0 +1,25 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Img from './index.vue';
export { default as config } from './formConfig';
export { default as value } from './initValue';
export { default as event } from './event';
export default Img;

View File

@ -0,0 +1,44 @@
<template>
<img class="magic-ui-img" :src="config.src" @click="clickHandler" />
</template>
<script lang="ts">
import { defineComponent, type PropType } from 'vue-demi';
import type { MComponent } from '@tmagic/schema';
import { useApp } from '@tmagic/vue-runtime-help';
interface ImgSchema extends MComponent {
type: 'img';
src: string;
url: string;
}
export default defineComponent({
props: {
config: {
type: Object as PropType<ImgSchema>,
required: true,
},
model: {
type: Object,
default: () => ({}),
},
},
setup(props) {
const clickHandler = () => {
if (props.config.url) window.location.href = props.config.url;
};
useApp({
config: props.config,
methods: {},
});
return {
clickHandler,
};
},
});
</script>

View File

@ -0,0 +1,40 @@
{
"version": "0.0.1",
"name": "@tmagic/vue-iterator-container",
"type": "module",
"main": "src/index.ts",
"files": [
"src"
],
"engines": {
"node": ">=18"
},
"repository": {
"type": "git",
"url": "https://github.com/Tencent/tmagic-editor.git"
},
"dependencies": {
"vue-demi": "^0.14.10"
},
"peerDependencies": {
"@tmagic/core": "workspace:*",
"@tmagic/schema": "workspace:*",
"@tmagic/utils": "workspace:*",
"@tmagic/vue-container": "workspace:*",
"@tmagic/vue-runtime-help": "workspace:*",
"@vue/composition-api": ">=1.7.2",
"typescript": "*",
"vue": ">=2.0.0 || >=3.0.0"
},
"peerDependenciesMeta": {
"@vue/composition-api": {
"optional": true
},
"@tmagic/schema": {
"optional": true
},
"typescript": {
"optional": true
}
}
}

View File

@ -0,0 +1,123 @@
<template>
<div
class="magic-ui-iterator-container"
:data-iterator-index="dataIteratorIndex"
:data-iterator-container-id="dataIteratorContainerId"
>
<TMagicContainer
v-for="(item, index) in configs"
:iterator-index="[...(dataIteratorIndex || []), index]"
:iterator-container-id="[...(dataIteratorContainerId || []), config.id]"
:key="index"
:config="item"
></TMagicContainer>
</div>
</template>
<script lang="ts">
import { computed, defineComponent, type PropType, watch } from 'vue-demi';
import type { IteratorContainer as TMagicIteratorContainer } from '@tmagic/core';
import { type Id, type MIteratorContainer, NodeType } from '@tmagic/schema';
import TMagicContainer from '@tmagic/vue-container';
import { useApp } from '@tmagic/vue-runtime-help';
export default defineComponent({
components: {
TMagicContainer,
},
props: {
config: {
type: Object as PropType<MIteratorContainer>,
required: true,
},
dataIteratorIndex: Array as PropType<number[]>,
dataIteratorContainerId: Array as PropType<Id[]>,
model: {
type: Object,
default: () => ({}),
},
},
setup(props) {
const { app } = useApp({
config: props.config,
iteratorContainerId: props.dataIteratorContainerId,
iteratorIndex: props.dataIteratorIndex,
methods: {},
});
const configs = computed(() => {
let { iteratorData = [] } = props.config;
const { id, itemConfig, dsField, items } = props.config;
if (!Array.isArray(iteratorData)) {
iteratorData = [];
}
if (app?.platform === 'editor' && !iteratorData.length) {
iteratorData.push({});
}
return iteratorData.map((itemData) => {
const condResult =
app?.platform !== 'editor'
? app?.dataSourceManager?.compliedIteratorItemConds(itemData, itemConfig, dsField) ?? true
: true;
const newItems =
app?.dataSourceManager?.compliedIteratorItems(
id,
itemData,
items,
dsField,
props.dataIteratorContainerId,
props.dataIteratorIndex,
) ?? items;
return {
items: newItems,
id: '',
type: NodeType.CONTAINER,
condResult,
style: {
...itemConfig.style,
position: 'relative',
left: 0,
top: 0,
},
};
});
});
watch(
configs,
(configs) => {
const iteratorContainerNode = app?.getNode<TMagicIteratorContainer>(
props.config.id,
props.dataIteratorContainerId,
props.dataIteratorIndex,
);
if (!iteratorContainerNode) {
return;
}
iteratorContainerNode.resetNodes();
configs.forEach((config, index) => {
iteratorContainerNode.setNodes(config.items, index);
});
},
{
immediate: true,
},
);
return {
configs,
};
},
});
</script>

View File

@ -0,0 +1,4 @@
export default {
methods: [],
events: [],
};

View File

@ -0,0 +1,25 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import IteratorContainer from './IteratorContainer.vue';
export { default as config } from './formConfig';
export { default as value } from './initValue';
export { default as event } from './event';
export default IteratorContainer;

View File

@ -1,6 +1,6 @@
{
"version": "1.4.19",
"name": "@tmagic/ui-vue2",
"version": "0.0.1",
"name": "@tmagic/vue-overlay",
"type": "module",
"main": "src/index.ts",
"files": [
@ -14,21 +14,18 @@
"url": "https://github.com/Tencent/tmagic-editor.git"
},
"dependencies": {
"qrcode": "^1.5.0"
"vue-demi": "^0.14.10"
},
"peerDependencies": {
"@tmagic/core": "workspace:*",
"@tmagic/schema": "workspace:*",
"@tmagic/utils": "workspace:*",
"vue": ">=2.7.4",
"@tmagic/vue-container": "workspace:*",
"@tmagic/vue-runtime-help": "workspace:*",
"vue-demi": ">=0.14.7",
"typescript": "*"
},
"peerDependenciesMeta": {
"typescript": {
"optional": true
}
},
"devDependencies": {
"vue-template-compiler": "^2.7.4"
}
}

View File

@ -0,0 +1,25 @@
/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2023 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Overlay from './index.vue';
export { default as config } from './formConfig';
export { default as value } from './initValue';
export { default as event } from './event';
export default Overlay;

View File

@ -0,0 +1,77 @@
<template>
<TMagicContainer v-if="visible" class="magic-ui-overlay" :config="{ items: config.items }">
<slot></slot>
</TMagicContainer>
</template>
<script lang="ts">
import { defineComponent, onBeforeUnmount, type PropType, ref } from 'vue-demi';
import type { MContainer, MNode, MPage } from '@tmagic/schema';
import TMagicContainer from '@tmagic/vue-container';
import { useApp } from '@tmagic/vue-runtime-help';
interface OverlaySchema extends MContainer {
type: 'overlay';
}
export default defineComponent({
components: {
TMagicContainer,
},
props: {
config: {
type: Object as PropType<OverlaySchema>,
required: true,
},
model: {
type: Object,
default: () => ({}),
},
},
setup(props) {
const visible = ref(false);
const { app, node } = useApp({
config: props.config,
methods: {
openOverlay() {
visible.value = true;
app?.emit('overlay:open', node);
},
closeOverlay() {
visible.value = false;
app?.emit('overlay:close', node);
},
},
});
const editorSelectHandler = (
info: {
node: MNode;
page: MPage;
parent: MContainer;
},
path: MNode[],
) => {
if (path.find((node: MNode) => node.id === props.config.id)) {
node?.instance.openOverlay();
} else {
node?.instance.closeOverlay();
}
};
app?.page?.on('editor:select', editorSelectHandler);
onBeforeUnmount(() => {
app?.page?.off('editor:select', editorSelectHandler);
});
return {
visible,
};
},
});
</script>

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