@maketribe/ms-app 3.0.11 → 3.0.13
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/dist/cjs/components/data-model/data-filter-form/composables/use-condition.js +14 -14
- package/dist/cjs/components/data-model/data-filter-form/composables/use-condition.js.map +1 -1
- package/dist/cjs/components/data-model/data-filter-form/data-filter-form-item/data-filter-form-item.js +1 -1
- package/dist/cjs/components/data-model/data-filter-form/data-filter-form-item/data-filter-form-item.js.map +1 -1
- package/dist/cjs/components/data-model/data-filter-form/data-filter-form-options.d.ts +3 -3
- package/dist/cjs/components/data-model/data-filter-form/data-filter-form-options.js +2 -1
- package/dist/cjs/components/data-model/data-filter-form/data-filter-form-options.js.map +1 -1
- package/dist/cjs/components/data-model/data-filter-form/data-filter-form.d.ts +4 -4
- package/dist/cjs/components/data-model/data-filter-form/data-filter-form.js +34 -5
- package/dist/cjs/components/data-model/data-filter-form/data-filter-form.js.map +1 -1
- package/dist/cjs/components/data-model/data-filter-form/index.d.ts +4 -4
- package/dist/cjs/components/data-model/data-filter-form/token.d.ts +1 -0
- package/dist/cjs/components/data-model/data-filter-form/token.js.map +1 -1
- package/dist/cjs/components/data-model/data-filter-popover/data-filter-popover.js +4 -3
- package/dist/cjs/components/data-model/data-filter-popover/data-filter-popover.js.map +1 -1
- package/dist/cjs/components/data-model/data-form/data-form.js +1 -1
- package/dist/cjs/components/data-model/data-form/data-form.js.map +1 -1
- package/dist/cjs/components/data-model/data-table/data-table.js +0 -1
- package/dist/cjs/components/data-model/data-table/data-table.js.map +1 -1
- package/dist/cjs/components/data-model/data-table/views/table-view/table-view.js +35 -30
- package/dist/cjs/components/data-model/data-table/views/table-view/table-view.js.map +1 -1
- package/dist/cjs/components/material-list/material-group-form-popover.vue2.js +8 -1
- package/dist/cjs/components/material-list/material-group-form-popover.vue2.js.map +1 -1
- package/dist/cjs/components/material-list/material-group.vue2.js +9 -7
- package/dist/cjs/components/material-list/material-group.vue2.js.map +1 -1
- package/dist/cjs/components/system-provider/system-provider.d.ts +7 -0
- package/dist/cjs/components/system-provider/system-provider.js +29 -46
- package/dist/cjs/components/system-provider/system-provider.js.map +1 -1
- package/dist/cjs/core/Router.d.ts +1 -11
- package/dist/cjs/core/Router.js +0 -22
- package/dist/cjs/core/Router.js.map +1 -1
- package/dist/cjs/core/UserSession.js +0 -12
- package/dist/cjs/core/UserSession.js.map +1 -1
- package/dist/cjs/core/tabs/Tabs.js +1 -8
- package/dist/cjs/core/tabs/Tabs.js.map +1 -1
- package/dist/cjs/dataview/material/MaterialMan.d.ts +1 -1
- package/dist/cjs/dataview/material/MaterialMan.js +1 -1
- package/dist/cjs/dataview/material/MaterialMan.js.map +1 -1
- package/dist/cjs/dataview/member/MemberTable.d.ts +1 -2
- package/dist/cjs/dataview/member/MemberTable.js +9 -3
- package/dist/cjs/dataview/member/MemberTable.js.map +1 -1
- package/dist/cjs/dataview/menu/MenuTable.js.map +1 -1
- package/dist/cjs/dataview/role/RoleTable.js.map +1 -1
- package/dist/cjs/layouts/components/bar/index.js +2 -2
- package/dist/cjs/layouts/components/bar/index.js.map +1 -1
- package/dist/cjs/layouts/components/menu/index.js +2 -2
- package/dist/cjs/layouts/components/menu/index.js.map +1 -1
- package/dist/cjs/page/index/dv/ms-member/index.vue2.js +53 -11
- package/dist/cjs/page/index/dv/ms-member/index.vue2.js.map +1 -1
- package/dist/cjs/router-middleware/auth.js +0 -19
- package/dist/cjs/router-middleware/auth.js.map +1 -1
- package/dist/esm/components/data-model/data-filter-form/composables/use-condition.js +14 -14
- package/dist/esm/components/data-model/data-filter-form/composables/use-condition.js.map +1 -1
- package/dist/esm/components/data-model/data-filter-form/data-filter-form-item/data-filter-form-item.js +1 -1
- package/dist/esm/components/data-model/data-filter-form/data-filter-form-item/data-filter-form-item.js.map +1 -1
- package/dist/esm/components/data-model/data-filter-form/data-filter-form-options.d.ts +3 -3
- package/dist/esm/components/data-model/data-filter-form/data-filter-form-options.js +3 -2
- package/dist/esm/components/data-model/data-filter-form/data-filter-form-options.js.map +1 -1
- package/dist/esm/components/data-model/data-filter-form/data-filter-form.d.ts +4 -4
- package/dist/esm/components/data-model/data-filter-form/data-filter-form.js +35 -6
- package/dist/esm/components/data-model/data-filter-form/data-filter-form.js.map +1 -1
- package/dist/esm/components/data-model/data-filter-form/index.d.ts +4 -4
- package/dist/esm/components/data-model/data-filter-form/token.d.ts +1 -0
- package/dist/esm/components/data-model/data-filter-form/token.js.map +1 -1
- package/dist/esm/components/data-model/data-filter-popover/data-filter-popover.js +5 -4
- package/dist/esm/components/data-model/data-filter-popover/data-filter-popover.js.map +1 -1
- package/dist/esm/components/data-model/data-form/data-form.js +1 -1
- package/dist/esm/components/data-model/data-form/data-form.js.map +1 -1
- package/dist/esm/components/data-model/data-table/data-table.js +0 -1
- package/dist/esm/components/data-model/data-table/data-table.js.map +1 -1
- package/dist/esm/components/data-model/data-table/views/table-view/table-view.js +35 -30
- package/dist/esm/components/data-model/data-table/views/table-view/table-view.js.map +1 -1
- package/dist/esm/components/material-list/material-group-form-popover.vue2.js +8 -1
- package/dist/esm/components/material-list/material-group-form-popover.vue2.js.map +1 -1
- package/dist/esm/components/material-list/material-group.vue2.js +9 -7
- package/dist/esm/components/material-list/material-group.vue2.js.map +1 -1
- package/dist/esm/components/system-provider/system-provider.d.ts +7 -0
- package/dist/esm/components/system-provider/system-provider.js +30 -47
- package/dist/esm/components/system-provider/system-provider.js.map +1 -1
- package/dist/esm/core/Router.d.ts +1 -11
- package/dist/esm/core/Router.js +1 -23
- package/dist/esm/core/Router.js.map +1 -1
- package/dist/esm/core/UserSession.js +0 -12
- package/dist/esm/core/UserSession.js.map +1 -1
- package/dist/esm/core/tabs/Tabs.js +1 -8
- package/dist/esm/core/tabs/Tabs.js.map +1 -1
- package/dist/esm/dataview/material/MaterialMan.d.ts +1 -1
- package/dist/esm/dataview/material/MaterialMan.js +1 -1
- package/dist/esm/dataview/material/MaterialMan.js.map +1 -1
- package/dist/esm/dataview/member/MemberTable.d.ts +1 -2
- package/dist/esm/dataview/member/MemberTable.js +10 -4
- package/dist/esm/dataview/member/MemberTable.js.map +1 -1
- package/dist/esm/dataview/menu/MenuTable.js.map +1 -1
- package/dist/esm/dataview/role/RoleTable.js.map +1 -1
- package/dist/esm/layouts/components/bar/index.js +2 -2
- package/dist/esm/layouts/components/bar/index.js.map +1 -1
- package/dist/esm/layouts/components/menu/index.js +2 -2
- package/dist/esm/layouts/components/menu/index.js.map +1 -1
- package/dist/esm/page/index/dv/ms-member/index.vue2.js +54 -12
- package/dist/esm/page/index/dv/ms-member/index.vue2.js.map +1 -1
- package/dist/esm/router-middleware/auth.js +0 -19
- package/dist/esm/router-middleware/auth.js.map +1 -1
- package/dist/style/components/data-filter-popover.css +1 -1
- package/dist/style/components/data-filter.css +1 -1
- package/dist/style/components/index.css +1 -1
- package/dist/style/index.css +2 -2
- package/dist/style/src/components/data-filter-popover.scss +3 -3
- package/dist/style/src/components/data-filter.scss +0 -1
- package/dist/style/src/index.scss +9 -0
- package/package.json +4 -4
- package/src/components/data-model/data-filter-form/composables/use-condition.ts +19 -16
- package/src/components/data-model/data-filter-form/data-filter-form-item/data-filter-form-item.tsx +7 -4
- package/src/components/data-model/data-filter-form/data-filter-form-options.ts +3 -2
- package/src/components/data-model/data-filter-form/data-filter-form.tsx +51 -6
- package/src/components/data-model/data-filter-form/token.ts +1 -0
- package/src/components/data-model/data-filter-popover/data-filter-popover.tsx +4 -3
- package/src/components/data-model/data-form/data-form.tsx +3 -1
- package/src/components/data-model/data-table/data-table.tsx +5 -1
- package/src/components/data-model/data-table/views/table-view/table-view.tsx +43 -35
- package/src/components/material-list/material-group-form-popover.vue +4 -2
- package/src/components/material-list/material-group.vue +13 -7
- package/src/components/system-provider/system-provider.tsx +52 -49
- package/src/core/Router.ts +0 -34
- package/src/core/UserSession.ts +0 -18
- package/src/core/tabs/Tabs.ts +20 -9
- package/src/dataview/material/MaterialMan.ts +1 -1
- package/src/dataview/member/MemberTable.tsx +12 -4
- package/src/dataview/menu/MenuTable.ts +1 -0
- package/src/dataview/role/RoleTable.ts +1 -0
- package/src/layouts/components/bar/index.tsx +3 -2
- package/src/layouts/components/menu/index.tsx +3 -2
- package/src/page/index/dv/ms-member/index.vue +3 -11
- package/src/router-middleware/auth.ts +0 -35
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"material-group-form-popover.vue2.js","sources":["../../../../src/components/material-list/material-group-form-popover.vue"],"sourcesContent":["<template>\n <ElPopover\n v-model:visible=\"visible\"\n title=\"添加素材分组\"\n effect=\"light\"\n placement=\"right\"\n trigger=\"click\"\n width=\"320\"\n >\n <template #reference>\n <slot></slot>\n </template>\n\n <div>\n <MKDataForm :data-form=\"materialGroupForm\" v-loading=\"loading\" />\n <div\n style=\"\n display: flex;\n align-items: center;\n justify-content: space-between;\n \"\n >\n <ElButton\n type=\"primary\"\n :loading=\"!allowSubmit\"\n @click=\"handleSaveClick\"\n >\n 保存\n </ElButton>\n <ElButton @click=\"handleCancelClick\">取消</ElButton>\n </div>\n </div>\n </ElPopover>\n</template>\n\n<script setup lang=\"ts\">\nimport { Ref, computed, ref, unref } from \"vue\";\nimport { ElMessage } from \"element-plus\";\nimport { MKDataForm } from \"../data-model/data-form\";\nimport { MaterialGroupForm, MaterialMan } from \"../../dataview/material\";\n\nconst props = defineProps({\n materialMan: {\n type: MaterialMan,\n required: true,\n },\n materialGroupForm: {\n type: MaterialGroupForm,\n required: true,\n },\n});\n\nconst visible: Ref<boolean> = ref(false);\n\nconst loading = computed(() => props.materialGroupForm.loading);\nconst allowSubmit = computed(\n () => !!(unref(loading) || !props.materialGroupForm.allowSubmit)\n);\n\nconst handleSaveClick = async () => {\n const result = await props.materialGroupForm.submit();\n\n if (result.data.code !== 200) {\n ElMessage.error(result.data.msg);\n return;\n }\n\n props.materialMan.materialGroupTree.load();\n\n visible.value = false;\n};\n\nconst handleCancelClick = () => {\n visible.value = false;\n};\n</script>\n"],"names":["ref","computed","unref","ElMessage"],"mappings":"
|
|
1
|
+
{"version":3,"file":"material-group-form-popover.vue2.js","sources":["../../../../src/components/material-list/material-group-form-popover.vue"],"sourcesContent":["<template>\n <ElPopover\n v-model:visible=\"visible\"\n title=\"添加素材分组\"\n effect=\"light\"\n placement=\"right\"\n trigger=\"click\"\n width=\"320\"\n >\n <template #reference>\n <slot></slot>\n </template>\n\n <div>\n <MKDataForm :data-form=\"materialGroupForm\" v-loading=\"loading\">\n <MKForm :data-form=\"materialGroupForm\" />\n </MKDataForm>\n <div\n style=\"\n display: flex;\n align-items: center;\n justify-content: space-between;\n \"\n >\n <ElButton\n type=\"primary\"\n :loading=\"!allowSubmit\"\n @click=\"handleSaveClick\"\n >\n 保存\n </ElButton>\n <ElButton @click=\"handleCancelClick\">取消</ElButton>\n </div>\n </div>\n </ElPopover>\n</template>\n\n<script setup lang=\"ts\">\nimport { Ref, computed, ref, unref } from \"vue\";\nimport { ElMessage } from \"element-plus\";\nimport { MKDataForm, MKForm } from \"../data-model/data-form\";\nimport { MaterialGroupForm, MaterialMan } from \"../../dataview/material\";\n\nconst props = defineProps({\n materialMan: {\n type: MaterialMan,\n required: true,\n },\n materialGroupForm: {\n type: MaterialGroupForm,\n required: true,\n },\n});\n\nconst visible: Ref<boolean> = ref(false);\n\nconst loading = computed(() => props.materialGroupForm.loading);\nconst allowSubmit = computed(\n () => !!(unref(loading) || !props.materialGroupForm.allowSubmit)\n);\n\nconst handleSaveClick = async () => {\n const result = await props.materialGroupForm.submit();\n\n if (result.data.code !== 200) {\n ElMessage.error(result.data.msg);\n return;\n }\n\n props.materialMan.materialGroupTree.load();\n\n visible.value = false;\n};\n\nconst handleCancelClick = () => {\n visible.value = false;\n};\n</script>\n"],"names":["ref","computed","unref","ElMessage"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAsDA,IAAM,MAAA,OAAA,GAAwBA,QAAI,KAAK,CAAA,CAAA;AAEvC,IAAA,MAAM,OAAU,GAAAC,YAAA,CAAS,MAAM,KAAA,CAAM,kBAAkB,OAAO,CAAA,CAAA;AAC9D,IAAA,MAAM,WAAc,GAAAA,YAAA;AAAA,MAClB,MAAM,CAAC,EAAEC,SAAA,CAAM,OAAO,CAAK,IAAA,CAAC,MAAM,iBAAkB,CAAA,WAAA,CAAA;AAAA,KACtD,CAAA;AAEA,IAAA,MAAM,kBAAkB,YAAY;AAClC,MAAA,MAAM,MAAS,GAAA,MAAM,KAAM,CAAA,iBAAA,CAAkB,MAAO,EAAA,CAAA;AAEpD,MAAI,IAAA,MAAA,CAAO,IAAK,CAAA,IAAA,KAAS,GAAK,EAAA;AAC5B,QAAUC,qBAAA,CAAA,KAAA,CAAM,MAAO,CAAA,IAAA,CAAK,GAAG,CAAA,CAAA;AAC/B,QAAA,OAAA;AAAA,OACF;AAEA,MAAM,KAAA,CAAA,WAAA,CAAY,kBAAkB,IAAK,EAAA,CAAA;AAEzC,MAAA,OAAA,CAAQ,KAAQ,GAAA,KAAA,CAAA;AAAA,KAClB,CAAA;AAEA,IAAA,MAAM,oBAAoB,MAAM;AAC9B,MAAA,OAAA,CAAQ,KAAQ,GAAA,KAAA,CAAA;AAAA,KAClB,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -81,7 +81,7 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
81
81
|
const loading = vue.computed(() => props.materialMan.materialGroupTree.loading);
|
|
82
82
|
const handleNodeClick = (item) => {
|
|
83
83
|
if (!item.children.length) {
|
|
84
|
-
props.materialMan.
|
|
84
|
+
props.materialMan.setCurrentMaterialGroup(item.data);
|
|
85
85
|
}
|
|
86
86
|
};
|
|
87
87
|
const handleAddClick = async (parent) => {
|
|
@@ -146,11 +146,13 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
146
146
|
vue.createVNode(vue.unref(index.MKDataTable), {
|
|
147
147
|
"auto-load": false,
|
|
148
148
|
"data-table": materialGroupTree.value,
|
|
149
|
-
"highlight-current": ""
|
|
150
|
-
onNodeClick: handleNodeClick
|
|
149
|
+
"highlight-current": ""
|
|
151
150
|
}, {
|
|
152
151
|
default: vue.withCtx(() => [
|
|
153
|
-
vue.createVNode(vue.unref(index$1.MKTree), {
|
|
152
|
+
vue.createVNode(vue.unref(index$1.MKTree), {
|
|
153
|
+
"data-tree": materialGroupTree.value,
|
|
154
|
+
onNodeClick: handleNodeClick
|
|
155
|
+
}, {
|
|
154
156
|
"node-tools": vue.withCtx(({ data }) => [
|
|
155
157
|
vue.createElementVNode("div", {
|
|
156
158
|
class: "mk-material-group__tools",
|
|
@@ -169,7 +171,7 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
169
171
|
}, {
|
|
170
172
|
default: vue.withCtx(() => [
|
|
171
173
|
vue.createVNode(_component_ElIcon, {
|
|
172
|
-
onClick: ($event) => handleAddClick(data)
|
|
174
|
+
onClick: ($event) => handleAddClick(data.data)
|
|
173
175
|
}, {
|
|
174
176
|
default: vue.withCtx(() => [
|
|
175
177
|
vue.createVNode(vue.unref(icons.Plus))
|
|
@@ -201,7 +203,7 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
201
203
|
}, {
|
|
202
204
|
default: vue.withCtx(() => [
|
|
203
205
|
vue.createVNode(_component_ElIcon, {
|
|
204
|
-
onClick: ($event) => handleEditClick(data)
|
|
206
|
+
onClick: ($event) => handleEditClick(data.data)
|
|
205
207
|
}, {
|
|
206
208
|
default: vue.withCtx(() => [
|
|
207
209
|
vue.createVNode(vue.unref(icons.Edit))
|
|
@@ -228,7 +230,7 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
228
230
|
default: vue.withCtx(() => [
|
|
229
231
|
vue.createElementVNode("span", _hoisted_7, [
|
|
230
232
|
vue.createVNode(_component_ElIcon, {
|
|
231
|
-
onClick: ($event) => handleDeleteClick(data)
|
|
233
|
+
onClick: ($event) => handleDeleteClick(data.data)
|
|
232
234
|
}, {
|
|
233
235
|
default: vue.withCtx(() => [
|
|
234
236
|
vue.createVNode(vue.unref(icons.Delete))
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"material-group.vue2.js","sources":["../../../../src/components/material-list/material-group.vue"],"sourcesContent":["<template>\n <div class=\"mk-material-group\" v-loading=\"loading\">\n <div class=\"mk-material-group__header\">\n <div class=\"mk-material-group__header-title\">素材分组</div>\n <MaterialGroupFromPopper\n :material-man=\"materialMan\"\n :material-group-form=\"materialGroupForm\"\n >\n <ElButton\n @click=\"handleAddClick\"\n :icon=\"Plus\"\n size=\"small\"\n type=\"primary\"\n >\n </ElButton>\n </MaterialGroupFromPopper>\n </div>\n <div class=\"mk-material-group__main\">\n <ElScrollbar height=\"100%\">\n <MKDataTable\n :auto-load=\"false\"\n :data-table=\"materialGroupTree\"\n highlight-current\n
|
|
1
|
+
{"version":3,"file":"material-group.vue2.js","sources":["../../../../src/components/material-list/material-group.vue"],"sourcesContent":["<template>\n <div class=\"mk-material-group\" v-loading=\"loading\">\n <div class=\"mk-material-group__header\">\n <div class=\"mk-material-group__header-title\">素材分组</div>\n <MaterialGroupFromPopper\n :material-man=\"materialMan\"\n :material-group-form=\"materialGroupForm\"\n >\n <ElButton\n @click=\"handleAddClick\"\n :icon=\"Plus\"\n size=\"small\"\n type=\"primary\"\n >\n </ElButton>\n </MaterialGroupFromPopper>\n </div>\n <div class=\"mk-material-group__main\">\n <ElScrollbar height=\"100%\">\n <MKDataTable\n :auto-load=\"false\"\n :data-table=\"materialGroupTree\"\n highlight-current\n >\n <MKTree :data-tree=\"materialGroupTree\" @nodeClick=\"handleNodeClick\">\n <template #node-tools=\"{ data }\">\n <div class=\"mk-material-group__tools\" @click.stop>\n <ElTooltip content=\"添加\">\n <span class=\"mk-material-group__tools-item\">\n <MaterialGroupFromPopper\n :material-man=\"materialMan\"\n :material-group-form=\"materialGroupForm\"\n >\n <ElIcon @click=\"handleAddClick(data.data)\">\n <Plus />\n </ElIcon>\n </MaterialGroupFromPopper>\n </span>\n </ElTooltip>\n <ElTooltip content=\"编辑\">\n <span class=\"mk-material-group__tools-item\">\n <MaterialGroupFromPopper\n :material-man=\"materialMan\"\n :material-group-form=\"materialGroupForm\"\n >\n <ElIcon @click=\"handleEditClick(data.data)\">\n <Edit />\n </ElIcon>\n </MaterialGroupFromPopper>\n </span>\n </ElTooltip>\n <ElTooltip content=\"删除\">\n <span class=\"mk-material-group__tools-item\">\n <ElIcon @click=\"handleDeleteClick(data.data)\">\n <Delete />\n </ElIcon>\n </span>\n </ElTooltip>\n </div>\n </template>\n </MKTree>\n </MKDataTable>\n </ElScrollbar>\n </div>\n <div class=\"mk-material-group__footer\"></div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, nextTick, reactive } from \"vue\";\nimport { ElMessage, ElMessageBox } from \"element-plus\";\nimport { Plus, Edit, Delete } from \"@element-plus/icons-vue\";\nimport {\n MaterialMan,\n MaterialGroupNode,\n MaterialGroupForm,\n} from \"../../dataview\";\nimport { MKDataTable, MKTree } from \"../data-model/data-table\";\n\nimport { useI18n } from \"../../composables\";\nimport MaterialGroupFromPopper from \"./material-group-form-popover.vue\";\nimport { DataTreeNode } from \"@maketribe/dm\";\n\nconst props = defineProps({\n materialMan: {\n type: MaterialMan,\n required: true,\n },\n});\n\nconst i18n = useI18n()!;\n\nconst materialGroupForm = reactive(\n new MaterialGroupForm()\n) as MaterialGroupForm;\n\nconst materialGroupTree = computed(() => props.materialMan.materialGroupTree);\n\nconst loading = computed(() => props.materialMan.materialGroupTree.loading);\n\nconst handleNodeClick = (item: DataTreeNode<MaterialGroupNode>) => {\n if (!item.children.length) {\n props.materialMan.setCurrentMaterialGroup(item.data);\n }\n};\n\nconst handleAddClick = async (parent?: MaterialGroupNode) => {\n materialGroupForm.addRecord();\n\n await nextTick();\n\n materialGroupForm.setData({\n ...materialGroupForm.data,\n parentGroupId: parent?.id || null,\n } as MaterialGroupNode);\n};\n\nconst handleEditClick = (item: MaterialGroupNode) => {\n materialGroupForm.editRecord(item);\n};\n\nconst handleDeleteClick = async (item: MaterialGroupNode) => {\n const isConfirm = await ElMessageBox.confirm(\n i18n.translate(\"mk.dataTablePage.deleteMessage\"),\n i18n.translate(\"mk.dataTablePage.deleteTitle\"),\n { type: \"warning\" }\n ).then(\n () => true,\n () => false\n );\n\n if (!isConfirm) {\n return;\n }\n\n const result = await props.materialMan.materialGroupTree.deleteAfterRefresh(\n item\n );\n\n if (result.data.code !== 200) {\n ElMessage.error(result.data.msg);\n return;\n }\n};\n</script>\n"],"names":["useI18n","reactive","MaterialGroupForm","computed","nextTick","ElMessageBox","ElMessage"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0FA,IAAA,MAAM,OAAOA,eAAQ,EAAA,CAAA;AAErB,IAAA,MAAM,iBAAoB,GAAAC,YAAA;AAAA,MACxB,IAAIC,mCAAkB,EAAA;AAAA,KACxB,CAAA;AAEA,IAAA,MAAM,iBAAoB,GAAAC,YAAA,CAAS,MAAM,KAAA,CAAM,YAAY,iBAAiB,CAAA,CAAA;AAE5E,IAAA,MAAM,UAAUA,YAAS,CAAA,MAAM,KAAM,CAAA,WAAA,CAAY,kBAAkB,OAAO,CAAA,CAAA;AAE1E,IAAM,MAAA,eAAA,GAAkB,CAAC,IAA0C,KAAA;AACjE,MAAI,IAAA,CAAC,IAAK,CAAA,QAAA,CAAS,MAAQ,EAAA;AACzB,QAAM,KAAA,CAAA,WAAA,CAAY,uBAAwB,CAAA,IAAA,CAAK,IAAI,CAAA,CAAA;AAAA,OACrD;AAAA,KACF,CAAA;AAEA,IAAM,MAAA,cAAA,GAAiB,OAAO,MAA+B,KAAA;AAC3D,MAAA,iBAAA,CAAkB,SAAU,EAAA,CAAA;AAE5B,MAAA,MAAMC,YAAS,EAAA,CAAA;AAEf,MAAA,iBAAA,CAAkB,OAAQ,CAAA;AAAA,QACxB,GAAG,iBAAkB,CAAA,IAAA;AAAA,QACrB,aAAA,EAAe,QAAQ,EAAM,IAAA,IAAA;AAAA,OACT,CAAA,CAAA;AAAA,KACxB,CAAA;AAEA,IAAM,MAAA,eAAA,GAAkB,CAAC,IAA4B,KAAA;AACnD,MAAA,iBAAA,CAAkB,WAAW,IAAI,CAAA,CAAA;AAAA,KACnC,CAAA;AAEA,IAAM,MAAA,iBAAA,GAAoB,OAAO,IAA4B,KAAA;AAC3D,MAAM,MAAA,SAAA,GAAY,MAAMC,wBAAa,CAAA,OAAA;AAAA,QACnC,IAAA,CAAK,UAAU,gCAAgC,CAAA;AAAA,QAC/C,IAAA,CAAK,UAAU,8BAA8B,CAAA;AAAA,QAC7C,EAAE,MAAM,SAAU,EAAA;AAAA,OAClB,CAAA,IAAA;AAAA,QACA,MAAM,IAAA;AAAA,QACN,MAAM,KAAA;AAAA,OACR,CAAA;AAEA,MAAA,IAAI,CAAC,SAAW,EAAA;AACd,QAAA,OAAA;AAAA,OACF;AAEA,MAAA,MAAM,MAAS,GAAA,MAAM,KAAM,CAAA,WAAA,CAAY,iBAAkB,CAAA,kBAAA;AAAA,QACvD,IAAA;AAAA,OACF,CAAA;AAEA,MAAI,IAAA,MAAA,CAAO,IAAK,CAAA,IAAA,KAAS,GAAK,EAAA;AAC5B,QAAUC,qBAAA,CAAA,KAAA,CAAM,MAAO,CAAA,IAAA,CAAK,GAAG,CAAA,CAAA;AAC/B,QAAA,OAAA;AAAA,OACF;AAAA,KACF,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -1,2 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 路由变动的几种情况,
|
|
3
|
+
* 1.点击菜单跳转陆游
|
|
4
|
+
* 2.特定业务逻辑需要跳转路由
|
|
5
|
+
* 3.返回上一页
|
|
6
|
+
* 4.刷新页面
|
|
7
|
+
*/
|
|
1
8
|
declare const _default: import("vue").DefineComponent<{}, () => JSX.Element, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}, {}>;
|
|
2
9
|
export default _default;
|
|
@@ -7,7 +7,6 @@ require('element-plus');
|
|
|
7
7
|
require('@maketribe/utils');
|
|
8
8
|
require('../../core/DataModelDefines.js');
|
|
9
9
|
var MSAppClient = require('../../core/MSAppClient.js');
|
|
10
|
-
var route = require('../../constants/route.js');
|
|
11
10
|
var index = require('../config-provider/index.js');
|
|
12
11
|
|
|
13
12
|
function _isSlot(s) {
|
|
@@ -20,53 +19,37 @@ var SystemProvider = /* @__PURE__ */ vue.defineComponent({
|
|
|
20
19
|
const msAppClient = MSAppClient.MSAppClient.instance;
|
|
21
20
|
vue.computed(() => msAppClient.ready);
|
|
22
21
|
const slots = vue.useSlots();
|
|
23
|
-
|
|
24
|
-
const
|
|
22
|
+
vue.watch(vue.computed(() => vue.unref(vueRouter$1.currentRoute)), (route) => {
|
|
23
|
+
const userSession = msAppClient.userSession;
|
|
24
|
+
if (!userSession) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
25
27
|
const router = userSession.router;
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
case route.RouteType.ROUTE:
|
|
40
|
-
if (routeInfo.name === currentTab?.route.name) {
|
|
41
|
-
return false;
|
|
42
|
-
}
|
|
43
|
-
break;
|
|
44
|
-
}
|
|
45
|
-
});
|
|
46
|
-
tabs.currentTabChangeEvent.on(({
|
|
47
|
-
currentTab
|
|
48
|
-
}) => {
|
|
49
|
-
if (!currentTab) {
|
|
50
|
-
return;
|
|
51
|
-
}
|
|
52
|
-
try {
|
|
53
|
-
vueRouter$1.push(currentTab.realRoute ?? {
|
|
54
|
-
name: currentTab.route.name
|
|
55
|
-
});
|
|
56
|
-
} catch (e) {
|
|
57
|
-
console.error(e);
|
|
58
|
-
}
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
if (msAppClient.userSession) {
|
|
62
|
-
initUserSession(msAppClient.userSession);
|
|
63
|
-
}
|
|
64
|
-
msAppClient.userSessionChangeEvent.on(({
|
|
65
|
-
userSession
|
|
66
|
-
}) => {
|
|
67
|
-
if (userSession) {
|
|
68
|
-
initUserSession(userSession);
|
|
28
|
+
const menu = userSession.menu;
|
|
29
|
+
const tabs = userSession.tabs;
|
|
30
|
+
const routeInfo = router.getRouteByName(route.name);
|
|
31
|
+
if (!routeInfo) {
|
|
32
|
+
menu.setCurrentMenuNode(null);
|
|
33
|
+
tabs.setCurrentTab(null);
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const menuNode = menu.findMenuNodeByID(routeInfo.menuId);
|
|
37
|
+
if (!menuNode) {
|
|
38
|
+
menu.setCurrentMenuNode(null);
|
|
39
|
+
tabs.setCurrentTab(null);
|
|
40
|
+
return;
|
|
69
41
|
}
|
|
42
|
+
menu.setCurrentMenuNode(menuNode);
|
|
43
|
+
const tab = tabs.findTabByID(route.fullPath) ?? tabs.createTab({
|
|
44
|
+
id: route.fullPath,
|
|
45
|
+
title: routeInfo.title,
|
|
46
|
+
affix: !!route.matched?.[route.matched?.length - 1]?.meta?.affix,
|
|
47
|
+
realRoute: route,
|
|
48
|
+
route: routeInfo
|
|
49
|
+
});
|
|
50
|
+
tabs.switchTab(tab);
|
|
51
|
+
}, {
|
|
52
|
+
immediate: true
|
|
70
53
|
});
|
|
71
54
|
return () => {
|
|
72
55
|
let _slot;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"system-provider.js","sources":["../../../../src/components/system-provider/system-provider.tsx"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"file":"system-provider.js","sources":["../../../../src/components/system-provider/system-provider.tsx"],"sourcesContent":["import {\n computed,\n defineComponent,\n renderSlot,\n unref,\n useSlots,\n watch,\n} from \"vue\";\nimport { useRouter } from \"vue-router\";\nimport { Components } from \"@maketribe/dm\";\nimport { MSAppClient } from \"../../core\";\nimport { MKConfigProvider } from \"../config-provider\";\n\n/**\n * 路由变动的几种情况,\n * 1.点击菜单跳转陆游\n * 2.特定业务逻辑需要跳转路由\n * 3.返回上一页\n * 4.刷新页面\n */\n\nexport default defineComponent({\n name: \"MKSystemProvider\",\n setup() {\n const vueRouter = useRouter();\n\n const msAppClient = MSAppClient.instance!;\n\n const ready = computed(() => msAppClient.ready);\n\n const slots = useSlots();\n\n watch(\n computed(() => unref(vueRouter.currentRoute)),\n (route) => {\n const userSession = msAppClient.userSession;\n\n if (!userSession) {\n return;\n }\n\n const router = userSession.router;\n const menu = userSession.menu;\n const tabs = userSession.tabs;\n\n const routeInfo = router.getRouteByName(route.name as string);\n\n if (!routeInfo) {\n menu.setCurrentMenuNode(null);\n tabs.setCurrentTab(null);\n return;\n }\n\n const menuNode = menu.findMenuNodeByID(routeInfo.menuId);\n\n if (!menuNode) {\n menu.setCurrentMenuNode(null);\n tabs.setCurrentTab(null);\n return;\n }\n\n menu.setCurrentMenuNode(menuNode);\n\n const tab =\n tabs.findTabByID(route.fullPath) ??\n tabs.createTab({\n id: route.fullPath,\n title: routeInfo.title,\n affix: !!route.matched?.[route.matched?.length - 1]?.meta?.affix,\n realRoute: route,\n route: routeInfo,\n });\n\n tabs.switchTab(tab);\n },\n { immediate: true }\n );\n\n return () => {\n return (\n <MKConfigProvider\n dataTableComponents={msAppClient.dataTableComponents as Components}\n dataFormComponents={msAppClient.dataFormComponents as Components}\n dataFilterComponents={msAppClient.dataFilterComponents as Components}\n whereFilterComponents={\n msAppClient.whereFilterComponents as Components\n }\n i18n={msAppClient.i18n}\n >\n {renderSlot(slots, \"default\")}\n </MKConfigProvider>\n );\n };\n },\n});\n"],"names":["_isSlot","s","Object","prototype","toString","call","_isVNode","defineComponent","name","setup","vueRouter","useRouter","msAppClient","MSAppClient","instance","computed","ready","slots","useSlots","watch","unref","currentRoute","route","userSession","router","menu","tabs","routeInfo","getRouteByName","setCurrentMenuNode","setCurrentTab","menuNode","findMenuNodeByID","menuId","tab","findTabByID","fullPath","createTab","id","title","affix","matched","length","meta","realRoute","switchTab","immediate","_slot","_createVNode","MKConfigProvider","dataTableComponents","dataFormComponents","dataFilterComponents","whereFilterComponents","i18n","renderSlot","default"],"mappings":"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"}
|
|
@@ -1,23 +1,13 @@
|
|
|
1
|
-
import { Disposable
|
|
1
|
+
import { Disposable } from "@maketribe/utils";
|
|
2
2
|
import { Route } from "../dataview";
|
|
3
3
|
import type { UserSession } from "./UserSession";
|
|
4
4
|
export declare class Router extends Disposable {
|
|
5
5
|
userSession: UserSession;
|
|
6
6
|
routes: Route[];
|
|
7
|
-
currentRoute: any | null;
|
|
8
|
-
beforeRouteChange: Event<{
|
|
9
|
-
routeInfo: Route;
|
|
10
|
-
route: any;
|
|
11
|
-
}>;
|
|
12
|
-
routeChange: Event<{
|
|
13
|
-
routeInfo: Route;
|
|
14
|
-
route: any;
|
|
15
|
-
}>;
|
|
16
7
|
constructor(userSession: UserSession);
|
|
17
8
|
setRoutes(routes: Route[]): void;
|
|
18
9
|
init(): void;
|
|
19
10
|
getRouteByName(name: string): Route | null;
|
|
20
11
|
getRouteByID(id: string): Route | null;
|
|
21
12
|
getRoutesByMenuID(menuId: Route["menuId"]): Route[];
|
|
22
|
-
changeRoute(route: any): Promise<boolean>;
|
|
23
13
|
}
|
package/dist/cjs/core/Router.js
CHANGED
|
@@ -8,13 +8,6 @@ const NORMALIZE_ROUTE_NAME_REG = /^dv\/([^/]+)\/([^/]+)(\/.+)?$/;
|
|
|
8
8
|
class Router extends utils.Disposable {
|
|
9
9
|
userSession;
|
|
10
10
|
routes = [];
|
|
11
|
-
currentRoute = null;
|
|
12
|
-
beforeRouteChange = this.register(
|
|
13
|
-
new utils.Event()
|
|
14
|
-
);
|
|
15
|
-
routeChange = this.register(
|
|
16
|
-
new utils.Event()
|
|
17
|
-
);
|
|
18
11
|
constructor(userSession) {
|
|
19
12
|
super();
|
|
20
13
|
this.userSession = userSession;
|
|
@@ -126,21 +119,6 @@ class Router extends utils.Disposable {
|
|
|
126
119
|
getRoutesByMenuID(menuId) {
|
|
127
120
|
return this.routes.filter((route) => route.menuId === menuId);
|
|
128
121
|
}
|
|
129
|
-
async changeRoute(route) {
|
|
130
|
-
if (!route) {
|
|
131
|
-
return true;
|
|
132
|
-
}
|
|
133
|
-
const routeInfo = this.getRouteByName(route.name);
|
|
134
|
-
if (!routeInfo) {
|
|
135
|
-
return true;
|
|
136
|
-
}
|
|
137
|
-
if (await this.beforeRouteChange.emitAsync({ route, routeInfo }) !== false) {
|
|
138
|
-
this.currentRoute = route;
|
|
139
|
-
this.routeChange.emit({ route, routeInfo });
|
|
140
|
-
return true;
|
|
141
|
-
}
|
|
142
|
-
return false;
|
|
143
|
-
}
|
|
144
122
|
}
|
|
145
123
|
|
|
146
124
|
exports.Router = Router;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Router.js","sources":["../../../src/core/Router.ts"],"sourcesContent":["import { Disposable, Event, createDisposable } from \"@maketribe/utils\";\nimport { Route } from \"../dataview\";\nimport type { UserSession } from \"./UserSession\";\n\nconst NORMALIZE_ROUTE_NAME_REG = /^dv\\/([^/]+)\\/([^/]+)(\\/.+)?$/;\n\nexport class Router extends Disposable {\n userSession: UserSession;\n\n routes: Route[] = [];\n\n
|
|
1
|
+
{"version":3,"file":"Router.js","sources":["../../../src/core/Router.ts"],"sourcesContent":["import { Disposable, Event, createDisposable } from \"@maketribe/utils\";\nimport { Route } from \"../dataview\";\nimport type { UserSession } from \"./UserSession\";\n\nconst NORMALIZE_ROUTE_NAME_REG = /^dv\\/([^/]+)\\/([^/]+)(\\/.+)?$/;\n\nexport class Router extends Disposable {\n userSession: UserSession;\n\n routes: Route[] = [];\n\n constructor(userSession: UserSession) {\n super();\n\n this.userSession = userSession;\n }\n\n setRoutes(routes: Route[]) {\n this.routes = routes;\n }\n\n init() {\n const vueRouter = this.userSession.vueRouter;\n const vueRoutes = vueRouter.getRoutes();\n\n // 给有权限访问的页面,注册默认页面\n const defaultPageRoutes = this.routes.filter(\n (route) => !vueRoutes.find((item) => item.name === route.name)\n );\n\n for (const defaultPageRoute of defaultPageRoutes) {\n const match = defaultPageRoute.name.match(NORMALIZE_ROUTE_NAME_REG);\n\n if (match) {\n const name = match[1];\n const action = match[2];\n\n switch (action) {\n case \"single\":\n const [listType, type] = match[3].slice(1).split(\"/\");\n\n switch (listType) {\n case \"list\":\n switch (type) {\n case \"normal\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/list/normal.vue\"\n ),\n meta: { name },\n });\n break;\n case \"dialog\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/list/dialog.vue\"\n ),\n meta: { name },\n });\n break;\n }\n\n break;\n case \"tree\":\n switch (type) {\n case \"dialog\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/tree/dialog.vue\"\n ),\n meta: { name },\n });\n break;\n }\n break;\n case \"table-tree\":\n switch (type) {\n case \"dialog\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () =>\n import(\n \"../page/index/dv/default/single/table-tree/dialog.vue\"\n ),\n meta: { name },\n });\n break;\n }\n }\n\n break;\n case \"list\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}`,\n component: () => import(\"../page/index/dv/default/table.vue\"),\n meta: { name },\n });\n break;\n case \"edit\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}/:id`,\n component: () => import(\"../page/index/dv/default/edit.vue\"),\n meta: { name },\n });\n break;\n case \"add\":\n vueRouter.addRoute(\"mk-ms-layout\", {\n name: defaultPageRoute.name,\n path: `/dv/${name}/add`,\n component: () => import(\"../page/index/dv/default/add.vue\"),\n meta: { name },\n });\n break;\n }\n }\n }\n\n this.register(\n createDisposable(() => {\n for (const defaultPageRoute of defaultPageRoutes) {\n vueRouter.removeRoute(defaultPageRoute.name);\n }\n })\n );\n }\n\n getRouteByName(name: string): Route | null {\n return this.routes.find((route) => route.name === name) ?? null;\n }\n\n getRouteByID(id: string): Route | null {\n return this.routes.find((route) => route.id === id) ?? null;\n }\n\n getRoutesByMenuID(menuId: Route[\"menuId\"]): Route[] {\n return this.routes.filter((route) => route.menuId === menuId);\n }\n}\n"],"names":["Disposable","createDisposable"],"mappings":"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"}
|
|
@@ -88,18 +88,6 @@ class UserSession extends utils.Disposable {
|
|
|
88
88
|
this.tabs.init();
|
|
89
89
|
this.beforeInitRouterEvent.emit();
|
|
90
90
|
this.router.init();
|
|
91
|
-
this.router.routeChange.on(({ route, routeInfo }) => {
|
|
92
|
-
const menuNode = this.menu.findMenuNodeByID(routeInfo.menuId);
|
|
93
|
-
this.menu.setCurrentMenuNode(menuNode);
|
|
94
|
-
const tab = this.tabs.findTabByID(routeInfo.name) ?? this.tabs.createTab({
|
|
95
|
-
id: routeInfo.name,
|
|
96
|
-
title: routeInfo.title,
|
|
97
|
-
affix: route.matched?.[route.matched?.length - 1]?.meta?.affix,
|
|
98
|
-
realRoute: route,
|
|
99
|
-
route: routeInfo
|
|
100
|
-
});
|
|
101
|
-
this.tabs.switchTab(tab);
|
|
102
|
-
});
|
|
103
91
|
return response;
|
|
104
92
|
} catch (e) {
|
|
105
93
|
httpRequest.getInterceptors().request.eject(beforeRequestInterceptorID);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserSession.js","sources":["../../../src/core/UserSession.ts"],"sourcesContent":["import { Disposable, Event, createDisposable, md5 } from \"@maketribe/utils\";\nimport { MemberInfo, UserInfo } from \"./UserInfo\";\nimport { Menu } from \"./menu\";\nimport { Tabs } from \"./tabs\";\nimport { Router } from \"./Router\";\nimport {\n PermissionPoint,\n PermissionPointManager,\n} from \"./PermissionPointManager\";\nimport type { MSAppClient, LoginResult } from \"./MSAppClient\";\nimport { MenuResult, Role, Route } from \"../dataview\";\nimport { R } from \"@maketribe/request\";\nimport {\n ACCESS_TOKEN_HEADER,\n AUTHORIZATION,\n AUTHORIZATION_PREFIX,\n X_ACCESS_TOKEN_HEADER,\n X_AUTHORIZATION,\n} from \"../constants\";\n\nexport type UserSessionOptions = {\n msAppClient: MSAppClient;\n accessToken?: string;\n xAccessToken?: string;\n};\n\nlet uid = 0;\n\nexport class UserSession extends Disposable {\n id = uid++;\n\n msAppClient: MSAppClient;\n\n vueRouter: MSAppClient[\"vueRouter\"];\n\n userInfo: UserInfo | null;\n\n menu: Menu;\n\n tabs: Tabs;\n\n router: Router;\n\n permissionPointManager: PermissionPointManager;\n\n accessToken: string;\n\n xAccessToken: string;\n\n beforeInitRouterEvent: Event = this.register(new Event());\n\n locking: boolean = false;\n\n lockingChangeEvent: Event<{ locking: boolean }> = this.register(new Event());\n\n constructor(options: UserSessionOptions) {\n super();\n\n this.msAppClient = options.msAppClient;\n\n this.vueRouter = this.msAppClient.vueRouter;\n\n this.userInfo = null;\n\n this.router = this.register(new Router(this));\n this.tabs = this.register(new Tabs(this));\n this.permissionPointManager = new PermissionPointManager();\n this.menu = this.register(\n new Menu(this.permissionPointManager, this.router)\n );\n\n this.accessToken =\n options.accessToken ?? localStorage.getItem(ACCESS_TOKEN_HEADER) ?? \"\";\n this.xAccessToken =\n options.xAccessToken ?? localStorage.getItem(X_ACCESS_TOKEN_HEADER) ?? \"\";\n }\n\n async init() {\n type BasicInfoResult = {\n member: MemberInfo;\n menus: MenuResult[];\n routes: Route[];\n roles: Role[];\n permissionPoints: PermissionPoint[];\n };\n\n const msAppClient = this.msAppClient;\n\n const httpRequest = msAppClient.httpRequest;\n\n const beforeRequestInterceptorID = httpRequest\n .getInterceptors()\n .request.use((config) => {\n if (this.accessToken) {\n config.headers[\n AUTHORIZATION\n ] = `${AUTHORIZATION_PREFIX} ${this.accessToken}`;\n }\n\n if (this.xAccessToken) {\n config.headers[\n X_AUTHORIZATION\n ] = `${AUTHORIZATION_PREFIX} ${this.xAccessToken}`;\n }\n\n return config;\n });\n\n const beforeResponseInterceptorID = httpRequest\n .getInterceptors()\n .response.use((config) => {\n if (config.data.code === 401) {\n this.accessToken = this.xAccessToken = \"\";\n } else {\n this.accessToken =\n config.headers[ACCESS_TOKEN_HEADER] || this.accessToken;\n\n this.xAccessToken =\n config.headers[X_ACCESS_TOKEN_HEADER] || this.xAccessToken;\n }\n\n localStorage.setItem(ACCESS_TOKEN_HEADER, this.accessToken);\n\n localStorage.setItem(X_ACCESS_TOKEN_HEADER, this.xAccessToken);\n\n return config;\n });\n\n this.register(\n createDisposable(() => {\n httpRequest.getInterceptors().request.eject(beforeRequestInterceptorID);\n httpRequest\n .getInterceptors()\n .request.eject(beforeResponseInterceptorID);\n })\n );\n\n try {\n let response = await httpRequest.request<R<BasicInfoResult>>({\n url: \"/api/ms-login/login-info\",\n method: \"GET\",\n });\n\n if (!response.data || response.data.code !== 200) {\n return response;\n }\n\n const BasicInfoResult = response.data!;\n\n const { member, routes, menus, permissionPoints, roles } =\n BasicInfoResult.data!;\n\n this.userInfo = new UserInfo(\n msAppClient,\n member,\n roles,\n permissionPoints\n );\n\n this.router.setRoutes(routes);\n this.permissionPointManager.setPermissionPoints(permissionPoints);\n this.menu.setMenus(menus);\n\n this.tabs.init();\n\n this.beforeInitRouterEvent.emit();\n this.router.init();\n\n this.router.routeChange.on(({ route, routeInfo }) => {\n const menuNode = this.menu.findMenuNodeByID(routeInfo.menuId);\n\n this.menu.setCurrentMenuNode(menuNode);\n\n const tab =\n this.tabs.findTabByID(routeInfo.name) ??\n this.tabs.createTab({\n id: routeInfo.name,\n title: routeInfo.title,\n affix: route.matched?.[route.matched?.length - 1]?.meta?.affix,\n realRoute: route,\n route: routeInfo,\n });\n\n this.tabs.switchTab(tab);\n });\n\n return response;\n } catch (e) {\n httpRequest.getInterceptors().request.eject(beforeRequestInterceptorID);\n httpRequest.getInterceptors().request.eject(beforeResponseInterceptorID);\n }\n }\n\n lock() {\n this.locking = true;\n\n this.lockingChangeEvent.emit({ locking: this.locking });\n }\n\n async unlock(password: string, code: string) {\n const response = await this.msAppClient.httpRequest.request<R<LoginResult>>(\n {\n url: \"/api/ms-login/login\",\n method: \"POST\",\n data: {\n account: this.userInfo!.account,\n password: md5(`mkbl#${password}`),\n vCode: code,\n },\n }\n );\n\n if (response.data.code !== 200) {\n return response;\n }\n\n this.accessToken = response.headers[ACCESS_TOKEN_HEADER];\n this.xAccessToken = response.headers[X_ACCESS_TOKEN_HEADER];\n\n this.locking = false;\n\n this.lockingChangeEvent.emit({ locking: this.locking });\n\n return response;\n }\n\n public dispose(): void {\n localStorage.removeItem(ACCESS_TOKEN_HEADER);\n localStorage.removeItem(X_ACCESS_TOKEN_HEADER);\n\n super.dispose();\n }\n}\n"],"names":["Disposable","Event","Router","Tabs","PermissionPointManager","Menu","ACCESS_TOKEN_HEADER","X_ACCESS_TOKEN_HEADER","AUTHORIZATION","AUTHORIZATION_PREFIX","X_AUTHORIZATION","createDisposable","UserInfo","md5"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"UserSession.js","sources":["../../../src/core/UserSession.ts"],"sourcesContent":["import { Disposable, Event, createDisposable, md5 } from \"@maketribe/utils\";\nimport { MemberInfo, UserInfo } from \"./UserInfo\";\nimport { Menu } from \"./menu\";\nimport { Tabs } from \"./tabs\";\nimport { Router } from \"./Router\";\nimport {\n PermissionPoint,\n PermissionPointManager,\n} from \"./PermissionPointManager\";\nimport type { MSAppClient, LoginResult } from \"./MSAppClient\";\nimport { MenuResult, Role, Route } from \"../dataview\";\nimport { R } from \"@maketribe/request\";\nimport {\n ACCESS_TOKEN_HEADER,\n AUTHORIZATION,\n AUTHORIZATION_PREFIX,\n X_ACCESS_TOKEN_HEADER,\n X_AUTHORIZATION,\n} from \"../constants\";\n\nexport type UserSessionOptions = {\n msAppClient: MSAppClient;\n accessToken?: string;\n xAccessToken?: string;\n};\n\nlet uid = 0;\n\nexport class UserSession extends Disposable {\n id = uid++;\n\n msAppClient: MSAppClient;\n\n vueRouter: MSAppClient[\"vueRouter\"];\n\n userInfo: UserInfo | null;\n\n menu: Menu;\n\n tabs: Tabs;\n\n router: Router;\n\n permissionPointManager: PermissionPointManager;\n\n accessToken: string;\n\n xAccessToken: string;\n\n beforeInitRouterEvent: Event = this.register(new Event());\n\n locking: boolean = false;\n\n lockingChangeEvent: Event<{ locking: boolean }> = this.register(new Event());\n\n constructor(options: UserSessionOptions) {\n super();\n\n this.msAppClient = options.msAppClient;\n\n this.vueRouter = this.msAppClient.vueRouter;\n\n this.userInfo = null;\n\n this.router = this.register(new Router(this));\n this.tabs = this.register(new Tabs(this));\n this.permissionPointManager = new PermissionPointManager();\n this.menu = this.register(\n new Menu(this.permissionPointManager, this.router)\n );\n\n this.accessToken =\n options.accessToken ?? localStorage.getItem(ACCESS_TOKEN_HEADER) ?? \"\";\n this.xAccessToken =\n options.xAccessToken ?? localStorage.getItem(X_ACCESS_TOKEN_HEADER) ?? \"\";\n }\n\n async init() {\n type BasicInfoResult = {\n member: MemberInfo;\n menus: MenuResult[];\n routes: Route[];\n roles: Role[];\n permissionPoints: PermissionPoint[];\n };\n\n const msAppClient = this.msAppClient;\n\n const httpRequest = msAppClient.httpRequest;\n\n const beforeRequestInterceptorID = httpRequest\n .getInterceptors()\n .request.use((config) => {\n if (this.accessToken) {\n config.headers[\n AUTHORIZATION\n ] = `${AUTHORIZATION_PREFIX} ${this.accessToken}`;\n }\n\n if (this.xAccessToken) {\n config.headers[\n X_AUTHORIZATION\n ] = `${AUTHORIZATION_PREFIX} ${this.xAccessToken}`;\n }\n\n return config;\n });\n\n const beforeResponseInterceptorID = httpRequest\n .getInterceptors()\n .response.use((config) => {\n if (config.data.code === 401) {\n this.accessToken = this.xAccessToken = \"\";\n } else {\n this.accessToken =\n config.headers[ACCESS_TOKEN_HEADER] || this.accessToken;\n\n this.xAccessToken =\n config.headers[X_ACCESS_TOKEN_HEADER] || this.xAccessToken;\n }\n\n localStorage.setItem(ACCESS_TOKEN_HEADER, this.accessToken);\n\n localStorage.setItem(X_ACCESS_TOKEN_HEADER, this.xAccessToken);\n\n return config;\n });\n\n this.register(\n createDisposable(() => {\n httpRequest.getInterceptors().request.eject(beforeRequestInterceptorID);\n httpRequest\n .getInterceptors()\n .request.eject(beforeResponseInterceptorID);\n })\n );\n\n try {\n let response = await httpRequest.request<R<BasicInfoResult>>({\n url: \"/api/ms-login/login-info\",\n method: \"GET\",\n });\n\n if (!response.data || response.data.code !== 200) {\n return response;\n }\n\n const BasicInfoResult = response.data!;\n\n const { member, routes, menus, permissionPoints, roles } =\n BasicInfoResult.data!;\n\n this.userInfo = new UserInfo(\n msAppClient,\n member,\n roles,\n permissionPoints\n );\n\n this.router.setRoutes(routes);\n this.permissionPointManager.setPermissionPoints(permissionPoints);\n this.menu.setMenus(menus);\n\n this.tabs.init();\n\n this.beforeInitRouterEvent.emit();\n this.router.init();\n\n return response;\n } catch (e) {\n httpRequest.getInterceptors().request.eject(beforeRequestInterceptorID);\n httpRequest.getInterceptors().request.eject(beforeResponseInterceptorID);\n }\n }\n\n lock() {\n this.locking = true;\n\n this.lockingChangeEvent.emit({ locking: this.locking });\n }\n\n async unlock(password: string, code: string) {\n const response = await this.msAppClient.httpRequest.request<R<LoginResult>>(\n {\n url: \"/api/ms-login/login\",\n method: \"POST\",\n data: {\n account: this.userInfo!.account,\n password: md5(`mkbl#${password}`),\n vCode: code,\n },\n }\n );\n\n if (response.data.code !== 200) {\n return response;\n }\n\n this.accessToken = response.headers[ACCESS_TOKEN_HEADER];\n this.xAccessToken = response.headers[X_ACCESS_TOKEN_HEADER];\n\n this.locking = false;\n\n this.lockingChangeEvent.emit({ locking: this.locking });\n\n return response;\n }\n\n public dispose(): void {\n localStorage.removeItem(ACCESS_TOKEN_HEADER);\n localStorage.removeItem(X_ACCESS_TOKEN_HEADER);\n\n super.dispose();\n }\n}\n"],"names":["Disposable","Event","Router","Tabs","PermissionPointManager","Menu","ACCESS_TOKEN_HEADER","X_ACCESS_TOKEN_HEADER","AUTHORIZATION","AUTHORIZATION_PREFIX","X_AUTHORIZATION","createDisposable","UserInfo","md5"],"mappings":"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"}
|
|
@@ -70,15 +70,8 @@ class Tabs extends utils.Disposable {
|
|
|
70
70
|
this.tabsChangeEvent.emit({ tabs });
|
|
71
71
|
}
|
|
72
72
|
switchTab(tab) {
|
|
73
|
-
if (!tab) {
|
|
74
|
-
this.setCurrentTab(null);
|
|
75
|
-
return;
|
|
76
|
-
}
|
|
77
|
-
let _tab = this._tabs.find((item) => item.getID() === tab.getID());
|
|
78
|
-
if (!_tab) {
|
|
79
|
-
this.setTabs([...this.getTabs(), tab]);
|
|
80
|
-
}
|
|
81
73
|
this.setCurrentTab(tab);
|
|
74
|
+
return;
|
|
82
75
|
}
|
|
83
76
|
findTabByID(id) {
|
|
84
77
|
return this.getTabs().find((tab) => tab.id === id) ?? null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tabs.js","sources":["../../../../src/core/tabs/Tabs.ts"],"sourcesContent":["import { Disposable, Event } from \"@maketribe/utils\";\nimport { Tab, TabOptions } from \"./Tab\";\nimport type { UserSession } from \"../UserSession\";\n\nexport class Tabs extends Disposable {\n userSession: UserSession;\n\n _tabs: Tab[] = [];\n _currentTab: Tab | null = null;\n\n currentTabChangeEvent: Event<{ currentTab: Tab | null }> = this.register(\n new Event()\n );\n tabsChangeEvent: Event<{ tabs: Tab[] }> = this.register(new Event());\n\n constructor(userSession: UserSession) {\n super();\n this.userSession = userSession;\n }\n\n init() {\n const getAffixRoutes = () => {\n let routes = this.userSession.vueRouter.getRoutes().slice();\n\n const affixRoutes: any[] = [];\n\n for (let i = 0; i < routes.length; i++) {\n const route = routes[i];\n\n if (route.meta?.affix === true) {\n affixRoutes.push(route);\n }\n }\n\n return affixRoutes;\n };\n\n const getAffixTabs = () => {\n return getAffixRoutes()\n .map((affixRoute) => {\n const route = this.userSession.router.getRouteByName(\n affixRoute.name as string\n );\n\n if (!route) {\n return null;\n }\n\n return this.createTab({\n id: affixRoute.path,\n title: route.title,\n affix: true,\n route: route,\n realRoute: affixRoute,\n });\n })\n .filter(Boolean) as Tab[];\n };\n\n this.setTabs(getAffixTabs());\n }\n\n getTabs() {\n return this._tabs;\n }\n\n getCurrentTab() {\n return this._currentTab;\n }\n\n setCurrentTab(tab: Tab | null) {\n if (this._currentTab === tab) {\n return;\n }\n\n this._currentTab = tab;\n\n this.currentTabChangeEvent.emit({ currentTab: tab });\n }\n\n getTabByID(id: string) {\n return this._tabs.find((tab) => tab.id === id) ?? null;\n }\n\n createTab(options: Omit<TabOptions, \"tabs\">) {\n return this.register(new Tab({ ...options, tabs: this }));\n }\n\n setTabs(tabs: Tab[]): void {\n this._tabs = tabs;\n\n this.tabsChangeEvent.emit({ tabs });\n }\n\n switchTab(tab: Tab | null) {\n if (!tab) {\n
|
|
1
|
+
{"version":3,"file":"Tabs.js","sources":["../../../../src/core/tabs/Tabs.ts"],"sourcesContent":["import { Disposable, Event } from \"@maketribe/utils\";\nimport { Tab, TabOptions } from \"./Tab\";\nimport type { UserSession } from \"../UserSession\";\n\nexport class Tabs extends Disposable {\n userSession: UserSession;\n\n _tabs: Tab[] = [];\n _currentTab: Tab | null = null;\n\n currentTabChangeEvent: Event<{ currentTab: Tab | null }> = this.register(\n new Event()\n );\n tabsChangeEvent: Event<{ tabs: Tab[] }> = this.register(new Event());\n\n constructor(userSession: UserSession) {\n super();\n this.userSession = userSession;\n }\n\n init() {\n const getAffixRoutes = () => {\n let routes = this.userSession.vueRouter.getRoutes().slice();\n\n const affixRoutes: any[] = [];\n\n for (let i = 0; i < routes.length; i++) {\n const route = routes[i];\n\n if (route.meta?.affix === true) {\n affixRoutes.push(route);\n }\n }\n\n return affixRoutes;\n };\n\n const getAffixTabs = () => {\n return getAffixRoutes()\n .map((affixRoute) => {\n const route = this.userSession.router.getRouteByName(\n affixRoute.name as string\n );\n\n if (!route) {\n return null;\n }\n\n return this.createTab({\n id: affixRoute.path,\n title: route.title,\n affix: true,\n route: route,\n realRoute: affixRoute,\n });\n })\n .filter(Boolean) as Tab[];\n };\n\n this.setTabs(getAffixTabs());\n }\n\n getTabs() {\n return this._tabs;\n }\n\n getCurrentTab() {\n return this._currentTab;\n }\n\n setCurrentTab(tab: Tab | null) {\n if (this._currentTab === tab) {\n return;\n }\n\n this._currentTab = tab;\n\n this.currentTabChangeEvent.emit({ currentTab: tab });\n }\n\n getTabByID(id: string) {\n return this._tabs.find((tab) => tab.id === id) ?? null;\n }\n\n createTab(options: Omit<TabOptions, \"tabs\">) {\n return this.register(new Tab({ ...options, tabs: this }));\n }\n\n setTabs(tabs: Tab[]): void {\n this._tabs = tabs;\n\n this.tabsChangeEvent.emit({ tabs });\n }\n\n switchTab(tab: Tab | null) {\n // TODO 暂时用不到Tab\n\n // if (\n // this.getCurrentTab()?.realRoute?.fullPath === tab?.realRoute?.fullPath\n // ) {\n // return;\n // }\n\n this.setCurrentTab(tab);\n return;\n\n // if (!tab) {\n // this.setCurrentTab(null);\n // return;\n // }\n\n // let _tab = this._tabs.find((item) => item.getID() === tab.getID());\n\n // if (!_tab) {\n // this.setTabs([...this.getTabs(), tab]);\n // }\n\n // this.setCurrentTab(tab);\n }\n\n findTabByID(id: Tab[\"id\"]) {\n return this.getTabs().find((tab) => tab.id === id) ?? null;\n }\n\n async closeTab(tab: Tab) {\n if ((await tab.beforeCloseEvent.emitAsync()) === false) {\n return;\n }\n\n const tabItemList = this.getTabs().slice();\n\n if (this.getCurrentTab()?.getID() !== tab.getID()) {\n this.setTabs(tabItemList.filter((item) => item.getID() !== tab.getID()));\n\n return;\n }\n\n const index = tabItemList.findIndex((item) => item.getID() === tab.getID());\n\n if (index === -1) {\n return;\n }\n\n const deleteTab = tabItemList[index];\n deleteTab.dispose();\n\n tabItemList.splice(index, 1);\n this.setTabs(tabItemList);\n\n this.setCurrentTab(this._tabs[this._tabs.length - 1] ?? null);\n }\n\n closeAll() {\n const affixTabs = this.getTabs().filter((tab) => tab.affix);\n\n if (affixTabs.length) {\n this.setTabs(affixTabs);\n this.setCurrentTab(affixTabs[0]);\n return;\n }\n\n this.setTabs([this.getCurrentTab() ?? this.getTabs()[0]]);\n this.setCurrentTab(this.getTabs()[0]);\n }\n\n closeOther() {\n const currentTab = this.getCurrentTab();\n\n if (!currentTab) {\n return;\n }\n\n const affixTabs = this.getTabs().filter((tab) => tab.affix);\n\n if (affixTabs.length) {\n if (affixTabs.find((item) => item.getID() === currentTab.getID())) {\n this.setTabs(affixTabs);\n } else {\n this.setTabs([...affixTabs, currentTab]);\n }\n\n return;\n }\n\n this.setTabs([currentTab]);\n }\n}\n"],"names":["Disposable","Event","Tab"],"mappings":"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"}
|
|
@@ -25,7 +25,7 @@ export declare class MaterialMan {
|
|
|
25
25
|
init(): Promise<void>;
|
|
26
26
|
setAllowAccessMaterialTypeValues(materialTypeValues: MaterialType["value"][]): void;
|
|
27
27
|
getMaterialType(): MaterialType[];
|
|
28
|
-
|
|
28
|
+
setCurrentMaterialGroup(materialGroup: MaterialGroupNode | null): void;
|
|
29
29
|
setCurrentMaterialTypeId(materialTypeId: MaterialType["value"] | null): void;
|
|
30
30
|
protected attachMaterialTableCondition(): void;
|
|
31
31
|
}
|
|
@@ -96,7 +96,7 @@ class MaterialMan {
|
|
|
96
96
|
(materialType) => this.materialTypeValues.includes(materialType.value)
|
|
97
97
|
);
|
|
98
98
|
}
|
|
99
|
-
|
|
99
|
+
setCurrentMaterialGroup(materialGroup) {
|
|
100
100
|
this.materialGroupTree.setCurrentNode(
|
|
101
101
|
materialGroup ? this.materialGroupTree.findDataTreeNode(materialGroup) : null
|
|
102
102
|
);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MaterialMan.js","sources":["../../../../src/dataview/material/MaterialMan.ts"],"sourcesContent":["import { Group, OrderType } from \"@maketribe/request\";\nimport { IComponents, WhereFilter } from \"@maketribe/dm\";\nimport { MaterialTable, MaterialType } from \"./MaterialTable\";\nimport {\n MaterialGroup,\n MaterialGroupNode,\n MaterialGroupTree,\n // MaterialGroupTable,\n} from \"./material-group\";\nimport { UploadError, WebFileUpload, HttpRequest } from \"@maketribe/request\";\nimport { MaterialForm } from \"./MaterialForm\";\n\nexport type MaterialManOptions = {\n components: IComponents;\n httpRequest?: HttpRequest;\n};\n\nexport class MaterialMan {\n // currentMaterialGroupId: MaterialGroup[\"id\"] | null;\n currentMaterialTypeId: MaterialType[\"value\"] | null;\n\n materialTypes: MaterialType[] = [];\n materialTypeValues: MaterialType[\"value\"][] = [];\n\n materialGroupTree: MaterialGroupTree;\n materialTable: MaterialTable;\n materialForm: MaterialForm;\n\n protected initing: boolean = false;\n protected initd: boolean = false;\n\n upload: WebFileUpload;\n\n protected materialConditionGroup: Group;\n\n get currentMaterialGroupId() {\n return this.materialGroupTree.getCurrentNode()?.data?.id ?? null;\n }\n\n get currentMaterialType() {\n return (\n this.materialTypes.find(\n (materialType) => materialType.value === this.currentMaterialTypeId\n ) ?? null\n );\n }\n\n constructor(options: MaterialManOptions) {\n this.materialGroupTree = new MaterialGroupTree();\n // this.materialGroupTable = new MaterialGroupTable();\n this.materialTable = new MaterialTable({\n materialComponents: options.components,\n });\n this.materialForm = new MaterialForm();\n\n this.materialConditionGroup = new Group();\n\n (this.materialTable.dataFilter as WhereFilter)\n .getWhere()\n .addGroup(this.materialConditionGroup);\n\n (this.materialTable.dataFilter as WhereFilter)\n .getOrder()\n .addOrderItem(\"createDate\", OrderType.DESC);\n\n // this.materialGroupTable.dataFilter.setReady();\n this.materialTable.dataFilter.setReady();\n\n this.upload = new WebFileUpload({\n filters: [\n (file) => {\n if (!this.currentMaterialType) {\n throw new UploadError(\"不能上传文件,素材类型无效\");\n }\n\n if (this.currentMaterialType.limit * 1024 * 1024 < file.size) {\n throw new UploadError(\"文件太大不能上传\");\n }\n },\n ],\n httpRequest: options.httpRequest,\n });\n\n // this.currentMaterialGroupId = null;\n this.currentMaterialTypeId = null;\n }\n\n async init() {\n if (this.initing || this.initd) {\n return;\n }\n this.initing = true;\n\n this.upload.uploadEvent.on(({ uploadItem }) => {\n uploadItem.completeEvent.once(async () => {\n await this.materialForm.addRecord();\n\n this.materialForm.setData({\n id: \"\",\n materialGroupId: this.currentMaterialGroupId,\n type: this.currentMaterialTypeId!,\n desc: uploadItem.payload.name,\n path: uploadItem.response!.data.data.path,\n });\n\n const submitResullt = await this.materialForm.submit();\n\n if (submitResullt.data.code !== 200) {\n return;\n }\n\n this.materialTable.load();\n });\n });\n\n await this.materialGroupTree.init();\n await this.materialGroupTree.load();\n\n await this.materialForm.init();\n\n // const getFirstMaterialGroupNode = (\n // materialGroupNodes: MaterialGroupNode[]\n // ): MaterialGroupNode => {\n // if (materialGroupNodes[0].children.length) {\n // return getFirstMaterialGroupNode(materialGroupNodes[0].children);\n // }\n\n // return materialGroupNodes[0];\n // };\n\n // const materialGroupList = this.materialGroupTree.getList();\n\n // if (!materialGroupList.length) {\n // return;\n // }\n\n // this.currentMaterialGroupId =\n // getFirstMaterialGroupNode(materialGroupList).id;\n\n await this.materialTable.init();\n\n this.materialTypes = this.materialTable.getMaterialTypes();\n\n if (this.materialTypes.length) {\n this.currentMaterialTypeId = this.materialTypes[0].value;\n }\n\n this.attachMaterialTableCondition();\n\n this.initing = false;\n this.initd = true;\n }\n\n setAllowAccessMaterialTypeValues(\n materialTypeValues: MaterialType[\"value\"][]\n ) {\n this.materialTypeValues = materialTypeValues;\n }\n\n getMaterialType() {\n if (!this.materialTypeValues.length) {\n return this.materialTypes;\n }\n\n return this.materialTypes.filter((materialType) =>\n this.materialTypeValues.includes(materialType.value)\n );\n }\n\n
|
|
1
|
+
{"version":3,"file":"MaterialMan.js","sources":["../../../../src/dataview/material/MaterialMan.ts"],"sourcesContent":["import { Group, OrderType } from \"@maketribe/request\";\nimport { IComponents, WhereFilter } from \"@maketribe/dm\";\nimport { MaterialTable, MaterialType } from \"./MaterialTable\";\nimport {\n MaterialGroup,\n MaterialGroupNode,\n MaterialGroupTree,\n // MaterialGroupTable,\n} from \"./material-group\";\nimport { UploadError, WebFileUpload, HttpRequest } from \"@maketribe/request\";\nimport { MaterialForm } from \"./MaterialForm\";\n\nexport type MaterialManOptions = {\n components: IComponents;\n httpRequest?: HttpRequest;\n};\n\nexport class MaterialMan {\n // currentMaterialGroupId: MaterialGroup[\"id\"] | null;\n currentMaterialTypeId: MaterialType[\"value\"] | null;\n\n materialTypes: MaterialType[] = [];\n materialTypeValues: MaterialType[\"value\"][] = [];\n\n materialGroupTree: MaterialGroupTree;\n materialTable: MaterialTable;\n materialForm: MaterialForm;\n\n protected initing: boolean = false;\n protected initd: boolean = false;\n\n upload: WebFileUpload;\n\n protected materialConditionGroup: Group;\n\n get currentMaterialGroupId() {\n return this.materialGroupTree.getCurrentNode()?.data?.id ?? null;\n }\n\n get currentMaterialType() {\n return (\n this.materialTypes.find(\n (materialType) => materialType.value === this.currentMaterialTypeId\n ) ?? null\n );\n }\n\n constructor(options: MaterialManOptions) {\n this.materialGroupTree = new MaterialGroupTree();\n // this.materialGroupTable = new MaterialGroupTable();\n this.materialTable = new MaterialTable({\n materialComponents: options.components,\n });\n this.materialForm = new MaterialForm();\n\n this.materialConditionGroup = new Group();\n\n (this.materialTable.dataFilter as WhereFilter)\n .getWhere()\n .addGroup(this.materialConditionGroup);\n\n (this.materialTable.dataFilter as WhereFilter)\n .getOrder()\n .addOrderItem(\"createDate\", OrderType.DESC);\n\n // this.materialGroupTable.dataFilter.setReady();\n this.materialTable.dataFilter.setReady();\n\n this.upload = new WebFileUpload({\n filters: [\n (file) => {\n if (!this.currentMaterialType) {\n throw new UploadError(\"不能上传文件,素材类型无效\");\n }\n\n if (this.currentMaterialType.limit * 1024 * 1024 < file.size) {\n throw new UploadError(\"文件太大不能上传\");\n }\n },\n ],\n httpRequest: options.httpRequest,\n });\n\n // this.currentMaterialGroupId = null;\n this.currentMaterialTypeId = null;\n }\n\n async init() {\n if (this.initing || this.initd) {\n return;\n }\n this.initing = true;\n\n this.upload.uploadEvent.on(({ uploadItem }) => {\n uploadItem.completeEvent.once(async () => {\n await this.materialForm.addRecord();\n\n this.materialForm.setData({\n id: \"\",\n materialGroupId: this.currentMaterialGroupId,\n type: this.currentMaterialTypeId!,\n desc: uploadItem.payload.name,\n path: uploadItem.response!.data.data.path,\n });\n\n const submitResullt = await this.materialForm.submit();\n\n if (submitResullt.data.code !== 200) {\n return;\n }\n\n this.materialTable.load();\n });\n });\n\n await this.materialGroupTree.init();\n await this.materialGroupTree.load();\n\n await this.materialForm.init();\n\n // const getFirstMaterialGroupNode = (\n // materialGroupNodes: MaterialGroupNode[]\n // ): MaterialGroupNode => {\n // if (materialGroupNodes[0].children.length) {\n // return getFirstMaterialGroupNode(materialGroupNodes[0].children);\n // }\n\n // return materialGroupNodes[0];\n // };\n\n // const materialGroupList = this.materialGroupTree.getList();\n\n // if (!materialGroupList.length) {\n // return;\n // }\n\n // this.currentMaterialGroupId =\n // getFirstMaterialGroupNode(materialGroupList).id;\n\n await this.materialTable.init();\n\n this.materialTypes = this.materialTable.getMaterialTypes();\n\n if (this.materialTypes.length) {\n this.currentMaterialTypeId = this.materialTypes[0].value;\n }\n\n this.attachMaterialTableCondition();\n\n this.initing = false;\n this.initd = true;\n }\n\n setAllowAccessMaterialTypeValues(\n materialTypeValues: MaterialType[\"value\"][]\n ) {\n this.materialTypeValues = materialTypeValues;\n }\n\n getMaterialType() {\n if (!this.materialTypeValues.length) {\n return this.materialTypes;\n }\n\n return this.materialTypes.filter((materialType) =>\n this.materialTypeValues.includes(materialType.value)\n );\n }\n\n setCurrentMaterialGroup(materialGroup: MaterialGroupNode | null) {\n this.materialGroupTree.setCurrentNode(\n materialGroup\n ? this.materialGroupTree.findDataTreeNode(materialGroup)\n : null\n );\n\n this.attachMaterialTableCondition();\n }\n\n setCurrentMaterialTypeId(materialTypeId: MaterialType[\"value\"] | null) {\n this.currentMaterialTypeId = materialTypeId;\n\n this.attachMaterialTableCondition();\n }\n\n protected attachMaterialTableCondition() {\n this.materialConditionGroup.clear();\n\n if (this.currentMaterialGroupId) {\n this.materialConditionGroup.addCondition(\n \"materialGroupId\",\n \"=\",\n this.currentMaterialGroupId\n );\n }\n\n if (this.currentMaterialTypeId) {\n this.materialConditionGroup.addCondition(\n \"type\",\n \"=\",\n this.currentMaterialTypeId\n );\n }\n\n this.materialTable.load();\n }\n}\n"],"names":["MaterialGroupTree","MaterialTable","MaterialForm","Group","OrderType","WebFileUpload","UploadError"],"mappings":"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"}
|
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { DataTable, DataTableOptions } from "@maketribe/dm";
|
|
2
|
-
import { Event } from "@maketribe/utils";
|
|
3
2
|
import { Member, MemberForm, MemberResult } from "./MemberForm";
|
|
4
3
|
export type MemberTableItem = Omit<Member, "password" | "confirmPassword">;
|
|
5
4
|
export declare class MemberTable extends DataTable<MemberResult, MemberTableItem> {
|
|
6
5
|
activeMemberForm: MemberForm;
|
|
7
|
-
|
|
6
|
+
isShowActiveMemberForm: boolean;
|
|
8
7
|
constructor(options?: DataTableOptions);
|
|
9
8
|
protected initialize(): Promise<void>;
|
|
10
9
|
protected initActiveMemberForm(): Promise<void>;
|