@maketribe/ms-app 3.0.16 → 3.0.17
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/json-editor/index.js +6 -2
- package/dist/cjs/components/json-editor/index.js.map +1 -1
- package/dist/cjs/components/json-editor/json-editor.js +2 -2
- package/dist/cjs/components/material-select/material-select-type.d.ts +6 -5
- package/dist/cjs/components/new-upload-file/MaterialUploadContext.d.ts +4 -0
- package/dist/cjs/components/new-upload-file/MaterialUploadContext.js +18 -0
- package/dist/cjs/components/new-upload-file/MaterialUploadContext.js.map +1 -0
- package/dist/cjs/components/new-upload-file/UploadContext.d.ts +8 -0
- package/dist/cjs/components/new-upload-file/UploadContext.js +10 -0
- package/dist/cjs/components/new-upload-file/UploadContext.js.map +1 -0
- package/dist/cjs/components/new-upload-file/WebFileUploadContext.d.ts +10 -0
- package/dist/cjs/components/new-upload-file/WebFileUploadContext.js +50 -0
- package/dist/cjs/components/new-upload-file/WebFileUploadContext.js.map +1 -0
- package/dist/cjs/components/new-upload-file/upload-file-options.d.ts +17 -0
- package/dist/cjs/components/new-upload-file/upload-file-options.js +23 -0
- package/dist/cjs/components/new-upload-file/upload-file-options.js.map +1 -0
- package/dist/cjs/components/new-upload-file/upload-file.d.ts +40 -0
- package/dist/cjs/components/new-upload-file/upload-file.js +49 -0
- package/dist/cjs/components/new-upload-file/upload-file.js.map +1 -0
- package/dist/cjs/core/PageManager.js +14 -8
- package/dist/cjs/core/PageManager.js.map +1 -1
- package/dist/cjs/core/Router.js +7 -7
- package/dist/cjs/core/Router.js.map +1 -1
- package/dist/cjs/dataview/route/RouteForm.d.ts +2 -2
- package/dist/cjs/dataview/route/RouteForm.js +2 -2
- package/dist/cjs/dataview/route/RouteForm.js.map +1 -1
- package/dist/cjs/dataview/route/RouteTable.js +1 -1
- package/dist/cjs/dataview/route/RouteTable.js.map +1 -1
- package/dist/cjs/init-application.js +1 -1
- package/dist/cjs/init-application.js.map +1 -1
- package/dist/cjs/router-middleware/auth.js +1 -1
- package/dist/cjs/router-middleware/auth.js.map +1 -1
- package/dist/esm/components/json-editor/index.js +4 -2
- package/dist/esm/components/json-editor/index.js.map +1 -1
- package/dist/esm/components/json-editor/json-editor.js +2 -2
- package/dist/esm/components/material-select/material-select-type.d.ts +6 -5
- package/dist/esm/components/new-upload-file/MaterialUploadContext.d.ts +4 -0
- package/dist/esm/components/new-upload-file/MaterialUploadContext.js +16 -0
- package/dist/esm/components/new-upload-file/MaterialUploadContext.js.map +1 -0
- package/dist/esm/components/new-upload-file/UploadContext.d.ts +8 -0
- package/dist/esm/components/new-upload-file/UploadContext.js +8 -0
- package/dist/esm/components/new-upload-file/UploadContext.js.map +1 -0
- package/dist/esm/components/new-upload-file/WebFileUploadContext.d.ts +10 -0
- package/dist/esm/components/new-upload-file/WebFileUploadContext.js +48 -0
- package/dist/esm/components/new-upload-file/WebFileUploadContext.js.map +1 -0
- package/dist/esm/components/new-upload-file/upload-file-options.d.ts +17 -0
- package/dist/esm/components/new-upload-file/upload-file-options.js +20 -0
- package/dist/esm/components/new-upload-file/upload-file-options.js.map +1 -0
- package/dist/esm/components/new-upload-file/upload-file.d.ts +40 -0
- package/dist/esm/components/new-upload-file/upload-file.js +47 -0
- package/dist/esm/components/new-upload-file/upload-file.js.map +1 -0
- package/dist/esm/core/PageManager.js +14 -8
- package/dist/esm/core/PageManager.js.map +1 -1
- package/dist/esm/core/Router.js +7 -7
- package/dist/esm/core/Router.js.map +1 -1
- package/dist/esm/dataview/route/RouteForm.d.ts +2 -2
- package/dist/esm/dataview/route/RouteForm.js +2 -2
- package/dist/esm/dataview/route/RouteForm.js.map +1 -1
- package/dist/esm/dataview/route/RouteTable.js +1 -1
- package/dist/esm/dataview/route/RouteTable.js.map +1 -1
- package/dist/esm/init-application.js +1 -1
- package/dist/esm/init-application.js.map +1 -1
- package/dist/esm/node_modules/.pnpm/@codemirror_language@6.9.3/node_modules/@codemirror/language/dist/index.js +2 -2
- package/dist/esm/router-middleware/auth.js +1 -1
- package/dist/esm/router-middleware/auth.js.map +1 -1
- package/package.json +2 -2
- package/src/components/json-editor/index.ts +4 -2
- package/src/components/material-select/material-select-type.ts +10 -5
- package/src/components/new-upload-file/MaterialUploadContext.ts +14 -0
- package/src/components/new-upload-file/UploadContext.ts +11 -0
- package/src/components/new-upload-file/WebFileUploadContext.ts +58 -0
- package/src/components/new-upload-file/upload-file-options.ts +23 -0
- package/src/components/new-upload-file/upload-file.tsx +61 -0
- package/src/core/PageManager.ts +18 -9
- package/src/core/Router.ts +7 -7
- package/src/dataview/route/RouteForm.ts +4 -4
- package/src/dataview/route/RouteTable.ts +1 -1
- package/src/init-application.ts +1 -1
- package/src/router-middleware/auth.ts +1 -2
|
@@ -2,10 +2,14 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
+
var vue = require('vue');
|
|
5
6
|
var utils = require('@maketribe/utils');
|
|
6
|
-
var jsonEditor = require('./json-editor.js');
|
|
7
7
|
|
|
8
|
-
|
|
8
|
+
function _interopNamespaceDefaultOnly (e) { return Object.freeze({ __proto__: null, default: e }); }
|
|
9
|
+
|
|
10
|
+
const MKJsonEditor = utils.withInstall(
|
|
11
|
+
vue.defineAsyncComponent(() => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('./json-editor.js')); }))
|
|
12
|
+
);
|
|
9
13
|
|
|
10
14
|
exports.MKJsonEditor = MKJsonEditor;
|
|
11
15
|
exports.default = MKJsonEditor;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../../src/components/json-editor/index.ts"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../src/components/json-editor/index.ts"],"sourcesContent":["import { defineAsyncComponent } from \"vue\";\nimport { withInstall } from \"@maketribe/utils\";\n\nexport const MKJsonEditor = withInstall(\n defineAsyncComponent(() => import(\"./json-editor\"))\n);\n\nexport default MKJsonEditor;\n"],"names":["withInstall","defineAsyncComponent"],"mappings":";;;;;;;;;AAGO,MAAM,YAAe,GAAAA,iBAAA;AAAA,EAC1BC,wBAAqB,CAAA,MAAM,8FAAO,kBAAe,MAAC,CAAA;AACpD;;;;;"}
|
|
@@ -5,7 +5,7 @@ var vueCodemirror_esm = require('../../node_modules/.pnpm/vue-codemirror@6.1.1_c
|
|
|
5
5
|
var index = require('../../node_modules/.pnpm/@codemirror_lang-json@6.0.1/node_modules/@codemirror/lang-json/dist/index.js');
|
|
6
6
|
var jsonEditorOptions = require('./json-editor-options.js');
|
|
7
7
|
|
|
8
|
-
var
|
|
8
|
+
var jsonEditor = /* @__PURE__ */ vue.defineComponent({
|
|
9
9
|
name: "MKCodeMirror",
|
|
10
10
|
props: jsonEditorOptions.jsonEditorProps,
|
|
11
11
|
emits: jsonEditorOptions.jsonEditorEmits,
|
|
@@ -27,5 +27,5 @@ var JsonEditor = /* @__PURE__ */ vue.defineComponent({
|
|
|
27
27
|
}
|
|
28
28
|
});
|
|
29
29
|
|
|
30
|
-
module.exports =
|
|
30
|
+
module.exports = jsonEditor;
|
|
31
31
|
//# sourceMappingURL=json-editor.js.map
|
|
@@ -4,11 +4,12 @@ export interface MKMaterialSelectOptions {
|
|
|
4
4
|
materialMan?: MaterialMan;
|
|
5
5
|
allowMaterialTypeValues: MaterialType["value"][];
|
|
6
6
|
}
|
|
7
|
+
export type MaterialSelectResult = {
|
|
8
|
+
success: boolean;
|
|
9
|
+
data: Material | null;
|
|
10
|
+
path: string;
|
|
11
|
+
};
|
|
7
12
|
export interface IMKMaterialSelect {
|
|
8
|
-
(options?: MKMaterialSelectOptions, appContext?: AppContext): Promise<
|
|
9
|
-
success: boolean;
|
|
10
|
-
data: Material | null;
|
|
11
|
-
path: string;
|
|
12
|
-
}>;
|
|
13
|
+
(options?: MKMaterialSelectOptions, appContext?: AppContext): Promise<MaterialSelectResult>;
|
|
13
14
|
_context: AppContext | null;
|
|
14
15
|
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var index = require('../material-select/index.js');
|
|
4
|
+
var UploadContext = require('./UploadContext.js');
|
|
5
|
+
|
|
6
|
+
class MaterialUploadContext extends UploadContext.UploadContext {
|
|
7
|
+
async selectFile() {
|
|
8
|
+
const materialSelectResult = await index.MKMaterialSelect();
|
|
9
|
+
return {
|
|
10
|
+
success: materialSelectResult.success,
|
|
11
|
+
path: materialSelectResult.path,
|
|
12
|
+
msg: ""
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
exports.MaterialUploadContext = MaterialUploadContext;
|
|
18
|
+
//# sourceMappingURL=MaterialUploadContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MaterialUploadContext.js","sources":["../../../../src/components/new-upload-file/MaterialUploadContext.ts"],"sourcesContent":["import { MKMaterialSelect, MaterialSelectResult } from \"../material-select\";\nimport { UploadContext, UploadResult } from \"./UploadContext\";\n\nexport class MaterialUploadContext extends UploadContext {\n async selectFile(): Promise<UploadResult> {\n const materialSelectResult = await MKMaterialSelect();\n\n return {\n success: materialSelectResult.success,\n path: materialSelectResult.path,\n msg: \"\",\n };\n }\n}\n"],"names":["UploadContext","MKMaterialSelect"],"mappings":";;;;;AAGO,MAAM,8BAA8BA,2BAAc,CAAA;AAAA,EACvD,MAAM,UAAoC,GAAA;AACxC,IAAM,MAAA,oBAAA,GAAuB,MAAMC,sBAAiB,EAAA,CAAA;AAEpD,IAAO,OAAA;AAAA,MACL,SAAS,oBAAqB,CAAA,OAAA;AAAA,MAC9B,MAAM,oBAAqB,CAAA,IAAA;AAAA,MAC3B,GAAK,EAAA,EAAA;AAAA,KACP,CAAA;AAAA,GACF;AACF;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UploadContext.js","sources":["../../../../src/components/new-upload-file/UploadContext.ts"],"sourcesContent":["export type UploadResult = {\n success: boolean;\n path: string;\n msg: string;\n};\n\nexport class UploadContext {\n selectFile(): Promise<UploadResult> {\n throw new Error();\n }\n}\n"],"names":[],"mappings":";;AAMO,MAAM,aAAc,CAAA;AAAA,EACzB,UAAoC,GAAA;AAClC,IAAA,MAAM,IAAI,KAAM,EAAA,CAAA;AAAA,GAClB;AACF;;;;"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { WebFileUpload } from "@maketribe/request";
|
|
2
|
+
import { UploadContext, UploadResult } from "./UploadContext";
|
|
3
|
+
export type WebFileUploadContextOptions = {
|
|
4
|
+
webFileUpload?: WebFileUpload;
|
|
5
|
+
};
|
|
6
|
+
export declare class WebFileUploadContext extends UploadContext {
|
|
7
|
+
webFileUpload: WebFileUpload;
|
|
8
|
+
constructor(options?: WebFileUploadContextOptions);
|
|
9
|
+
selectFile(): Promise<UploadResult>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var request = require('@maketribe/request');
|
|
4
|
+
var UploadContext = require('./UploadContext.js');
|
|
5
|
+
require('vue');
|
|
6
|
+
require('@maketribe/dm');
|
|
7
|
+
require('element-plus');
|
|
8
|
+
require('@maketribe/utils');
|
|
9
|
+
require('../../core/DataModelDefines.js');
|
|
10
|
+
var MSAppClient = require('../../core/MSAppClient.js');
|
|
11
|
+
|
|
12
|
+
class WebFileUploadContext extends UploadContext.UploadContext {
|
|
13
|
+
webFileUpload;
|
|
14
|
+
constructor(options = {}) {
|
|
15
|
+
super();
|
|
16
|
+
this.webFileUpload = options.webFileUpload ?? new request.WebFileUpload({
|
|
17
|
+
httpRequest: MSAppClient.MSAppClient.instance.httpRequest
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
async selectFile() {
|
|
21
|
+
const input = document.createElement("input");
|
|
22
|
+
input.type = "file";
|
|
23
|
+
Object.assign(input.style, {
|
|
24
|
+
width: "1px",
|
|
25
|
+
height: "1px",
|
|
26
|
+
display: "none"
|
|
27
|
+
});
|
|
28
|
+
const file = await new Promise((resolve) => {
|
|
29
|
+
const handleFileChange = (event) => {
|
|
30
|
+
const files = input.files;
|
|
31
|
+
input.parentElement?.removeChild(input);
|
|
32
|
+
resolve(files?.length ? files[0] : null);
|
|
33
|
+
};
|
|
34
|
+
input.addEventListener("change", handleFileChange);
|
|
35
|
+
document.body.append(input);
|
|
36
|
+
});
|
|
37
|
+
if (!file) {
|
|
38
|
+
return { success: true, path: "", msg: "" };
|
|
39
|
+
}
|
|
40
|
+
const response = await this.webFileUpload.upload(file);
|
|
41
|
+
return {
|
|
42
|
+
success: response.data.code === 200,
|
|
43
|
+
path: response.data.data.path,
|
|
44
|
+
msg: response.data.msg
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
exports.WebFileUploadContext = WebFileUploadContext;
|
|
50
|
+
//# sourceMappingURL=WebFileUploadContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WebFileUploadContext.js","sources":["../../../../src/components/new-upload-file/WebFileUploadContext.ts"],"sourcesContent":["import { WebFileUpload } from \"@maketribe/request\";\nimport { UploadContext, UploadResult } from \"./UploadContext\";\nimport { MSAppClient } from \"../../core\";\n\nexport type WebFileUploadContextOptions = {\n webFileUpload?: WebFileUpload;\n};\n\nexport class WebFileUploadContext extends UploadContext {\n webFileUpload: WebFileUpload;\n\n constructor(options: WebFileUploadContextOptions = {}) {\n super();\n\n this.webFileUpload =\n options.webFileUpload ??\n new WebFileUpload({\n httpRequest: MSAppClient.instance!.httpRequest,\n });\n }\n\n async selectFile(): Promise<UploadResult> {\n const input = document.createElement(\"input\");\n\n input.type = \"file\";\n Object.assign(input.style, {\n width: \"1px\",\n height: \"1px\",\n display: \"none\",\n });\n\n const file: File | null = await new Promise((resolve) => {\n const handleFileChange = (event: Event) => {\n const files = input.files;\n\n input.parentElement?.removeChild(input);\n\n resolve(files?.length ? files[0] : null);\n };\n\n input.addEventListener(\"change\", handleFileChange);\n\n document.body.append(input);\n });\n\n if (!file) {\n return { success: true, path: \"\", msg: \"\" };\n }\n\n const response = await this.webFileUpload.upload(file);\n\n return {\n success: response.data.code === 200,\n path: response.data.data.path,\n msg: response.data.msg,\n };\n }\n}\n"],"names":["UploadContext","WebFileUpload","MSAppClient"],"mappings":";;;;;;;;;;;AAQO,MAAM,6BAA6BA,2BAAc,CAAA;AAAA,EACtD,aAAA,CAAA;AAAA,EAEA,WAAA,CAAY,OAAuC,GAAA,EAAI,EAAA;AACrD,IAAM,KAAA,EAAA,CAAA;AAEN,IAAA,IAAA,CAAK,aACH,GAAA,OAAA,CAAQ,aACR,IAAA,IAAIC,qBAAc,CAAA;AAAA,MAChB,WAAA,EAAaC,wBAAY,QAAU,CAAA,WAAA;AAAA,KACpC,CAAA,CAAA;AAAA,GACL;AAAA,EAEA,MAAM,UAAoC,GAAA;AACxC,IAAM,MAAA,KAAA,GAAQ,QAAS,CAAA,aAAA,CAAc,OAAO,CAAA,CAAA;AAE5C,IAAA,KAAA,CAAM,IAAO,GAAA,MAAA,CAAA;AACb,IAAO,MAAA,CAAA,MAAA,CAAO,MAAM,KAAO,EAAA;AAAA,MACzB,KAAO,EAAA,KAAA;AAAA,MACP,MAAQ,EAAA,KAAA;AAAA,MACR,OAAS,EAAA,MAAA;AAAA,KACV,CAAA,CAAA;AAED,IAAA,MAAM,IAAoB,GAAA,MAAM,IAAI,OAAA,CAAQ,CAAC,OAAY,KAAA;AACvD,MAAM,MAAA,gBAAA,GAAmB,CAAC,KAAiB,KAAA;AACzC,QAAA,MAAM,QAAQ,KAAM,CAAA,KAAA,CAAA;AAEpB,QAAM,KAAA,CAAA,aAAA,EAAe,YAAY,KAAK,CAAA,CAAA;AAEtC,QAAA,OAAA,CAAQ,KAAO,EAAA,MAAA,GAAS,KAAM,CAAA,CAAC,IAAI,IAAI,CAAA,CAAA;AAAA,OACzC,CAAA;AAEA,MAAM,KAAA,CAAA,gBAAA,CAAiB,UAAU,gBAAgB,CAAA,CAAA;AAEjD,MAAS,QAAA,CAAA,IAAA,CAAK,OAAO,KAAK,CAAA,CAAA;AAAA,KAC3B,CAAA,CAAA;AAED,IAAA,IAAI,CAAC,IAAM,EAAA;AACT,MAAA,OAAO,EAAE,OAAS,EAAA,IAAA,EAAM,IAAM,EAAA,EAAA,EAAI,KAAK,EAAG,EAAA,CAAA;AAAA,KAC5C;AAEA,IAAA,MAAM,QAAW,GAAA,MAAM,IAAK,CAAA,aAAA,CAAc,OAAO,IAAI,CAAA,CAAA;AAErD,IAAO,OAAA;AAAA,MACL,OAAA,EAAS,QAAS,CAAA,IAAA,CAAK,IAAS,KAAA,GAAA;AAAA,MAChC,IAAA,EAAM,QAAS,CAAA,IAAA,CAAK,IAAK,CAAA,IAAA;AAAA,MACzB,GAAA,EAAK,SAAS,IAAK,CAAA,GAAA;AAAA,KACrB,CAAA;AAAA,GACF;AACF;;;;"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ExtractPropTypes } from "vue";
|
|
2
|
+
import { UploadContext } from "./UploadContext";
|
|
3
|
+
import { MaterialUploadContext } from "./MaterialUploadContext";
|
|
4
|
+
export declare const uploadFileProps: {
|
|
5
|
+
readonly modelValue: {
|
|
6
|
+
readonly type: import("vue").PropType<string>;
|
|
7
|
+
readonly required: true;
|
|
8
|
+
readonly validator: ((val: unknown) => boolean) | undefined;
|
|
9
|
+
__mkPropKey: true;
|
|
10
|
+
};
|
|
11
|
+
readonly uploadContext: import("@maketribe/utils").PropFinalized<typeof UploadContext, unknown, unknown, () => MaterialUploadContext, boolean>;
|
|
12
|
+
};
|
|
13
|
+
export type UploadFileProps = ExtractPropTypes<typeof uploadFileProps>;
|
|
14
|
+
export declare const uploadFileEmits: {
|
|
15
|
+
"upload:modelValue": (path: string) => boolean;
|
|
16
|
+
};
|
|
17
|
+
export type UploadFileEmits = typeof uploadFileEmits;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var utils = require('@maketribe/utils');
|
|
4
|
+
var UploadContext = require('./UploadContext.js');
|
|
5
|
+
var MaterialUploadContext = require('./MaterialUploadContext.js');
|
|
6
|
+
|
|
7
|
+
const uploadFileProps = utils.buildProps({
|
|
8
|
+
modelValue: {
|
|
9
|
+
type: String,
|
|
10
|
+
required: true
|
|
11
|
+
},
|
|
12
|
+
uploadContext: {
|
|
13
|
+
type: UploadContext.UploadContext,
|
|
14
|
+
default: () => new MaterialUploadContext.MaterialUploadContext()
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
const uploadFileEmits = {
|
|
18
|
+
"upload:modelValue": (path) => true
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
exports.uploadFileEmits = uploadFileEmits;
|
|
22
|
+
exports.uploadFileProps = uploadFileProps;
|
|
23
|
+
//# sourceMappingURL=upload-file-options.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upload-file-options.js","sources":["../../../../src/components/new-upload-file/upload-file-options.ts"],"sourcesContent":["import { ExtractPropTypes } from \"vue\";\nimport { buildProps } from \"@maketribe/utils\";\nimport { UploadContext } from \"./UploadContext\";\nimport { MaterialUploadContext } from \"./MaterialUploadContext\";\n\nexport const uploadFileProps = buildProps({\n modelValue: {\n type: String,\n required: true,\n },\n uploadContext: {\n type: UploadContext,\n default: () => new MaterialUploadContext(),\n },\n} as const);\n\nexport type UploadFileProps = ExtractPropTypes<typeof uploadFileProps>;\n\nexport const uploadFileEmits = {\n \"upload:modelValue\": (path: string) => true,\n};\n\nexport type UploadFileEmits = typeof uploadFileEmits;\n"],"names":["buildProps","UploadContext","MaterialUploadContext"],"mappings":";;;;;;AAKO,MAAM,kBAAkBA,gBAAW,CAAA;AAAA,EACxC,UAAY,EAAA;AAAA,IACV,IAAM,EAAA,MAAA;AAAA,IACN,QAAU,EAAA,IAAA;AAAA,GACZ;AAAA,EACA,aAAe,EAAA;AAAA,IACb,IAAM,EAAAC,2BAAA;AAAA,IACN,OAAA,EAAS,MAAM,IAAIC,2CAAsB,EAAA;AAAA,GAC3C;AACF,CAAU,EAAA;AAIH,MAAM,eAAkB,GAAA;AAAA,EAC7B,mBAAA,EAAqB,CAAC,IAAiB,KAAA,IAAA;AACzC;;;;;"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 文件上传
|
|
3
|
+
*
|
|
4
|
+
* 文件上传在本后台中有两大分类
|
|
5
|
+
* 1.直接上传文件
|
|
6
|
+
* 2.使用素材库文件
|
|
7
|
+
*
|
|
8
|
+
* 文件上传的界面交互又会分为几种情况
|
|
9
|
+
* 1.单文件上传(单文件上传,可能会根据。文件情况的不同,界面显示方式不一样)
|
|
10
|
+
* 2.多文件上传(多文件上传基于单文件的逻辑,不过是会变成多个文件)
|
|
11
|
+
*
|
|
12
|
+
* 希望文件交互组件不需要用了解是直接上传文件或使用素材库。
|
|
13
|
+
*
|
|
14
|
+
*/
|
|
15
|
+
declare const _default: import("vue").DefineComponent<{
|
|
16
|
+
readonly modelValue: {
|
|
17
|
+
readonly type: import("vue").PropType<string>;
|
|
18
|
+
readonly required: true;
|
|
19
|
+
readonly validator: ((val: unknown) => boolean) | undefined;
|
|
20
|
+
__mkPropKey: true;
|
|
21
|
+
};
|
|
22
|
+
readonly uploadContext: import("@maketribe/utils").PropFinalized<typeof import("./UploadContext").UploadContext, unknown, unknown, () => import("./MaterialUploadContext").MaterialUploadContext, boolean>;
|
|
23
|
+
}, {
|
|
24
|
+
handleUpload: () => Promise<void>;
|
|
25
|
+
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
26
|
+
"upload:modelValue": (path: string) => boolean;
|
|
27
|
+
}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
28
|
+
readonly modelValue: {
|
|
29
|
+
readonly type: import("vue").PropType<string>;
|
|
30
|
+
readonly required: true;
|
|
31
|
+
readonly validator: ((val: unknown) => boolean) | undefined;
|
|
32
|
+
__mkPropKey: true;
|
|
33
|
+
};
|
|
34
|
+
readonly uploadContext: import("@maketribe/utils").PropFinalized<typeof import("./UploadContext").UploadContext, unknown, unknown, () => import("./MaterialUploadContext").MaterialUploadContext, boolean>;
|
|
35
|
+
}>> & {
|
|
36
|
+
"onUpload:modelValue"?: ((path: string) => any) | undefined;
|
|
37
|
+
}, {
|
|
38
|
+
readonly uploadContext: import("./UploadContext").UploadContext;
|
|
39
|
+
}, {}>;
|
|
40
|
+
export default _default;
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
var uploadFileOptions = require('./upload-file-options.js');
|
|
5
|
+
var elementPlus = require('element-plus');
|
|
6
|
+
|
|
7
|
+
var uploadFile = /* @__PURE__ */ vue.defineComponent({
|
|
8
|
+
name: "MKUploadFile",
|
|
9
|
+
props: uploadFileOptions.uploadFileProps,
|
|
10
|
+
emits: uploadFileOptions.uploadFileEmits,
|
|
11
|
+
setup(props, {
|
|
12
|
+
emit
|
|
13
|
+
}) {
|
|
14
|
+
const value = vue.computed({
|
|
15
|
+
get: () => props.modelValue,
|
|
16
|
+
set: (v) => emit("upload:modelValue", v)
|
|
17
|
+
});
|
|
18
|
+
const uploadContext = vue.computed(() => props.uploadContext);
|
|
19
|
+
const handleUpload = async () => {
|
|
20
|
+
try {
|
|
21
|
+
const uploadResult = await vue.unref(uploadContext).selectFile();
|
|
22
|
+
if (uploadResult.success) {
|
|
23
|
+
value.value = uploadResult.path;
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
elementPlus.ElMessage.error(uploadResult.msg);
|
|
27
|
+
} catch (e) {
|
|
28
|
+
console.error(e);
|
|
29
|
+
elementPlus.ElMessage.error("\u7F51\u7EDC\u5F02\u5E38");
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
return {
|
|
33
|
+
handleUpload
|
|
34
|
+
};
|
|
35
|
+
},
|
|
36
|
+
render() {
|
|
37
|
+
const {
|
|
38
|
+
handleUpload,
|
|
39
|
+
$slots
|
|
40
|
+
} = this;
|
|
41
|
+
return vue.createVNode("div", {
|
|
42
|
+
"class": "mk-upload-file",
|
|
43
|
+
"onClick": handleUpload
|
|
44
|
+
}, [$slots.default?.()]);
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
module.exports = uploadFile;
|
|
49
|
+
//# sourceMappingURL=upload-file.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upload-file.js","sources":["../../../../src/components/new-upload-file/upload-file.tsx"],"sourcesContent":["import { computed, defineComponent, unref } from \"vue\";\nimport { uploadFileEmits, uploadFileProps } from \"./upload-file-options\";\nimport { ElMessage } from \"element-plus\";\n\n/**\n * 文件上传\n *\n * 文件上传在本后台中有两大分类\n * 1.直接上传文件\n * 2.使用素材库文件\n *\n * 文件上传的界面交互又会分为几种情况\n * 1.单文件上传(单文件上传,可能会根据。文件情况的不同,界面显示方式不一样)\n * 2.多文件上传(多文件上传基于单文件的逻辑,不过是会变成多个文件)\n *\n * 希望文件交互组件不需要用了解是直接上传文件或使用素材库。\n *\n */\n\nexport default defineComponent({\n name: \"MKUploadFile\",\n props: uploadFileProps,\n emits: uploadFileEmits,\n setup(props, { emit }) {\n const value = computed({\n get: () => props.modelValue,\n set: (v: string) => emit(\"upload:modelValue\", v),\n });\n\n const uploadContext = computed(() => props.uploadContext);\n\n const handleUpload = async () => {\n try {\n const uploadResult = await unref(uploadContext).selectFile();\n\n if (uploadResult.success) {\n value.value = uploadResult.path;\n return;\n }\n\n ElMessage.error(uploadResult.msg);\n } catch (e) {\n console.error(e);\n ElMessage.error(\"网络异常\");\n }\n };\n\n return {\n handleUpload,\n };\n },\n render() {\n const { handleUpload, $slots } = this;\n\n return (\n <div class=\"mk-upload-file\" onClick={handleUpload}>\n {$slots.default?.()}\n </div>\n );\n },\n});\n"],"names":["defineComponent","name","props","uploadFileProps","emits","uploadFileEmits","setup","emit","value","computed","get","modelValue","set","v","uploadContext","handleUpload","uploadResult","unref","selectFile","success","path","ElMessage","error","msg","e","console","render","$slots","_createVNode","default"],"mappings":";;;;;;AAmBA,iCAA+BA,mBAAA,CAAA;AAAA,EAC7BC,IAAM,EAAA,cAAA;AAAA,EACNC,KAAOC,EAAAA,iCAAAA;AAAAA,EACPC,KAAOC,EAAAA,iCAAAA;AAAAA,EACPC,MAAMJ,KAAO,EAAA;AAAA,IAAEK,IAAAA;AAAAA,GAAQ,EAAA;AACrB,IAAA,MAAMC,QAAQC,YAAS,CAAA;AAAA,MACrBC,GAAAA,EAAKA,MAAMR,KAAMS,CAAAA,UAAAA;AAAAA,MACjBC,GAAMC,EAAAA,CAAAA,CAAAA,KAAcN,IAAK,CAAA,mBAAA,EAAqBM,CAAC,CAAA;AAAA,KAChD,CAAA,CAAA;AAED,IAAA,MAAMC,aAAgBL,GAAAA,YAAAA,CAAS,MAAMP,KAAAA,CAAMY,aAAa,CAAA,CAAA;AAExD,IAAA,MAAMC,eAAe,YAAY;AAC/B,MAAI,IAAA;AACF,QAAA,MAAMC,YAAe,GAAA,MAAMC,SAAMH,CAAAA,aAAa,EAAEI,UAAW,EAAA,CAAA;AAE3D,QAAA,IAAIF,aAAaG,OAAS,EAAA;AACxBX,UAAAA,KAAAA,CAAMA,QAAQQ,YAAaI,CAAAA,IAAAA,CAAAA;AAC3B,UAAA,OAAA;AAAA,SACF;AAEAC,QAAUC,qBAAAA,CAAAA,KAAAA,CAAMN,aAAaO,GAAG,CAAA,CAAA;AAAA,eACzBC,CAAG,EAAA;AACVC,QAAAA,OAAAA,CAAQH,MAAME,CAAC,CAAA,CAAA;AACfH,QAAAA,qBAAAA,CAAUC,MAAM,0BAAM,CAAA,CAAA;AAAA,OACxB;AAAA,KACF,CAAA;AAEA,IAAO,OAAA;AAAA,MACLP,YAAAA;AAAAA,KACF,CAAA;AAAA,GACF;AAAA,EACAW,MAAS,GAAA;AACP,IAAM,MAAA;AAAA,MAAEX,YAAAA;AAAAA,MAAcY,MAAAA;AAAAA,KAAW,GAAA,IAAA,CAAA;AAEjC,IAAA,OAAAC,gBAAA,KAAA,EAAA;AAAA,MAAA,OAAA,EAAA,gBAAA;AAAA,MAAA,SACuCb,EAAAA,YAAAA;AAAAA,KAAY,EAAA,CAC9CY,MAAOE,CAAAA,OAAAA,IAAW,CAAA,CAAA,CAAA;AAAA,GAGzB;AACF,CAAC,CAAA;;;;"}
|
|
@@ -96,24 +96,30 @@ class PageManager {
|
|
|
96
96
|
if (!userSession) {
|
|
97
97
|
return;
|
|
98
98
|
}
|
|
99
|
+
const router = userSession.router;
|
|
99
100
|
const addedExtendsPageNames = [];
|
|
100
|
-
if (!this.extendsPages.find((page) => page.name === "notFound")) {
|
|
101
|
-
this.addExtendsPage({
|
|
102
|
-
name: "notFound",
|
|
103
|
-
// path: ":pathMatch(.*)*",
|
|
104
|
-
path: "",
|
|
105
|
-
component: () => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('../page/index/404.vue.js')); })
|
|
106
|
-
});
|
|
107
|
-
}
|
|
108
101
|
for (const extendsPage of this.extendsPages) {
|
|
102
|
+
const routeInfo = router.getRouteByName(extendsPage.name);
|
|
103
|
+
if (!routeInfo) {
|
|
104
|
+
continue;
|
|
105
|
+
}
|
|
109
106
|
const vueRoute = vueRoutes.find(
|
|
110
107
|
(vueRoute2) => vueRoute2.name === extendsPage.name
|
|
111
108
|
);
|
|
112
109
|
if (!vueRoute) {
|
|
110
|
+
extendsPage.path = routeInfo.route || extendsPage.path;
|
|
113
111
|
addedExtendsPageNames.push(extendsPage.name);
|
|
114
112
|
vueRouter.addRoute("mk-ms-layout", extendsPage);
|
|
115
113
|
}
|
|
116
114
|
}
|
|
115
|
+
if (!this.extendsPages.find((page) => page.name === "notFound")) {
|
|
116
|
+
this.addExtendsPage({
|
|
117
|
+
name: "notFound",
|
|
118
|
+
// path: ":pathMatch(.*)*",
|
|
119
|
+
path: "",
|
|
120
|
+
component: () => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('../page/index/404.vue.js')); })
|
|
121
|
+
});
|
|
122
|
+
}
|
|
117
123
|
userSession.register(
|
|
118
124
|
utils.createDisposable(() => {
|
|
119
125
|
for (const addedExtendsPageName of addedExtendsPageNames) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PageManager.js","sources":["../../../src/core/PageManager.ts"],"sourcesContent":["import { RouteRecordRaw } from \"vue-router\";\nimport type { MSAppClient } from \"./MSAppClient\";\nimport { Disposable, Event, createDisposable } from \"@maketribe/utils\";\n\nexport class PageManager {\n normalPages: RouteRecordRaw[] = [];\n\n extendsPages: RouteRecordRaw[] = [];\n\n msAppClient: MSAppClient | null = null;\n\n msAppClientChangeEvent: Event<{ msAppClient: MSAppClient | null }> =\n new Event();\n\n msAppClientDisposable: Disposable | null = null;\n\n setMSAppCLient(msAppClient: MSAppClient | null) {\n this.msAppClientDisposable?.dispose();\n\n this.msAppClientDisposable = new Disposable();\n\n this.msAppClient = msAppClient;\n\n this.msAppClientChangeEvent.emit({ msAppClient });\n }\n\n addNormalPage(normalPage: RouteRecordRaw) {\n this.normalPages.push(normalPage);\n }\n\n addExtendsPage(extendsPage: RouteRecordRaw) {\n this.extendsPages.push(extendsPage);\n }\n\n init() {\n this.addNormalPage({\n name: \"mk-ms-layout\",\n path: \"/\",\n component: () => import(\"../page/index.vue\"),\n });\n\n this.addNormalPage({\n name: \"login\",\n path: \"/login\",\n meta: {\n isAuthorization: false,\n },\n component: () => import(\"../page/login/index.vue\"),\n });\n\n this.addNormalPage({\n name: \"signup\",\n path: \"/signup\",\n meta: {\n isAuthorization: false,\n },\n component: () => import(\"../page/signup/index.vue\"),\n });\n\n this.addExtendsPage({\n name: \"dv/ms-material/list\",\n path: \"/material-list\",\n component: () => import(\"../page/index/material/index.vue\"),\n meta: { name: \"ms-material\" },\n });\n\n this.addExtendsPage({\n name: \"dv/ms-member/single/list/normal\",\n path: \"/dv/ms-member\",\n component: () => import(\"../page/index/dv/ms-member/index.vue\"),\n meta: { name: \"ms-member\" },\n });\n\n this.addExtendsPage({\n name: \"dv/ms-role/single/list/dialog\",\n path: \"/dv/ms-role\",\n component: () => import(\"../page/index/dv/ms-role/index.vue\"),\n meta: { name: \"ms-role\" },\n });\n\n this.addExtendsPage({\n name: \"dv/local-log/single/tree/dialog\",\n path: \"/log/local\",\n component: () => import(\"../page/index/dv/local-log/index.vue\"),\n meta: { name: \"local-log\" },\n });\n\n this.msAppClientChangeEvent.on(({ msAppClient }) => {\n if (!msAppClient) {\n return;\n }\n\n const vueRouter = msAppClient.vueRouter;\n const vueRoutes = vueRouter.getRoutes();\n\n const addedNormalPageNames: string[] = [];\n\n for (const normalPage of this.normalPages) {\n const vueRoute = vueRoutes.find(\n (vueRoute) => vueRoute.name === normalPage.name\n );\n\n if (!vueRoute) {\n addedNormalPageNames.push(normalPage.name as string);\n vueRouter.addRoute(normalPage);\n }\n }\n\n this.msAppClientDisposable?.register(\n createDisposable(() => {\n for (const addedNormalPageName of addedNormalPageNames) {\n vueRouter.removeRoute(addedNormalPageName);\n }\n })\n );\n\n this.msAppClientDisposable?.register(\n msAppClient.beforeInitUserSessionEvent.on(({ userSession }) => {\n if (!userSession) {\n return;\n }\n\n const addedExtendsPageNames: string[] = [];\n\n
|
|
1
|
+
{"version":3,"file":"PageManager.js","sources":["../../../src/core/PageManager.ts"],"sourcesContent":["import { RouteRecordRaw } from \"vue-router\";\nimport type { MSAppClient } from \"./MSAppClient\";\nimport { Disposable, Event, createDisposable } from \"@maketribe/utils\";\n\nexport class PageManager {\n normalPages: RouteRecordRaw[] = [];\n\n extendsPages: RouteRecordRaw[] = [];\n\n msAppClient: MSAppClient | null = null;\n\n msAppClientChangeEvent: Event<{ msAppClient: MSAppClient | null }> =\n new Event();\n\n msAppClientDisposable: Disposable | null = null;\n\n setMSAppCLient(msAppClient: MSAppClient | null) {\n this.msAppClientDisposable?.dispose();\n\n this.msAppClientDisposable = new Disposable();\n\n this.msAppClient = msAppClient;\n\n this.msAppClientChangeEvent.emit({ msAppClient });\n }\n\n addNormalPage(normalPage: RouteRecordRaw) {\n this.normalPages.push(normalPage);\n }\n\n addExtendsPage(extendsPage: RouteRecordRaw) {\n this.extendsPages.push(extendsPage);\n }\n\n init() {\n this.addNormalPage({\n name: \"mk-ms-layout\",\n path: \"/\",\n component: () => import(\"../page/index.vue\"),\n });\n\n this.addNormalPage({\n name: \"login\",\n path: \"/login\",\n meta: {\n isAuthorization: false,\n },\n component: () => import(\"../page/login/index.vue\"),\n });\n\n this.addNormalPage({\n name: \"signup\",\n path: \"/signup\",\n meta: {\n isAuthorization: false,\n },\n component: () => import(\"../page/signup/index.vue\"),\n });\n\n this.addExtendsPage({\n name: \"dv/ms-material/list\",\n path: \"/material-list\",\n component: () => import(\"../page/index/material/index.vue\"),\n meta: { name: \"ms-material\" },\n });\n\n this.addExtendsPage({\n name: \"dv/ms-member/single/list/normal\",\n path: \"/dv/ms-member\",\n component: () => import(\"../page/index/dv/ms-member/index.vue\"),\n meta: { name: \"ms-member\" },\n });\n\n this.addExtendsPage({\n name: \"dv/ms-role/single/list/dialog\",\n path: \"/dv/ms-role\",\n component: () => import(\"../page/index/dv/ms-role/index.vue\"),\n meta: { name: \"ms-role\" },\n });\n\n this.addExtendsPage({\n name: \"dv/local-log/single/tree/dialog\",\n path: \"/log/local\",\n component: () => import(\"../page/index/dv/local-log/index.vue\"),\n meta: { name: \"local-log\" },\n });\n\n this.msAppClientChangeEvent.on(({ msAppClient }) => {\n if (!msAppClient) {\n return;\n }\n\n const vueRouter = msAppClient.vueRouter;\n const vueRoutes = vueRouter.getRoutes();\n\n const addedNormalPageNames: string[] = [];\n\n for (const normalPage of this.normalPages) {\n const vueRoute = vueRoutes.find(\n (vueRoute) => vueRoute.name === normalPage.name\n );\n\n if (!vueRoute) {\n addedNormalPageNames.push(normalPage.name as string);\n vueRouter.addRoute(normalPage);\n }\n }\n\n this.msAppClientDisposable?.register(\n createDisposable(() => {\n for (const addedNormalPageName of addedNormalPageNames) {\n vueRouter.removeRoute(addedNormalPageName);\n }\n })\n );\n\n this.msAppClientDisposable?.register(\n msAppClient.beforeInitUserSessionEvent.on(({ userSession }) => {\n if (!userSession) {\n return;\n }\n\n const router = userSession.router;\n\n const addedExtendsPageNames: string[] = [];\n\n for (const extendsPage of this.extendsPages) {\n const routeInfo = router.getRouteByName(extendsPage.name as string);\n\n if (!routeInfo) {\n continue;\n }\n\n const vueRoute = vueRoutes.find(\n (vueRoute) => vueRoute.name === extendsPage.name\n );\n\n if (!vueRoute) {\n extendsPage.path = routeInfo.route || extendsPage.path;\n addedExtendsPageNames.push(extendsPage.name as string);\n vueRouter.addRoute(\"mk-ms-layout\", extendsPage);\n }\n }\n\n if (!this.extendsPages.find((page) => page.name === \"notFound\")) {\n this.addExtendsPage({\n name: \"notFound\",\n // path: \":pathMatch(.*)*\",\n path: \"\",\n component: () => import(\"../page/index/404.vue\"),\n });\n }\n\n userSession.register(\n createDisposable(() => {\n for (const addedExtendsPageName of addedExtendsPageNames) {\n vueRouter.removeRoute(addedExtendsPageName);\n }\n })\n );\n })\n );\n });\n }\n}\n"],"names":["Event","Disposable","vueRoute","createDisposable"],"mappings":"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"}
|
package/dist/cjs/core/Router.js
CHANGED
|
@@ -35,7 +35,7 @@ class Router extends utils.Disposable {
|
|
|
35
35
|
case "normal":
|
|
36
36
|
vueRouter.addRoute("mk-ms-layout", {
|
|
37
37
|
name: defaultPageRoute.name,
|
|
38
|
-
path: `/dv/${name}`,
|
|
38
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
39
39
|
component: () => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('../page/index/dv/default/single/list/normal.vue.js')); }),
|
|
40
40
|
meta: { name }
|
|
41
41
|
});
|
|
@@ -43,7 +43,7 @@ class Router extends utils.Disposable {
|
|
|
43
43
|
case "dialog":
|
|
44
44
|
vueRouter.addRoute("mk-ms-layout", {
|
|
45
45
|
name: defaultPageRoute.name,
|
|
46
|
-
path: `/dv/${name}`,
|
|
46
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
47
47
|
component: () => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('../page/index/dv/default/single/list/dialog.vue.js')); }),
|
|
48
48
|
meta: { name }
|
|
49
49
|
});
|
|
@@ -55,7 +55,7 @@ class Router extends utils.Disposable {
|
|
|
55
55
|
case "dialog":
|
|
56
56
|
vueRouter.addRoute("mk-ms-layout", {
|
|
57
57
|
name: defaultPageRoute.name,
|
|
58
|
-
path: `/dv/${name}`,
|
|
58
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
59
59
|
component: () => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('../page/index/dv/default/single/tree/dialog.vue.js')); }),
|
|
60
60
|
meta: { name }
|
|
61
61
|
});
|
|
@@ -67,7 +67,7 @@ class Router extends utils.Disposable {
|
|
|
67
67
|
case "dialog":
|
|
68
68
|
vueRouter.addRoute("mk-ms-layout", {
|
|
69
69
|
name: defaultPageRoute.name,
|
|
70
|
-
path: `/dv/${name}`,
|
|
70
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
71
71
|
component: () => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('../page/index/dv/default/single/table-tree/dialog.vue.js')); }),
|
|
72
72
|
meta: { name }
|
|
73
73
|
});
|
|
@@ -78,7 +78,7 @@ class Router extends utils.Disposable {
|
|
|
78
78
|
case "list":
|
|
79
79
|
vueRouter.addRoute("mk-ms-layout", {
|
|
80
80
|
name: defaultPageRoute.name,
|
|
81
|
-
path: `/dv/${name}`,
|
|
81
|
+
path: defaultPageRoute.route || `/dv/${name}`,
|
|
82
82
|
component: () => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('../page/index/dv/default/table.vue.js')); }),
|
|
83
83
|
meta: { name }
|
|
84
84
|
});
|
|
@@ -86,7 +86,7 @@ class Router extends utils.Disposable {
|
|
|
86
86
|
case "edit":
|
|
87
87
|
vueRouter.addRoute("mk-ms-layout", {
|
|
88
88
|
name: defaultPageRoute.name,
|
|
89
|
-
path: `/dv/${name}/:id`,
|
|
89
|
+
path: defaultPageRoute.route || `/dv/${name}/:id`,
|
|
90
90
|
component: () => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('../page/index/dv/default/edit.vue.js')); }),
|
|
91
91
|
meta: { name }
|
|
92
92
|
});
|
|
@@ -94,7 +94,7 @@ class Router extends utils.Disposable {
|
|
|
94
94
|
case "add":
|
|
95
95
|
vueRouter.addRoute("mk-ms-layout", {
|
|
96
96
|
name: defaultPageRoute.name,
|
|
97
|
-
path: `/dv/${name}/add`,
|
|
97
|
+
path: defaultPageRoute.route || `/dv/${name}/add`,
|
|
98
98
|
component: () => Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespaceDefaultOnly(require('../page/index/dv/default/add.vue.js')); }),
|
|
99
99
|
meta: { name }
|
|
100
100
|
});
|
|
@@ -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 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":";;;;;;AAIA,MAAM,wBAA2B,GAAA,+BAAA,CAAA;AAE1B,MAAM,eAAeA,gBAAW,CAAA;AAAA,EACrC,WAAA,CAAA;AAAA,EAEA,SAAkB,EAAC,CAAA;AAAA,EAEnB,YAAY,WAA0B,EAAA;AACpC,IAAM,KAAA,EAAA,CAAA;AAEN,IAAA,IAAA,CAAK,WAAc,GAAA,WAAA,CAAA;AAAA,GACrB;AAAA,EAEA,UAAU,MAAiB,EAAA;AACzB,IAAA,IAAA,CAAK,MAAS,GAAA,MAAA,CAAA;AAAA,GAChB;AAAA,EAEA,IAAO,GAAA;AACL,IAAM,MAAA,SAAA,GAAY,KAAK,WAAY,CAAA,SAAA,CAAA;AACnC,IAAM,MAAA,SAAA,GAAY,UAAU,SAAU,EAAA,CAAA;AAGtC,IAAM,MAAA,iBAAA,GAAoB,KAAK,MAAO,CAAA,MAAA;AAAA,MACpC,CAAC,KAAU,KAAA,CAAC,SAAU,CAAA,IAAA,CAAK,CAAC,IAAS,KAAA,IAAA,CAAK,IAAS,KAAA,KAAA,CAAM,IAAI,CAAA;AAAA,KAC/D,CAAA;AAEA,IAAA,KAAA,MAAW,oBAAoB,iBAAmB,EAAA;AAChD,MAAA,MAAM,KAAQ,GAAA,gBAAA,CAAiB,IAAK,CAAA,KAAA,CAAM,wBAAwB,CAAA,CAAA;AAElE,MAAA,IAAI,KAAO,EAAA;AACT,QAAM,MAAA,IAAA,GAAO,MAAM,CAAC,CAAA,CAAA;AACpB,QAAM,MAAA,MAAA,GAAS,MAAM,CAAC,CAAA,CAAA;AAEtB,QAAA,QAAQ,MAAQ;AAAA,UACd,KAAK,QAAA;AACH,YAAM,MAAA,CAAC,QAAU,EAAA,IAAI,CAAI,GAAA,KAAA,CAAM,CAAC,CAAA,CAAE,KAAM,CAAA,CAAC,CAAE,CAAA,KAAA,CAAM,GAAG,CAAA,CAAA;AAEpD,YAAA,QAAQ,QAAU;AAAA,cAChB,KAAK,MAAA;AACH,gBAAA,QAAQ,IAAM;AAAA,kBACZ,KAAK,QAAA;AACH,oBAAA,SAAA,CAAU,SAAS,cAAgB,EAAA;AAAA,sBACjC,MAAM,gBAAiB,CAAA,IAAA;AAAA,sBACvB,IAAA,
|
|
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: defaultPageRoute.route || `/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: defaultPageRoute.route || `/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: defaultPageRoute.route || `/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: defaultPageRoute.route || `/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: defaultPageRoute.route || `/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: defaultPageRoute.route || `/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: defaultPageRoute.route || `/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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"}
|
|
@@ -7,7 +7,7 @@ export type RouteResult = {
|
|
|
7
7
|
type: number;
|
|
8
8
|
menuId: string;
|
|
9
9
|
iconName: string;
|
|
10
|
-
|
|
10
|
+
route?: string;
|
|
11
11
|
};
|
|
12
12
|
export type Route = {
|
|
13
13
|
id: string;
|
|
@@ -16,7 +16,7 @@ export type Route = {
|
|
|
16
16
|
type: RouteType;
|
|
17
17
|
menuId: string;
|
|
18
18
|
iconName: string;
|
|
19
|
-
|
|
19
|
+
route: string;
|
|
20
20
|
};
|
|
21
21
|
export declare class RouteForm extends DataForm<RouteResult, Route> {
|
|
22
22
|
constructor(options?: DataFormOptions);
|
|
@@ -30,7 +30,7 @@ class RouteForm extends dm.DataForm {
|
|
|
30
30
|
label: "\u56FE\u6807",
|
|
31
31
|
componentInfo: "MKFormIconSelect"
|
|
32
32
|
}),
|
|
33
|
-
new dm.FormColumn({ name: "
|
|
33
|
+
new dm.FormColumn({ name: "route", label: "\u8DEF\u5F84" }),
|
|
34
34
|
new dm.FormColumn({
|
|
35
35
|
name: "type",
|
|
36
36
|
label: "\u8DEF\u7531\u7C7B\u578B",
|
|
@@ -62,7 +62,7 @@ class RouteForm extends dm.DataForm {
|
|
|
62
62
|
type: `${item.type}` === route.RouteType.ROUTE ? route.RouteType.ROUTE : route.RouteType.LINK,
|
|
63
63
|
menuId: item.menuId,
|
|
64
64
|
iconName: item.iconName || "",
|
|
65
|
-
|
|
65
|
+
route: item.route || ""
|
|
66
66
|
};
|
|
67
67
|
}
|
|
68
68
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RouteForm.js","sources":["../../../../src/dataview/route/RouteForm.ts"],"sourcesContent":["import { DataForm, DataFormOptions, FormColumn } from \"@maketribe/dm\";\nimport { defineDataForm } from \"../../define-data-form\";\nimport { RouteType } from \"../../constants\";\nimport { MenuTable } from \"../menu/MenuTable\";\n\nexport type RouteResult = {\n id: string;\n name: string;\n title: string;\n type: number;\n menuId: string;\n iconName: string;\n
|
|
1
|
+
{"version":3,"file":"RouteForm.js","sources":["../../../../src/dataview/route/RouteForm.ts"],"sourcesContent":["import { DataForm, DataFormOptions, FormColumn } from \"@maketribe/dm\";\nimport { defineDataForm } from \"../../define-data-form\";\nimport { RouteType } from \"../../constants\";\nimport { MenuTable } from \"../menu/MenuTable\";\n\nexport type RouteResult = {\n id: string;\n name: string;\n title: string;\n type: number;\n menuId: string;\n iconName: string;\n route?: string;\n};\n\nexport type Route = {\n id: string;\n name: string;\n title: string;\n type: RouteType;\n menuId: string;\n iconName: string;\n route: string;\n};\n\nexport class RouteForm extends DataForm<RouteResult, Route> {\n constructor(options: DataFormOptions = {}) {\n super({ name: \"ms-route\", ...options });\n }\n\n protected async initialize() {\n await super.initialize();\n\n this.setColumns([\n new FormColumn({ name: \"id\", label: \"编号\" }),\n new FormColumn({ name: \"name\", label: \"路由名\", required: true }),\n new FormColumn({ name: \"title\", label: \"路由描述\", required: true }),\n new FormColumn({\n name: \"menuId\",\n label: \"所属菜单\",\n componentInfo: \"MKFormDataTableSelect\",\n required: true,\n componentProps: {\n labelFieldName: \"title\",\n dataTable: new MenuTable({ pageSize: 10 }),\n },\n }),\n new FormColumn({\n name: \"iconName\",\n label: \"图标\",\n componentInfo: \"MKFormIconSelect\",\n }),\n new FormColumn({ name: \"route\", label: \"路径\" }),\n new FormColumn({\n name: \"type\",\n label: \"路由类型\",\n defaultValue: RouteType.ROUTE,\n componentInfo: \"MKFormDataSelect\",\n required: true,\n componentProps: {\n options: [\n { value: RouteType.ROUTE, label: \"站内路由\" },\n { value: RouteType.LINK, label: \"站外链接\" },\n ],\n },\n }),\n ]);\n }\n\n formatSubmitData(data: any) {\n const type = Number.parseInt(data.type);\n\n return {\n ...data,\n iconName: data.iconName || null,\n type: Number.isNaN(type) ? RouteType.ROUTE : type,\n };\n }\n\n formatItem(item: RouteResult): Route {\n return {\n id: item.id,\n name: item.name || \"\",\n title: item.title || \"\",\n type:\n `${item.type}` === RouteType.ROUTE ? RouteType.ROUTE : RouteType.LINK,\n menuId: item.menuId,\n iconName: item.iconName || \"\",\n route: item.route || \"\",\n };\n }\n}\n\ndefineDataForm(RouteForm);\n"],"names":["DataForm","FormColumn","MenuTable","RouteType","defineDataForm"],"mappings":"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"}
|