@kp-ui/lowcode-pc-v2 0.0.6 → 0.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/styles/style.css +14 -12
- package/core/src/components/common/render/usePageContext.js +2 -7
- package/core/src/hooks/useLowcode.js +17 -17
- package/core/src/utils/smart-vue-i18n/index.js +6 -6
- package/install.js +2 -3
- package/package.json +1 -1
- package/src/components/public/ConfigView/CustomPageRender.vue_vue_type_script_setup_true_lang.js +8 -14
- package/src/components/public/CustomerModal/CustomerModal.vue_vue_type_script_setup_true_lang.js +5 -2
- package/src/render/index.js +1 -1
- package/src/render/index.vue_vue_type_script_setup_true_lang.js +1 -1
- package/src/widgets/containers/collapse/index-render.js +1 -1
- package/src/widgets/containers/collapse/index-render.vue_vue_type_script_setup_true_lang.js +1 -1
- package/stats.html +1 -1
package/assets/styles/style.css
CHANGED
|
@@ -445,27 +445,25 @@
|
|
|
445
445
|
}
|
|
446
446
|
.vf-box-widget .vf-box-content[data-v-d52cfec5] {
|
|
447
447
|
min-height: 60px;
|
|
448
|
-
}.collapse-container[data-v-
|
|
448
|
+
}.collapse-container[data-v-198dcc4f] {
|
|
449
449
|
display: flex;
|
|
450
450
|
margin: 2px;
|
|
451
|
-
height: 100%;
|
|
452
451
|
width: 100%;
|
|
453
|
-
flex: 1 0 0;
|
|
454
452
|
}
|
|
455
|
-
.collapse-container .form-widget-list[data-v-
|
|
453
|
+
.collapse-container .form-widget-list[data-v-198dcc4f] {
|
|
456
454
|
min-height: 28px;
|
|
457
455
|
}
|
|
458
|
-
.collapse-container[data-v-
|
|
456
|
+
.collapse-container[data-v-198dcc4f] .header-right .form-widget-list {
|
|
459
457
|
min-width: 200px;
|
|
460
458
|
}
|
|
461
|
-
.tpf-collapse[data-v-
|
|
459
|
+
.tpf-collapse[data-v-198dcc4f] {
|
|
462
460
|
padding: 5px;
|
|
463
461
|
}
|
|
464
|
-
.tpf-collapse .collapse-right[data-v-
|
|
462
|
+
.tpf-collapse .collapse-right[data-v-198dcc4f] {
|
|
465
463
|
min-width: 200px;
|
|
466
464
|
min-height: 30px;
|
|
467
465
|
}
|
|
468
|
-
.tpf-collapse[data-v-
|
|
466
|
+
.tpf-collapse[data-v-198dcc4f] .tpf-collapse-content-wrapper {
|
|
469
467
|
overflow: hidden;
|
|
470
468
|
background-color: #fff;
|
|
471
469
|
padding: 16px;
|
|
@@ -531,16 +529,20 @@
|
|
|
531
529
|
.page-template-widget[data-v-dc2a06fa] .addInfoLayout-footer .ant-form-item {
|
|
532
530
|
margin-bottom: 0;
|
|
533
531
|
}
|
|
534
|
-
.layout-render-wrapper[data-v-
|
|
532
|
+
.layout-render-wrapper[data-v-976bc2cb] {
|
|
533
|
+
flex: 1;
|
|
534
|
+
width: 100%;
|
|
535
|
+
height: 100%;
|
|
536
|
+
min-height: 0;
|
|
535
537
|
overflow-y: auto;
|
|
536
538
|
overflow-x: hidden;
|
|
537
|
-
background: var(--
|
|
539
|
+
background: var(--ee95b64a);
|
|
538
540
|
}
|
|
539
|
-
.loading-wrapper[data-v-
|
|
541
|
+
.loading-wrapper[data-v-976bc2cb] {
|
|
540
542
|
min-height: 300px;
|
|
541
543
|
padding: 20px;
|
|
542
544
|
}
|
|
543
|
-
.ant-form .ant-form-item-explain.ant-form-item-explain-connected[data-v-
|
|
545
|
+
.ant-form .ant-form-item-explain.ant-form-item-explain-connected[data-v-976bc2cb] {
|
|
544
546
|
display: none;
|
|
545
547
|
}
|
|
546
548
|
/*$vite$:1*/
|
|
@@ -2,7 +2,7 @@ import { EVENT_TYPE, useEmitter } from "../../../utils/useEmitter.js";
|
|
|
2
2
|
import { useI18n } from "../../../utils/i18n.js";
|
|
3
3
|
import { generateId, insertCustomCssToHead, insertGlobalFunctionsToHtml, removeCustomCssToHead, removeScriptToHead } from "../../../utils/util.js";
|
|
4
4
|
import { useAppRef } from "../../../hooks/useAppRef.js";
|
|
5
|
-
import { computed, nextTick, onMounted, ref,
|
|
5
|
+
import { computed, nextTick, onMounted, ref, watch, watchEffect } from "vue";
|
|
6
6
|
import { useExecFunction, useRef } from "tmgc2-share";
|
|
7
7
|
import { cloneDeep, set } from "lodash-es";
|
|
8
8
|
//#region ../core/src/components/common/render/usePageContext.ts
|
|
@@ -13,7 +13,6 @@ import { cloneDeep, set } from "lodash-es";
|
|
|
13
13
|
*/
|
|
14
14
|
var usePageContext = ({ props }) => {
|
|
15
15
|
const { formJson } = props;
|
|
16
|
-
const dynamicDialogRef = useTemplateRef("dynamicDialogRef");
|
|
17
16
|
const { i18nt } = useI18n();
|
|
18
17
|
const [readModeFlag, setReadMode] = useRef(false);
|
|
19
18
|
const formContextData = ref({});
|
|
@@ -96,10 +95,7 @@ var usePageContext = ({ props }) => {
|
|
|
96
95
|
const getParentPageInstance = () => {
|
|
97
96
|
return props.parentForm;
|
|
98
97
|
};
|
|
99
|
-
const getChildFormRef = () => {
|
|
100
|
-
var _dynamicDialogRef$val;
|
|
101
|
-
return (_dynamicDialogRef$val = dynamicDialogRef.value) === null || _dynamicDialogRef$val === void 0 ? void 0 : _dynamicDialogRef$val.getPageInstance();
|
|
102
|
-
};
|
|
98
|
+
const getChildFormRef = () => {};
|
|
103
99
|
/**
|
|
104
100
|
* 字段值变化事件处理器
|
|
105
101
|
*/
|
|
@@ -202,7 +198,6 @@ var usePageContext = ({ props }) => {
|
|
|
202
198
|
isLoading,
|
|
203
199
|
vfCtx: props.vfCtx,
|
|
204
200
|
formConfig,
|
|
205
|
-
dynamicDialogRef,
|
|
206
201
|
setChildFormRef,
|
|
207
202
|
setDialogOrDrawerRef,
|
|
208
203
|
executeHttp
|
|
@@ -2,7 +2,6 @@ import { ref } from "vue";
|
|
|
2
2
|
import { message } from "ant-design-vue";
|
|
3
3
|
import { http, routerReloadStatus, useDataQueryApi, useRouteBackTab } from "tmgc2-share";
|
|
4
4
|
import { cloneDeep } from "lodash-es";
|
|
5
|
-
import { getLocat } from "@kp-ui/tool";
|
|
6
5
|
//#region ../core/src/hooks/useLowcode.ts
|
|
7
6
|
var defaultPageJson = {
|
|
8
7
|
widgetList: [],
|
|
@@ -12,25 +11,25 @@ var pageJsonCache = /* @__PURE__ */ new Map();
|
|
|
12
11
|
var pageJsonRequestCache = /* @__PURE__ */ new Map();
|
|
13
12
|
var normalizePageJson = (json) => ({
|
|
14
13
|
...defaultPageJson,
|
|
15
|
-
...json
|
|
14
|
+
...json
|
|
16
15
|
});
|
|
17
|
-
var getCachedPageJson = (
|
|
18
|
-
const cached = pageJsonCache.get(
|
|
16
|
+
var getCachedPageJson = (pageCode, useDataQuery) => {
|
|
17
|
+
const cached = pageJsonCache.get(pageCode);
|
|
19
18
|
if (cached) return Promise.resolve(cached);
|
|
20
|
-
const pending = pageJsonRequestCache.get(
|
|
19
|
+
const pending = pageJsonRequestCache.get(pageCode);
|
|
21
20
|
if (pending) return pending;
|
|
22
|
-
const request = useDataQuery.dataQueryDetail({ code:
|
|
21
|
+
const request = useDataQuery.dataQueryDetail({ code: pageCode }, "FormDefinitionV2").then((res) => {
|
|
23
22
|
const data = res.data.object || {};
|
|
24
23
|
const cache = {
|
|
25
24
|
formId: data.formId,
|
|
26
25
|
json: normalizePageJson(JSON.parse(data.frontendDefinition || "{}"))
|
|
27
26
|
};
|
|
28
|
-
pageJsonCache.set(
|
|
27
|
+
pageJsonCache.set(pageCode, cache);
|
|
29
28
|
return cache;
|
|
30
29
|
}).finally(() => {
|
|
31
|
-
pageJsonRequestCache.delete(
|
|
30
|
+
pageJsonRequestCache.delete(pageCode);
|
|
32
31
|
});
|
|
33
|
-
pageJsonRequestCache.set(
|
|
32
|
+
pageJsonRequestCache.set(pageCode, request);
|
|
34
33
|
return request;
|
|
35
34
|
};
|
|
36
35
|
var useLowcode = (options = {}) => {
|
|
@@ -40,14 +39,16 @@ var useLowcode = (options = {}) => {
|
|
|
40
39
|
const formId = ref();
|
|
41
40
|
const formConfig = ref();
|
|
42
41
|
const { routeBackTab } = useRouteBackTab();
|
|
43
|
-
const
|
|
42
|
+
const pageCode = ref(options.pageCode || "");
|
|
43
|
+
const getPageJson = async (_pageCode) => {
|
|
44
44
|
let json = cloneDeep(defaultPageJson);
|
|
45
|
-
|
|
46
|
-
|
|
45
|
+
pageCode.value = _pageCode || options.pageCode || "";
|
|
46
|
+
console.log(pageCode.value);
|
|
47
|
+
if (pageCode.value) {
|
|
47
48
|
var _vfdRef$value;
|
|
48
49
|
(_vfdRef$value = vfdRef.value) === null || _vfdRef$value === void 0 || _vfdRef$value.setLoading(true);
|
|
49
50
|
try {
|
|
50
|
-
const cache = await getCachedPageJson(
|
|
51
|
+
const cache = await getCachedPageJson(pageCode.value, useDataQuery);
|
|
51
52
|
json = cloneDeep(cache.json);
|
|
52
53
|
formId.value = cache.formId;
|
|
53
54
|
} finally {
|
|
@@ -60,7 +61,7 @@ var useLowcode = (options = {}) => {
|
|
|
60
61
|
vfdRef.value.setPageJson(json);
|
|
61
62
|
return json;
|
|
62
63
|
};
|
|
63
|
-
const getComponentJson = async (..._args) => getPageJson(options.
|
|
64
|
+
const getComponentJson = async (..._args) => getPageJson(options.pageCode);
|
|
64
65
|
const getFieldList = async (entityCode) => {
|
|
65
66
|
isLoading.value = true;
|
|
66
67
|
const p = {
|
|
@@ -91,14 +92,13 @@ var useLowcode = (options = {}) => {
|
|
|
91
92
|
routeBackTab(reloadStatus, cb);
|
|
92
93
|
};
|
|
93
94
|
const saveJsonApi = async (json) => {
|
|
94
|
-
const { formCode } = getLocat();
|
|
95
95
|
const params = {
|
|
96
|
-
|
|
96
|
+
pageCode: pageCode.value,
|
|
97
97
|
formId: formId.value,
|
|
98
98
|
frontendDefinition: JSON.stringify(json)
|
|
99
99
|
};
|
|
100
100
|
await http.post(`/api/tmgc2-mgt/formDefinition/formDefinitionV2/save`, params);
|
|
101
|
-
if (
|
|
101
|
+
if (pageCode.value) pageJsonCache.set(pageCode.value, {
|
|
102
102
|
formId: formId.value,
|
|
103
103
|
json: normalizePageJson(cloneDeep(json))
|
|
104
104
|
});
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { reactive } from "vue";
|
|
2
2
|
import { get, isObject } from "lodash-es";
|
|
3
|
+
import zhCN from "ant-design-vue/es/locale/zh_CN";
|
|
4
|
+
import enUS from "ant-design-vue/es/locale/en_US";
|
|
3
5
|
//#region ../core/src/utils/smart-vue-i18n/index.ts
|
|
4
6
|
var locale = reactive({
|
|
5
7
|
lang: "zh-CN",
|
|
@@ -7,28 +9,26 @@ var locale = reactive({
|
|
|
7
9
|
});
|
|
8
10
|
var langLoaders = {
|
|
9
11
|
"zh-CN": async () => {
|
|
10
|
-
const [
|
|
11
|
-
import("ant-design-vue/es/locale/zh_CN"),
|
|
12
|
+
const [zhLocale, zhLocale_render, zhLocale_extension] = await Promise.all([
|
|
12
13
|
import("../../lang/zh-CN.js"),
|
|
13
14
|
import("../../lang/zh-CN_render.js"),
|
|
14
15
|
import("../../lang/zh-CN_extension.js")
|
|
15
16
|
]);
|
|
16
17
|
return {
|
|
17
|
-
...zhCN
|
|
18
|
+
...zhCN,
|
|
18
19
|
...zhLocale.default,
|
|
19
20
|
...zhLocale_render.default,
|
|
20
21
|
...zhLocale_extension.default
|
|
21
22
|
};
|
|
22
23
|
},
|
|
23
24
|
"en-US": async () => {
|
|
24
|
-
const [
|
|
25
|
-
import("ant-design-vue/es/locale/en_US"),
|
|
25
|
+
const [enLocale, enLocale_render, enLocale_extension] = await Promise.all([
|
|
26
26
|
import("../../lang/en-US.js"),
|
|
27
27
|
import("../../lang/en-US_render.js"),
|
|
28
28
|
import("../../lang/en-US_extension.js")
|
|
29
29
|
]);
|
|
30
30
|
return {
|
|
31
|
-
...enUS
|
|
31
|
+
...enUS,
|
|
32
32
|
...enLocale.default,
|
|
33
33
|
...enLocale_render.default,
|
|
34
34
|
...enLocale_extension.default
|
package/install.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import "./_virtual/virtual_svg-icons-register.js";
|
|
2
2
|
/* empty css */
|
|
3
|
+
import { openCustomerModal } from "./src/components/public/CustomerModal/useCustomerModal.js";
|
|
3
4
|
import render_default from "./src/render/index.js";
|
|
4
5
|
import CustomPageRender_default from "./src/components/public/ConfigView/CustomPageRender.js";
|
|
5
6
|
import { VxeTooltip } from "vxe-pc-ui";
|
|
@@ -8,9 +9,7 @@ var createLowcode = ({ app, publicComponents }) => {
|
|
|
8
9
|
app.config.globalProperties.$publicComponents = publicComponents;
|
|
9
10
|
app.component("VxeTooltip", VxeTooltip);
|
|
10
11
|
app.config.globalProperties.$openLowcodeModal = (ops) => {
|
|
11
|
-
|
|
12
|
-
openCustomerModal(ops, app);
|
|
13
|
-
});
|
|
12
|
+
openCustomerModal(ops, app);
|
|
14
13
|
};
|
|
15
14
|
};
|
|
16
15
|
//#endregion
|
package/package.json
CHANGED
package/src/components/public/ConfigView/CustomPageRender.vue_vue_type_script_setup_true_lang.js
CHANGED
|
@@ -1,21 +1,17 @@
|
|
|
1
1
|
import { useLowcode } from "../../../../core/src/hooks/useLowcode.js";
|
|
2
2
|
import render_default from "../../../render/index.js";
|
|
3
|
-
import { createBlock, defineComponent, onMounted, openBlock,
|
|
3
|
+
import { createBlock, defineComponent, onMounted, openBlock, unref } from "vue";
|
|
4
4
|
import { getLocat } from "@kp-ui/tool";
|
|
5
5
|
//#region src/components/public/ConfigView/CustomPageRender.vue?vue&type=script&setup=true&lang.tsx
|
|
6
6
|
var CustomPageRender_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
7
7
|
__name: "CustomPageRender",
|
|
8
|
-
props: {
|
|
9
|
-
type: String,
|
|
10
|
-
default: ""
|
|
11
|
-
} },
|
|
8
|
+
props: { pageCode: String },
|
|
12
9
|
setup(__props) {
|
|
13
|
-
const {
|
|
14
|
-
const
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
};
|
|
18
|
-
const { vfdRef, formConfig, getPageJson, goBack } = useLowcode();
|
|
10
|
+
const { type = "edit" } = getLocat();
|
|
11
|
+
const { vfdRef, getPageJson, goBack } = useLowcode({
|
|
12
|
+
pageCode: __props.pageCode,
|
|
13
|
+
type
|
|
14
|
+
});
|
|
19
15
|
onMounted(async () => {
|
|
20
16
|
await getPageJson();
|
|
21
17
|
});
|
|
@@ -24,10 +20,8 @@ var CustomPageRender_vue_vue_type_script_setup_true_lang_default = /* @__PURE__
|
|
|
24
20
|
ref_key: "vfdRef",
|
|
25
21
|
ref: vfdRef,
|
|
26
22
|
vfCtx: {
|
|
27
|
-
_id: unref(id),
|
|
28
23
|
...unref(getLocat)(),
|
|
29
|
-
goBack: unref(goBack)
|
|
30
|
-
setAnchorList
|
|
24
|
+
goBack: unref(goBack)
|
|
31
25
|
}
|
|
32
26
|
}, null, 8, ["vfCtx"]);
|
|
33
27
|
};
|
package/src/components/public/CustomerModal/CustomerModal.vue_vue_type_script_setup_true_lang.js
CHANGED
|
@@ -35,7 +35,10 @@ var CustomerModal_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */
|
|
|
35
35
|
};
|
|
36
36
|
});
|
|
37
37
|
const isDisabled = ref(false);
|
|
38
|
-
const { vfdRef, formConfig, getPageJson, isLoading } = useLowcode(
|
|
38
|
+
const { vfdRef, formConfig, getPageJson, isLoading } = useLowcode({
|
|
39
|
+
pageCode: props.formCode,
|
|
40
|
+
type: props.type
|
|
41
|
+
});
|
|
39
42
|
const leftNum = ref(null);
|
|
40
43
|
const modalTitle = computed(() => {
|
|
41
44
|
if (props.title) return props.title;
|
|
@@ -47,7 +50,7 @@ var CustomerModal_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */
|
|
|
47
50
|
const show = async () => {
|
|
48
51
|
visible.value = true;
|
|
49
52
|
await nextTick();
|
|
50
|
-
await getPageJson(
|
|
53
|
+
await getPageJson();
|
|
51
54
|
};
|
|
52
55
|
const setleftText = (number) => {
|
|
53
56
|
leftNum.value = number;
|
package/src/render/index.js
CHANGED
|
@@ -2,6 +2,6 @@ import _plugin_vue_export_helper_default from "../../_virtual/_plugin-vue_export
|
|
|
2
2
|
import index_vue_vue_type_script_setup_true_lang_default from "./index.vue_vue_type_script_setup_true_lang.js";
|
|
3
3
|
/* empty css */
|
|
4
4
|
//#region src/render/index.vue
|
|
5
|
-
var render_default = /* @__PURE__ */ _plugin_vue_export_helper_default(index_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-
|
|
5
|
+
var render_default = /* @__PURE__ */ _plugin_vue_export_helper_default(index_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-976bc2cb"]]);
|
|
6
6
|
//#endregion
|
|
7
7
|
export { render_default as default };
|
|
@@ -28,7 +28,7 @@ var index_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineCo
|
|
|
28
28
|
parentForm: { default: null }
|
|
29
29
|
},
|
|
30
30
|
setup(__props, { expose: __expose }) {
|
|
31
|
-
useCssVars((_ctx) => ({ "
|
|
31
|
+
useCssVars((_ctx) => ({ "ee95b64a": unref(formConfig).backgroundColor }));
|
|
32
32
|
const debug = computed(() => getLocat().debug === "1");
|
|
33
33
|
const debugVisible = ref(false);
|
|
34
34
|
const props = __props;
|
|
@@ -3,6 +3,6 @@ import index_render_vue_vue_type_script_setup_true_lang_default from "./index-re
|
|
|
3
3
|
/* empty css */
|
|
4
4
|
/* empty css */
|
|
5
5
|
//#region src/widgets/containers/collapse/index-render.vue
|
|
6
|
-
var index_render_default = /* @__PURE__ */ _plugin_vue_export_helper_default(index_render_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-
|
|
6
|
+
var index_render_default = /* @__PURE__ */ _plugin_vue_export_helper_default(index_render_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-198dcc4f"]]);
|
|
7
7
|
//#endregion
|
|
8
8
|
export { index_render_default as default };
|
|
@@ -18,7 +18,7 @@ var index_render_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ d
|
|
|
18
18
|
__name: "index-render",
|
|
19
19
|
props: { widget: {} },
|
|
20
20
|
setup(__props, { expose: __expose }) {
|
|
21
|
-
const { handleHidden, defineExposed } = useField(__props.widget
|
|
21
|
+
const { handleHidden, defineExposed } = useField(__props.widget);
|
|
22
22
|
__expose({ ...defineExposed });
|
|
23
23
|
return (_ctx, _cache) => {
|
|
24
24
|
return !unref(handleHidden) ? (openBlock(), createElementBlock("div", _hoisted_1, [createVNode(unref(TpfCollapse), { title: _ctx.widget.props.label }, {
|