@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.
Files changed (79) hide show
  1. package/dist/cjs/components/json-editor/index.js +6 -2
  2. package/dist/cjs/components/json-editor/index.js.map +1 -1
  3. package/dist/cjs/components/json-editor/json-editor.js +2 -2
  4. package/dist/cjs/components/material-select/material-select-type.d.ts +6 -5
  5. package/dist/cjs/components/new-upload-file/MaterialUploadContext.d.ts +4 -0
  6. package/dist/cjs/components/new-upload-file/MaterialUploadContext.js +18 -0
  7. package/dist/cjs/components/new-upload-file/MaterialUploadContext.js.map +1 -0
  8. package/dist/cjs/components/new-upload-file/UploadContext.d.ts +8 -0
  9. package/dist/cjs/components/new-upload-file/UploadContext.js +10 -0
  10. package/dist/cjs/components/new-upload-file/UploadContext.js.map +1 -0
  11. package/dist/cjs/components/new-upload-file/WebFileUploadContext.d.ts +10 -0
  12. package/dist/cjs/components/new-upload-file/WebFileUploadContext.js +50 -0
  13. package/dist/cjs/components/new-upload-file/WebFileUploadContext.js.map +1 -0
  14. package/dist/cjs/components/new-upload-file/upload-file-options.d.ts +17 -0
  15. package/dist/cjs/components/new-upload-file/upload-file-options.js +23 -0
  16. package/dist/cjs/components/new-upload-file/upload-file-options.js.map +1 -0
  17. package/dist/cjs/components/new-upload-file/upload-file.d.ts +40 -0
  18. package/dist/cjs/components/new-upload-file/upload-file.js +49 -0
  19. package/dist/cjs/components/new-upload-file/upload-file.js.map +1 -0
  20. package/dist/cjs/core/PageManager.js +14 -8
  21. package/dist/cjs/core/PageManager.js.map +1 -1
  22. package/dist/cjs/core/Router.js +7 -7
  23. package/dist/cjs/core/Router.js.map +1 -1
  24. package/dist/cjs/dataview/route/RouteForm.d.ts +2 -2
  25. package/dist/cjs/dataview/route/RouteForm.js +2 -2
  26. package/dist/cjs/dataview/route/RouteForm.js.map +1 -1
  27. package/dist/cjs/dataview/route/RouteTable.js +1 -1
  28. package/dist/cjs/dataview/route/RouteTable.js.map +1 -1
  29. package/dist/cjs/init-application.js +1 -1
  30. package/dist/cjs/init-application.js.map +1 -1
  31. package/dist/cjs/router-middleware/auth.js +1 -1
  32. package/dist/cjs/router-middleware/auth.js.map +1 -1
  33. package/dist/esm/components/json-editor/index.js +4 -2
  34. package/dist/esm/components/json-editor/index.js.map +1 -1
  35. package/dist/esm/components/json-editor/json-editor.js +2 -2
  36. package/dist/esm/components/material-select/material-select-type.d.ts +6 -5
  37. package/dist/esm/components/new-upload-file/MaterialUploadContext.d.ts +4 -0
  38. package/dist/esm/components/new-upload-file/MaterialUploadContext.js +16 -0
  39. package/dist/esm/components/new-upload-file/MaterialUploadContext.js.map +1 -0
  40. package/dist/esm/components/new-upload-file/UploadContext.d.ts +8 -0
  41. package/dist/esm/components/new-upload-file/UploadContext.js +8 -0
  42. package/dist/esm/components/new-upload-file/UploadContext.js.map +1 -0
  43. package/dist/esm/components/new-upload-file/WebFileUploadContext.d.ts +10 -0
  44. package/dist/esm/components/new-upload-file/WebFileUploadContext.js +48 -0
  45. package/dist/esm/components/new-upload-file/WebFileUploadContext.js.map +1 -0
  46. package/dist/esm/components/new-upload-file/upload-file-options.d.ts +17 -0
  47. package/dist/esm/components/new-upload-file/upload-file-options.js +20 -0
  48. package/dist/esm/components/new-upload-file/upload-file-options.js.map +1 -0
  49. package/dist/esm/components/new-upload-file/upload-file.d.ts +40 -0
  50. package/dist/esm/components/new-upload-file/upload-file.js +47 -0
  51. package/dist/esm/components/new-upload-file/upload-file.js.map +1 -0
  52. package/dist/esm/core/PageManager.js +14 -8
  53. package/dist/esm/core/PageManager.js.map +1 -1
  54. package/dist/esm/core/Router.js +7 -7
  55. package/dist/esm/core/Router.js.map +1 -1
  56. package/dist/esm/dataview/route/RouteForm.d.ts +2 -2
  57. package/dist/esm/dataview/route/RouteForm.js +2 -2
  58. package/dist/esm/dataview/route/RouteForm.js.map +1 -1
  59. package/dist/esm/dataview/route/RouteTable.js +1 -1
  60. package/dist/esm/dataview/route/RouteTable.js.map +1 -1
  61. package/dist/esm/init-application.js +1 -1
  62. package/dist/esm/init-application.js.map +1 -1
  63. package/dist/esm/node_modules/.pnpm/@codemirror_language@6.9.3/node_modules/@codemirror/language/dist/index.js +2 -2
  64. package/dist/esm/router-middleware/auth.js +1 -1
  65. package/dist/esm/router-middleware/auth.js.map +1 -1
  66. package/package.json +2 -2
  67. package/src/components/json-editor/index.ts +4 -2
  68. package/src/components/material-select/material-select-type.ts +10 -5
  69. package/src/components/new-upload-file/MaterialUploadContext.ts +14 -0
  70. package/src/components/new-upload-file/UploadContext.ts +11 -0
  71. package/src/components/new-upload-file/WebFileUploadContext.ts +58 -0
  72. package/src/components/new-upload-file/upload-file-options.ts +23 -0
  73. package/src/components/new-upload-file/upload-file.tsx +61 -0
  74. package/src/core/PageManager.ts +18 -9
  75. package/src/core/Router.ts +7 -7
  76. package/src/dataview/route/RouteForm.ts +4 -4
  77. package/src/dataview/route/RouteTable.ts +1 -1
  78. package/src/init-application.ts +1 -1
  79. package/src/router-middleware/auth.ts +1 -2
@@ -1 +1 @@
1
- {"version":3,"file":"RouteTable.js","sources":["../../../../src/dataview/route/RouteTable.ts"],"sourcesContent":["import {\n DataTable,\n DataTableOptions,\n TableColumn,\n FilterColumn,\n TableActionColumn,\n} from \"@maketribe/dm\";\nimport { defineDataTable } from \"../../define-data-table\";\nimport { Route, RouteResult } from \"./RouteForm\";\nimport { RouteType } from \"../../constants\";\n\nexport class RouteTable extends DataTable<RouteResult, Route> {\n constructor(options: DataTableOptions = {}) {\n super({ name: \"ms-route\", ...options });\n }\n\n protected async initialize() {\n await super.initialize();\n\n this.dataFilter.setColumns([\n new FilterColumn({\n name: \"name\",\n label: \"路由名\",\n componentInfo: \"MKConditionInput\",\n }),\n new FilterColumn({\n name: \"title\",\n label: \"路由描述\",\n componentInfo: \"MKConditionInput\",\n }),\n new FilterColumn({\n name: \"type\",\n label: \"路由类型\",\n componentInfo: \"MKConditionSelect\",\n componentProps: {\n options: [\n { value: 0, label: \"站内路由\" },\n { value: 1, label: \"站外链接\" },\n ],\n },\n }),\n ]);\n\n this.setColumns([\n new TableColumn({ name: \"id\", label: \"编号\", visible: false }),\n new TableColumn({ name: \"name\", label: \"路由名\" }),\n new TableColumn({ name: \"title\", label: \"路由描述\" }),\n new TableColumn({\n name: \"type\",\n label: \"路由类型\",\n componentInfo: \"MKColumnObjectMappingText\",\n componentProps: {\n mapping: { 0: \"站内路由\", 1: \"站外链接\" },\n },\n }),\n new TableActionColumn(),\n ]);\n }\n\n formatItem(item: RouteResult): Route {\n return {\n id: item.id,\n name: item.name || \"\",\n title: item.title || \"\",\n type: item.type === 0 ? RouteType.ROUTE : RouteType.LINK,\n menuId: item.menuId,\n iconName: item.iconName || \"\",\n path: item.path || \"\",\n };\n }\n}\n\ndefineDataTable(RouteTable);\n"],"names":["DataTable","FilterColumn","TableColumn","TableActionColumn","RouteType","defineDataTable"],"mappings":";;;;;;AAWO,MAAM,mBAAmBA,YAA8B,CAAA;AAAA,EAC5D,WAAA,CAAY,OAA4B,GAAA,EAAI,EAAA;AAC1C,IAAA,KAAA,CAAM,EAAE,IAAA,EAAM,UAAY,EAAA,GAAG,SAAS,CAAA,CAAA;AAAA,GACxC;AAAA,EAEA,MAAgB,UAAa,GAAA;AAC3B,IAAA,MAAM,MAAM,UAAW,EAAA,CAAA;AAEvB,IAAA,IAAA,CAAK,WAAW,UAAW,CAAA;AAAA,MACzB,IAAIC,eAAa,CAAA;AAAA,QACf,IAAM,EAAA,MAAA;AAAA,QACN,KAAO,EAAA,oBAAA;AAAA,QACP,aAAe,EAAA,kBAAA;AAAA,OAChB,CAAA;AAAA,MACD,IAAIA,eAAa,CAAA;AAAA,QACf,IAAM,EAAA,OAAA;AAAA,QACN,KAAO,EAAA,0BAAA;AAAA,QACP,aAAe,EAAA,kBAAA;AAAA,OAChB,CAAA;AAAA,MACD,IAAIA,eAAa,CAAA;AAAA,QACf,IAAM,EAAA,MAAA;AAAA,QACN,KAAO,EAAA,0BAAA;AAAA,QACP,aAAe,EAAA,mBAAA;AAAA,QACf,cAAgB,EAAA;AAAA,UACd,OAAS,EAAA;AAAA,YACP,EAAE,KAAA,EAAO,CAAG,EAAA,KAAA,EAAO,0BAAO,EAAA;AAAA,YAC1B,EAAE,KAAA,EAAO,CAAG,EAAA,KAAA,EAAO,0BAAO,EAAA;AAAA,WAC5B;AAAA,SACF;AAAA,OACD,CAAA;AAAA,KACF,CAAA,CAAA;AAED,IAAA,IAAA,CAAK,UAAW,CAAA;AAAA,MACd,IAAIC,eAAY,EAAE,IAAA,EAAM,MAAM,KAAO,EAAA,cAAA,EAAM,OAAS,EAAA,KAAA,EAAO,CAAA;AAAA,MAC3D,IAAIA,cAAY,CAAA,EAAE,MAAM,MAAQ,EAAA,KAAA,EAAO,sBAAO,CAAA;AAAA,MAC9C,IAAIA,cAAY,CAAA,EAAE,MAAM,OAAS,EAAA,KAAA,EAAO,4BAAQ,CAAA;AAAA,MAChD,IAAIA,cAAY,CAAA;AAAA,QACd,IAAM,EAAA,MAAA;AAAA,QACN,KAAO,EAAA,0BAAA;AAAA,QACP,aAAe,EAAA,2BAAA;AAAA,QACf,cAAgB,EAAA;AAAA,UACd,OAAS,EAAA,EAAE,CAAG,EAAA,0BAAA,EAAQ,GAAG,0BAAO,EAAA;AAAA,SAClC;AAAA,OACD,CAAA;AAAA,MACD,IAAIC,oBAAkB,EAAA;AAAA,KACvB,CAAA,CAAA;AAAA,GACH;AAAA,EAEA,WAAW,IAA0B,EAAA;AACnC,IAAO,OAAA;AAAA,MACL,IAAI,IAAK,CAAA,EAAA;AAAA,MACT,IAAA,EAAM,KAAK,IAAQ,IAAA,EAAA;AAAA,MACnB,KAAA,EAAO,KAAK,KAAS,IAAA,EAAA;AAAA,MACrB,MAAM,IAAK,CAAA,IAAA,KAAS,CAAI,GAAAC,eAAA,CAAU,QAAQA,eAAU,CAAA,IAAA;AAAA,MACpD,QAAQ,IAAK,CAAA,MAAA;AAAA,MACb,QAAA,EAAU,KAAK,QAAY,IAAA,EAAA;AAAA,MAC3B,IAAA,EAAM,KAAK,IAAQ,IAAA,EAAA;AAAA,KACrB,CAAA;AAAA,GACF;AACF,CAAA;AAEAC,+BAAA,CAAgB,UAAU,CAAA;;;;"}
1
+ {"version":3,"file":"RouteTable.js","sources":["../../../../src/dataview/route/RouteTable.ts"],"sourcesContent":["import {\n DataTable,\n DataTableOptions,\n TableColumn,\n FilterColumn,\n TableActionColumn,\n} from \"@maketribe/dm\";\nimport { defineDataTable } from \"../../define-data-table\";\nimport { Route, RouteResult } from \"./RouteForm\";\nimport { RouteType } from \"../../constants\";\n\nexport class RouteTable extends DataTable<RouteResult, Route> {\n constructor(options: DataTableOptions = {}) {\n super({ name: \"ms-route\", ...options });\n }\n\n protected async initialize() {\n await super.initialize();\n\n this.dataFilter.setColumns([\n new FilterColumn({\n name: \"name\",\n label: \"路由名\",\n componentInfo: \"MKConditionInput\",\n }),\n new FilterColumn({\n name: \"title\",\n label: \"路由描述\",\n componentInfo: \"MKConditionInput\",\n }),\n new FilterColumn({\n name: \"type\",\n label: \"路由类型\",\n componentInfo: \"MKConditionSelect\",\n componentProps: {\n options: [\n { value: 0, label: \"站内路由\" },\n { value: 1, label: \"站外链接\" },\n ],\n },\n }),\n ]);\n\n this.setColumns([\n new TableColumn({ name: \"id\", label: \"编号\", visible: false }),\n new TableColumn({ name: \"name\", label: \"路由名\" }),\n new TableColumn({ name: \"title\", label: \"路由描述\" }),\n new TableColumn({\n name: \"type\",\n label: \"路由类型\",\n componentInfo: \"MKColumnObjectMappingText\",\n componentProps: {\n mapping: { 0: \"站内路由\", 1: \"站外链接\" },\n },\n }),\n new TableActionColumn(),\n ]);\n }\n\n formatItem(item: RouteResult): Route {\n return {\n id: item.id,\n name: item.name || \"\",\n title: item.title || \"\",\n type: item.type === 0 ? RouteType.ROUTE : RouteType.LINK,\n menuId: item.menuId,\n iconName: item.iconName || \"\",\n route: item.route || \"\",\n };\n }\n}\n\ndefineDataTable(RouteTable);\n"],"names":["DataTable","FilterColumn","TableColumn","TableActionColumn","RouteType","defineDataTable"],"mappings":";;;;;;AAWO,MAAM,mBAAmBA,YAA8B,CAAA;AAAA,EAC5D,WAAA,CAAY,OAA4B,GAAA,EAAI,EAAA;AAC1C,IAAA,KAAA,CAAM,EAAE,IAAA,EAAM,UAAY,EAAA,GAAG,SAAS,CAAA,CAAA;AAAA,GACxC;AAAA,EAEA,MAAgB,UAAa,GAAA;AAC3B,IAAA,MAAM,MAAM,UAAW,EAAA,CAAA;AAEvB,IAAA,IAAA,CAAK,WAAW,UAAW,CAAA;AAAA,MACzB,IAAIC,eAAa,CAAA;AAAA,QACf,IAAM,EAAA,MAAA;AAAA,QACN,KAAO,EAAA,oBAAA;AAAA,QACP,aAAe,EAAA,kBAAA;AAAA,OAChB,CAAA;AAAA,MACD,IAAIA,eAAa,CAAA;AAAA,QACf,IAAM,EAAA,OAAA;AAAA,QACN,KAAO,EAAA,0BAAA;AAAA,QACP,aAAe,EAAA,kBAAA;AAAA,OAChB,CAAA;AAAA,MACD,IAAIA,eAAa,CAAA;AAAA,QACf,IAAM,EAAA,MAAA;AAAA,QACN,KAAO,EAAA,0BAAA;AAAA,QACP,aAAe,EAAA,mBAAA;AAAA,QACf,cAAgB,EAAA;AAAA,UACd,OAAS,EAAA;AAAA,YACP,EAAE,KAAA,EAAO,CAAG,EAAA,KAAA,EAAO,0BAAO,EAAA;AAAA,YAC1B,EAAE,KAAA,EAAO,CAAG,EAAA,KAAA,EAAO,0BAAO,EAAA;AAAA,WAC5B;AAAA,SACF;AAAA,OACD,CAAA;AAAA,KACF,CAAA,CAAA;AAED,IAAA,IAAA,CAAK,UAAW,CAAA;AAAA,MACd,IAAIC,eAAY,EAAE,IAAA,EAAM,MAAM,KAAO,EAAA,cAAA,EAAM,OAAS,EAAA,KAAA,EAAO,CAAA;AAAA,MAC3D,IAAIA,cAAY,CAAA,EAAE,MAAM,MAAQ,EAAA,KAAA,EAAO,sBAAO,CAAA;AAAA,MAC9C,IAAIA,cAAY,CAAA,EAAE,MAAM,OAAS,EAAA,KAAA,EAAO,4BAAQ,CAAA;AAAA,MAChD,IAAIA,cAAY,CAAA;AAAA,QACd,IAAM,EAAA,MAAA;AAAA,QACN,KAAO,EAAA,0BAAA;AAAA,QACP,aAAe,EAAA,2BAAA;AAAA,QACf,cAAgB,EAAA;AAAA,UACd,OAAS,EAAA,EAAE,CAAG,EAAA,0BAAA,EAAQ,GAAG,0BAAO,EAAA;AAAA,SAClC;AAAA,OACD,CAAA;AAAA,MACD,IAAIC,oBAAkB,EAAA;AAAA,KACvB,CAAA,CAAA;AAAA,GACH;AAAA,EAEA,WAAW,IAA0B,EAAA;AACnC,IAAO,OAAA;AAAA,MACL,IAAI,IAAK,CAAA,EAAA;AAAA,MACT,IAAA,EAAM,KAAK,IAAQ,IAAA,EAAA;AAAA,MACnB,KAAA,EAAO,KAAK,KAAS,IAAA,EAAA;AAAA,MACrB,MAAM,IAAK,CAAA,IAAA,KAAS,CAAI,GAAAC,eAAA,CAAU,QAAQA,eAAU,CAAA,IAAA;AAAA,MACpD,QAAQ,IAAK,CAAA,MAAA;AAAA,MACb,QAAA,EAAU,KAAK,QAAY,IAAA,EAAA;AAAA,MAC3B,KAAA,EAAO,KAAK,KAAS,IAAA,EAAA;AAAA,KACvB,CAAA;AAAA,GACF;AACF,CAAA;AAEAC,+BAAA,CAAgB,UAAU,CAAA;;;;"}
@@ -47,7 +47,7 @@ const initApplication = async (options) => {
47
47
  })
48
48
  );
49
49
  for (const route of routes) {
50
- if (route.key.startsWith("index-")) {
50
+ if (route.key.startsWith("index")) {
51
51
  msAppClient$1.pageManager.addExtendsPage(route);
52
52
  } else {
53
53
  msAppClient$1.pageManager.addNormalPage(route);
@@ -1 +1 @@
1
- {"version":3,"file":"init-application.js","sources":["../../src/init-application.ts"],"sourcesContent":["import { App, reactive } from \"vue\";\nimport {\n createRouter,\n createWebHashHistory,\n Router as VueRouter,\n} from \"vue-router\";\nimport { MSAppClient } from \"./core\";\nimport { HttpRequest, WebHttpRequest } from \"@maketribe/request\";\nimport { MSAPPCLIENT_CONTEXT_KEY } from \"./tokens\";\n\nimport { generateRoutesFromFiles } from \"./utils\";\nimport {\n DataFilterComponents,\n DataFormComponents,\n DataTableComponents,\n} from \"./core\";\n\nexport type InitMsApplicationOptions = {\n routes: any;\n vueRouter?: VueRouter;\n app: App;\n appID: string;\n logo?: string;\n projectName: string;\n locale?: string;\n httpRequest?: HttpRequest;\n};\n\nexport const initApplication = async (options: InitMsApplicationOptions) => {\n const app = options.app;\n\n const vueRouter =\n options.vueRouter ??\n createRouter({\n history: createWebHashHistory(),\n routes: [],\n });\n\n const msAppClient = reactive(\n new MSAppClient({\n appID: options!.appID,\n logo: options!.logo ?? \"\",\n projectName: options!.projectName,\n httpRequest: options.httpRequest ?? new WebHttpRequest(),\n origin: location.origin,\n locale: options!.locale,\n vueRouter,\n dataTableComponents: new DataTableComponents(),\n dataFormComponents: new DataFormComponents(),\n dataFilterComponents: new DataFilterComponents(),\n whereFilterComponents: new DataFilterComponents(),\n })\n ) as unknown as MSAppClient;\n\n app.provide(MSAPPCLIENT_CONTEXT_KEY, { msAppClient });\n\n MSAppClient.instance = msAppClient;\n\n (window as any).msAppClient = msAppClient;\n\n const routes = generateRoutesFromFiles(\n Object.keys(options.routes).map((key) => {\n return {\n path: key.replace(/^\\.\\/pages\\/(.+)\\.vue$/, (_, g) => g),\n module: options.routes[key]?.default || options.routes[key],\n };\n })\n );\n\n for (const route of routes) {\n if (route.key.startsWith(\"index-\")) {\n msAppClient.pageManager.addExtendsPage(route);\n } else {\n msAppClient.pageManager.addNormalPage(route);\n }\n }\n\n await msAppClient.init();\n\n app.use(msAppClient.vueRouter);\n\n return msAppClient;\n};\n"],"names":["vueRouter","createRouter","createWebHashHistory","msAppClient","reactive","MSAppClient","WebHttpRequest","DataTableComponents","DataFormComponents","DataFilterComponents","MSAPPCLIENT_CONTEXT_KEY","generateRoutesFromFiles"],"mappings":";;;;;;;;;;;;;;;;AA4Ba,MAAA,eAAA,GAAkB,OAAO,OAAsC,KAAA;AAC1E,EAAA,MAAM,MAAM,OAAQ,CAAA,GAAA,CAAA;AAEpB,EAAM,MAAAA,WAAA,GACJ,OAAQ,CAAA,SAAA,IACRC,sBAAa,CAAA;AAAA,IACX,SAASC,8BAAqB,EAAA;AAAA,IAC9B,QAAQ,EAAC;AAAA,GACV,CAAA,CAAA;AAEH,EAAA,MAAMC,aAAc,GAAAC,YAAA;AAAA,IAClB,IAAIC,uBAAY,CAAA;AAAA,MACd,OAAO,OAAS,CAAA,KAAA;AAAA,MAChB,IAAA,EAAM,QAAS,IAAQ,IAAA,EAAA;AAAA,MACvB,aAAa,OAAS,CAAA,WAAA;AAAA,MACtB,WAAa,EAAA,OAAA,CAAQ,WAAe,IAAA,IAAIC,sBAAe,EAAA;AAAA,MACvD,QAAQ,QAAS,CAAA,MAAA;AAAA,MACjB,QAAQ,OAAS,CAAA,MAAA;AAAA,iBACjBN,WAAA;AAAA,MACA,mBAAA,EAAqB,IAAIO,uCAAoB,EAAA;AAAA,MAC7C,kBAAA,EAAoB,IAAIC,qCAAmB,EAAA;AAAA,MAC3C,oBAAA,EAAsB,IAAIC,yCAAqB,EAAA;AAAA,MAC/C,qBAAA,EAAuB,IAAIA,yCAAqB,EAAA;AAAA,KACjD,CAAA;AAAA,GACH,CAAA;AAEA,EAAA,GAAA,CAAI,OAAQ,CAAAC,mCAAA,EAAyB,eAAEP,aAAA,EAAa,CAAA,CAAA;AAEpD,EAAAE,uBAAA,CAAY,QAAW,GAAAF,aAAA,CAAA;AAEvB,EAAC,OAAe,WAAc,GAAAA,aAAA,CAAA;AAE9B,EAAA,MAAM,MAAS,GAAAQ,6BAAA;AAAA,IACb,OAAO,IAAK,CAAA,OAAA,CAAQ,MAAM,CAAE,CAAA,GAAA,CAAI,CAAC,GAAQ,KAAA;AACvC,MAAO,OAAA;AAAA,QACL,MAAM,GAAI,CAAA,OAAA,CAAQ,0BAA0B,CAAC,CAAA,EAAG,MAAM,CAAC,CAAA;AAAA,QACvD,MAAA,EAAQ,QAAQ,MAAO,CAAA,GAAG,GAAG,OAAW,IAAA,OAAA,CAAQ,OAAO,GAAG,CAAA;AAAA,OAC5D,CAAA;AAAA,KACD,CAAA;AAAA,GACH,CAAA;AAEA,EAAA,KAAA,MAAW,SAAS,MAAQ,EAAA;AAC1B,IAAA,IAAI,KAAM,CAAA,GAAA,CAAI,UAAW,CAAA,QAAQ,CAAG,EAAA;AAClC,MAAYR,aAAA,CAAA,WAAA,CAAY,eAAe,KAAK,CAAA,CAAA;AAAA,KACvC,MAAA;AACL,MAAYA,aAAA,CAAA,WAAA,CAAY,cAAc,KAAK,CAAA,CAAA;AAAA,KAC7C;AAAA,GACF;AAEA,EAAA,MAAMA,cAAY,IAAK,EAAA,CAAA;AAEvB,EAAI,GAAA,CAAA,GAAA,CAAIA,cAAY,SAAS,CAAA,CAAA;AAE7B,EAAO,OAAAA,aAAA,CAAA;AACT;;;;"}
1
+ {"version":3,"file":"init-application.js","sources":["../../src/init-application.ts"],"sourcesContent":["import { App, reactive } from \"vue\";\nimport {\n createRouter,\n createWebHashHistory,\n Router as VueRouter,\n} from \"vue-router\";\nimport { MSAppClient } from \"./core\";\nimport { HttpRequest, WebHttpRequest } from \"@maketribe/request\";\nimport { MSAPPCLIENT_CONTEXT_KEY } from \"./tokens\";\n\nimport { generateRoutesFromFiles } from \"./utils\";\nimport {\n DataFilterComponents,\n DataFormComponents,\n DataTableComponents,\n} from \"./core\";\n\nexport type InitMsApplicationOptions = {\n routes: any;\n vueRouter?: VueRouter;\n app: App;\n appID: string;\n logo?: string;\n projectName: string;\n locale?: string;\n httpRequest?: HttpRequest;\n};\n\nexport const initApplication = async (options: InitMsApplicationOptions) => {\n const app = options.app;\n\n const vueRouter =\n options.vueRouter ??\n createRouter({\n history: createWebHashHistory(),\n routes: [],\n });\n\n const msAppClient = reactive(\n new MSAppClient({\n appID: options!.appID,\n logo: options!.logo ?? \"\",\n projectName: options!.projectName,\n httpRequest: options.httpRequest ?? new WebHttpRequest(),\n origin: location.origin,\n locale: options!.locale,\n vueRouter,\n dataTableComponents: new DataTableComponents(),\n dataFormComponents: new DataFormComponents(),\n dataFilterComponents: new DataFilterComponents(),\n whereFilterComponents: new DataFilterComponents(),\n })\n ) as unknown as MSAppClient;\n\n app.provide(MSAPPCLIENT_CONTEXT_KEY, { msAppClient });\n\n MSAppClient.instance = msAppClient;\n\n (window as any).msAppClient = msAppClient;\n\n const routes = generateRoutesFromFiles(\n Object.keys(options.routes).map((key) => {\n return {\n path: key.replace(/^\\.\\/pages\\/(.+)\\.vue$/, (_, g) => g),\n module: options.routes[key]?.default || options.routes[key],\n };\n })\n );\n\n for (const route of routes) {\n if (route.key.startsWith(\"index\")) {\n msAppClient.pageManager.addExtendsPage(route);\n } else {\n msAppClient.pageManager.addNormalPage(route);\n }\n }\n\n await msAppClient.init();\n\n app.use(msAppClient.vueRouter);\n\n return msAppClient;\n};\n"],"names":["vueRouter","createRouter","createWebHashHistory","msAppClient","reactive","MSAppClient","WebHttpRequest","DataTableComponents","DataFormComponents","DataFilterComponents","MSAPPCLIENT_CONTEXT_KEY","generateRoutesFromFiles"],"mappings":";;;;;;;;;;;;;;;;AA4Ba,MAAA,eAAA,GAAkB,OAAO,OAAsC,KAAA;AAC1E,EAAA,MAAM,MAAM,OAAQ,CAAA,GAAA,CAAA;AAEpB,EAAM,MAAAA,WAAA,GACJ,OAAQ,CAAA,SAAA,IACRC,sBAAa,CAAA;AAAA,IACX,SAASC,8BAAqB,EAAA;AAAA,IAC9B,QAAQ,EAAC;AAAA,GACV,CAAA,CAAA;AAEH,EAAA,MAAMC,aAAc,GAAAC,YAAA;AAAA,IAClB,IAAIC,uBAAY,CAAA;AAAA,MACd,OAAO,OAAS,CAAA,KAAA;AAAA,MAChB,IAAA,EAAM,QAAS,IAAQ,IAAA,EAAA;AAAA,MACvB,aAAa,OAAS,CAAA,WAAA;AAAA,MACtB,WAAa,EAAA,OAAA,CAAQ,WAAe,IAAA,IAAIC,sBAAe,EAAA;AAAA,MACvD,QAAQ,QAAS,CAAA,MAAA;AAAA,MACjB,QAAQ,OAAS,CAAA,MAAA;AAAA,iBACjBN,WAAA;AAAA,MACA,mBAAA,EAAqB,IAAIO,uCAAoB,EAAA;AAAA,MAC7C,kBAAA,EAAoB,IAAIC,qCAAmB,EAAA;AAAA,MAC3C,oBAAA,EAAsB,IAAIC,yCAAqB,EAAA;AAAA,MAC/C,qBAAA,EAAuB,IAAIA,yCAAqB,EAAA;AAAA,KACjD,CAAA;AAAA,GACH,CAAA;AAEA,EAAA,GAAA,CAAI,OAAQ,CAAAC,mCAAA,EAAyB,eAAEP,aAAA,EAAa,CAAA,CAAA;AAEpD,EAAAE,uBAAA,CAAY,QAAW,GAAAF,aAAA,CAAA;AAEvB,EAAC,OAAe,WAAc,GAAAA,aAAA,CAAA;AAE9B,EAAA,MAAM,MAAS,GAAAQ,6BAAA;AAAA,IACb,OAAO,IAAK,CAAA,OAAA,CAAQ,MAAM,CAAE,CAAA,GAAA,CAAI,CAAC,GAAQ,KAAA;AACvC,MAAO,OAAA;AAAA,QACL,MAAM,GAAI,CAAA,OAAA,CAAQ,0BAA0B,CAAC,CAAA,EAAG,MAAM,CAAC,CAAA;AAAA,QACvD,MAAA,EAAQ,QAAQ,MAAO,CAAA,GAAG,GAAG,OAAW,IAAA,OAAA,CAAQ,OAAO,GAAG,CAAA;AAAA,OAC5D,CAAA;AAAA,KACD,CAAA;AAAA,GACH,CAAA;AAEA,EAAA,KAAA,MAAW,SAAS,MAAQ,EAAA;AAC1B,IAAA,IAAI,KAAM,CAAA,GAAA,CAAI,UAAW,CAAA,OAAO,CAAG,EAAA;AACjC,MAAYR,aAAA,CAAA,WAAA,CAAY,eAAe,KAAK,CAAA,CAAA;AAAA,KACvC,MAAA;AACL,MAAYA,aAAA,CAAA,WAAA,CAAY,cAAc,KAAK,CAAA,CAAA;AAAA,KAC7C;AAAA,GACF;AAEA,EAAA,MAAMA,cAAY,IAAK,EAAA,CAAA;AAEvB,EAAI,GAAA,CAAA,GAAA,CAAIA,cAAY,SAAS,CAAA,CAAA;AAE7B,EAAO,OAAAA,aAAA,CAAA;AACT;;;;"}
@@ -12,7 +12,7 @@ const authBeforeEach = async (msAppClient, to, from) => {
12
12
  if (!userSession) {
13
13
  return { name: "login" };
14
14
  }
15
- return { ...to };
15
+ return { path: to.fullPath };
16
16
  } catch (e) {
17
17
  return { name: "login" };
18
18
  }
@@ -1 +1 @@
1
- {"version":3,"file":"auth.js","sources":["../../../src/router-middleware/auth.ts"],"sourcesContent":["import { RouteLocationNormalized, RouteLocationRaw } from \"vue-router\";\nimport { isSameRoute } from \"@maketribe/utils\";\nimport type { MSAppClient } from \"../core\";\n\nexport const authBeforeEach = async (\n msAppClient: MSAppClient,\n to: RouteLocationNormalized,\n from: RouteLocationNormalized\n): Promise<RouteLocationRaw | void> => {\n if (to.meta.isAuthorization === false) {\n return;\n }\n\n let userSession = msAppClient.userSession;\n\n if (!userSession) {\n try {\n await msAppClient.loadCurrentUserSession();\n\n userSession = msAppClient.userSession;\n\n if (!userSession) {\n return { name: \"login\" };\n }\n\n // 因为登陆成功会添加用户可以访问的路由,这里给到vue-router去重新resolve\n return { ...to };\n } catch (e) {\n return { name: \"login\" };\n }\n }\n};\n"],"names":[],"mappings":";;AAIO,MAAM,cAAiB,GAAA,OAC5B,WACA,EAAA,EAAA,EACA,IACqC,KAAA;AACrC,EAAI,IAAA,EAAA,CAAG,IAAK,CAAA,eAAA,KAAoB,KAAO,EAAA;AACrC,IAAA,OAAA;AAAA,GACF;AAEA,EAAA,IAAI,cAAc,WAAY,CAAA,WAAA,CAAA;AAE9B,EAAA,IAAI,CAAC,WAAa,EAAA;AAChB,IAAI,IAAA;AACF,MAAA,MAAM,YAAY,sBAAuB,EAAA,CAAA;AAEzC,MAAA,WAAA,GAAc,WAAY,CAAA,WAAA,CAAA;AAE1B,MAAA,IAAI,CAAC,WAAa,EAAA;AAChB,QAAO,OAAA,EAAE,MAAM,OAAQ,EAAA,CAAA;AAAA,OACzB;AAGA,MAAO,OAAA,EAAE,GAAG,EAAG,EAAA,CAAA;AAAA,aACR,CAAG,EAAA;AACV,MAAO,OAAA,EAAE,MAAM,OAAQ,EAAA,CAAA;AAAA,KACzB;AAAA,GACF;AACF;;;;"}
1
+ {"version":3,"file":"auth.js","sources":["../../../src/router-middleware/auth.ts"],"sourcesContent":["import { RouteLocationNormalized, RouteLocationRaw } from \"vue-router\";\nimport type { MSAppClient } from \"../core\";\n\nexport const authBeforeEach = async (\n msAppClient: MSAppClient,\n to: RouteLocationNormalized,\n from: RouteLocationNormalized\n): Promise<RouteLocationRaw | void> => {\n if (to.meta.isAuthorization === false) {\n return;\n }\n\n let userSession = msAppClient.userSession;\n\n if (!userSession) {\n try {\n await msAppClient.loadCurrentUserSession();\n\n userSession = msAppClient.userSession;\n\n if (!userSession) {\n return { name: \"login\" };\n }\n\n // 因为登陆成功会添加用户可以访问的路由,这里给到vue-router去重新resolve\n return { path: to.fullPath };\n } catch (e) {\n return { name: \"login\" };\n }\n }\n};\n"],"names":[],"mappings":";;AAGO,MAAM,cAAiB,GAAA,OAC5B,WACA,EAAA,EAAA,EACA,IACqC,KAAA;AACrC,EAAI,IAAA,EAAA,CAAG,IAAK,CAAA,eAAA,KAAoB,KAAO,EAAA;AACrC,IAAA,OAAA;AAAA,GACF;AAEA,EAAA,IAAI,cAAc,WAAY,CAAA,WAAA,CAAA;AAE9B,EAAA,IAAI,CAAC,WAAa,EAAA;AAChB,IAAI,IAAA;AACF,MAAA,MAAM,YAAY,sBAAuB,EAAA,CAAA;AAEzC,MAAA,WAAA,GAAc,WAAY,CAAA,WAAA,CAAA;AAE1B,MAAA,IAAI,CAAC,WAAa,EAAA;AAChB,QAAO,OAAA,EAAE,MAAM,OAAQ,EAAA,CAAA;AAAA,OACzB;AAGA,MAAO,OAAA,EAAE,IAAM,EAAA,EAAA,CAAG,QAAS,EAAA,CAAA;AAAA,aACpB,CAAG,EAAA;AACV,MAAO,OAAA,EAAE,MAAM,OAAQ,EAAA,CAAA;AAAA,KACzB;AAAA,GACF;AACF;;;;"}
@@ -1,7 +1,9 @@
1
+ import { defineAsyncComponent } from 'vue';
1
2
  import { withInstall } from '@maketribe/utils';
2
- import JsonEditor from './json-editor.js';
3
3
 
4
- const MKJsonEditor = withInstall(JsonEditor);
4
+ const MKJsonEditor = withInstall(
5
+ defineAsyncComponent(() => import('./json-editor.js'))
6
+ );
5
7
 
6
8
  export { MKJsonEditor, MKJsonEditor as default };
7
9
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/json-editor/index.ts"],"sourcesContent":["import { withInstall } from \"@maketribe/utils\";\nimport JsonEditor from \"./json-editor\";\n\nexport const MKJsonEditor = withInstall(JsonEditor);\n\nexport default MKJsonEditor;\n"],"names":[],"mappings":";;;AAGa,MAAA,YAAA,GAAe,YAAY,UAAU;;;;"}
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":[],"mappings":";;;AAGO,MAAM,YAAe,GAAA,WAAA;AAAA,EAC1B,oBAAqB,CAAA,MAAM,OAAO,kBAAe,CAAC,CAAA;AACpD;;;;"}
@@ -3,7 +3,7 @@ import { Codemirror as T } from '../../node_modules/.pnpm/vue-codemirror@6.1.1_c
3
3
  import { json } from '../../node_modules/.pnpm/@codemirror_lang-json@6.0.1/node_modules/@codemirror/lang-json/dist/index.js';
4
4
  import { jsonEditorProps, jsonEditorEmits } from './json-editor-options.js';
5
5
 
6
- var JsonEditor = /* @__PURE__ */ defineComponent({
6
+ var jsonEditor = /* @__PURE__ */ defineComponent({
7
7
  name: "MKCodeMirror",
8
8
  props: jsonEditorProps,
9
9
  emits: jsonEditorEmits,
@@ -25,5 +25,5 @@ var JsonEditor = /* @__PURE__ */ defineComponent({
25
25
  }
26
26
  });
27
27
 
28
- export { JsonEditor as default };
28
+ export { jsonEditor as default };
29
29
  //# 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,4 @@
1
+ import { UploadContext, UploadResult } from "./UploadContext";
2
+ export declare class MaterialUploadContext extends UploadContext {
3
+ selectFile(): Promise<UploadResult>;
4
+ }
@@ -0,0 +1,16 @@
1
+ import { MKMaterialSelect } from '../material-select/index.js';
2
+ import { UploadContext } from './UploadContext.js';
3
+
4
+ class MaterialUploadContext extends UploadContext {
5
+ async selectFile() {
6
+ const materialSelectResult = await MKMaterialSelect();
7
+ return {
8
+ success: materialSelectResult.success,
9
+ path: materialSelectResult.path,
10
+ msg: ""
11
+ };
12
+ }
13
+ }
14
+
15
+ export { MaterialUploadContext };
16
+ //# 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":[],"mappings":";;;AAGO,MAAM,8BAA8B,aAAc,CAAA;AAAA,EACvD,MAAM,UAAoC,GAAA;AACxC,IAAM,MAAA,oBAAA,GAAuB,MAAM,gBAAiB,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,8 @@
1
+ export type UploadResult = {
2
+ success: boolean;
3
+ path: string;
4
+ msg: string;
5
+ };
6
+ export declare class UploadContext {
7
+ selectFile(): Promise<UploadResult>;
8
+ }
@@ -0,0 +1,8 @@
1
+ class UploadContext {
2
+ selectFile() {
3
+ throw new Error();
4
+ }
5
+ }
6
+
7
+ export { UploadContext };
8
+ //# sourceMappingURL=UploadContext.js.map
@@ -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,48 @@
1
+ import { WebFileUpload } from '@maketribe/request';
2
+ import { UploadContext } from './UploadContext.js';
3
+ import 'vue';
4
+ import '@maketribe/dm';
5
+ import 'element-plus';
6
+ import '@maketribe/utils';
7
+ import '../../core/DataModelDefines.js';
8
+ import { MSAppClient } from '../../core/MSAppClient.js';
9
+
10
+ class WebFileUploadContext extends UploadContext {
11
+ webFileUpload;
12
+ constructor(options = {}) {
13
+ super();
14
+ this.webFileUpload = options.webFileUpload ?? new WebFileUpload({
15
+ httpRequest: MSAppClient.instance.httpRequest
16
+ });
17
+ }
18
+ async selectFile() {
19
+ const input = document.createElement("input");
20
+ input.type = "file";
21
+ Object.assign(input.style, {
22
+ width: "1px",
23
+ height: "1px",
24
+ display: "none"
25
+ });
26
+ const file = await new Promise((resolve) => {
27
+ const handleFileChange = (event) => {
28
+ const files = input.files;
29
+ input.parentElement?.removeChild(input);
30
+ resolve(files?.length ? files[0] : null);
31
+ };
32
+ input.addEventListener("change", handleFileChange);
33
+ document.body.append(input);
34
+ });
35
+ if (!file) {
36
+ return { success: true, path: "", msg: "" };
37
+ }
38
+ const response = await this.webFileUpload.upload(file);
39
+ return {
40
+ success: response.data.code === 200,
41
+ path: response.data.data.path,
42
+ msg: response.data.msg
43
+ };
44
+ }
45
+ }
46
+
47
+ export { WebFileUploadContext };
48
+ //# 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":[],"mappings":";;;;;;;;;AAQO,MAAM,6BAA6B,aAAc,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,IAAI,aAAc,CAAA;AAAA,MAChB,WAAA,EAAa,YAAY,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,20 @@
1
+ import { buildProps } from '@maketribe/utils';
2
+ import { UploadContext } from './UploadContext.js';
3
+ import { MaterialUploadContext } from './MaterialUploadContext.js';
4
+
5
+ const uploadFileProps = buildProps({
6
+ modelValue: {
7
+ type: String,
8
+ required: true
9
+ },
10
+ uploadContext: {
11
+ type: UploadContext,
12
+ default: () => new MaterialUploadContext()
13
+ }
14
+ });
15
+ const uploadFileEmits = {
16
+ "upload:modelValue": (path) => true
17
+ };
18
+
19
+ export { uploadFileEmits, uploadFileProps };
20
+ //# 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":[],"mappings":";;;;AAKO,MAAM,kBAAkB,UAAW,CAAA;AAAA,EACxC,UAAY,EAAA;AAAA,IACV,IAAM,EAAA,MAAA;AAAA,IACN,QAAU,EAAA,IAAA;AAAA,GACZ;AAAA,EACA,aAAe,EAAA;AAAA,IACb,IAAM,EAAA,aAAA;AAAA,IACN,OAAA,EAAS,MAAM,IAAI,qBAAsB,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,47 @@
1
+ import { defineComponent, computed, createVNode, unref } from 'vue';
2
+ import { uploadFileProps, uploadFileEmits } from './upload-file-options.js';
3
+ import { ElMessage } from 'element-plus';
4
+
5
+ var uploadFile = /* @__PURE__ */ defineComponent({
6
+ name: "MKUploadFile",
7
+ props: uploadFileProps,
8
+ emits: uploadFileEmits,
9
+ setup(props, {
10
+ emit
11
+ }) {
12
+ const value = computed({
13
+ get: () => props.modelValue,
14
+ set: (v) => emit("upload:modelValue", v)
15
+ });
16
+ const uploadContext = computed(() => props.uploadContext);
17
+ const handleUpload = async () => {
18
+ try {
19
+ const uploadResult = await unref(uploadContext).selectFile();
20
+ if (uploadResult.success) {
21
+ value.value = uploadResult.path;
22
+ return;
23
+ }
24
+ ElMessage.error(uploadResult.msg);
25
+ } catch (e) {
26
+ console.error(e);
27
+ ElMessage.error("\u7F51\u7EDC\u5F02\u5E38");
28
+ }
29
+ };
30
+ return {
31
+ handleUpload
32
+ };
33
+ },
34
+ render() {
35
+ const {
36
+ handleUpload,
37
+ $slots
38
+ } = this;
39
+ return createVNode("div", {
40
+ "class": "mk-upload-file",
41
+ "onClick": handleUpload
42
+ }, [$slots.default?.()]);
43
+ }
44
+ });
45
+
46
+ export { uploadFile as default };
47
+ //# 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":["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+B,eAAA,CAAA;AAAA,EAC7BA,IAAM,EAAA,cAAA;AAAA,EACNC,KAAOC,EAAAA,eAAAA;AAAAA,EACPC,KAAOC,EAAAA,eAAAA;AAAAA,EACPC,MAAMJ,KAAO,EAAA;AAAA,IAAEK,IAAAA;AAAAA,GAAQ,EAAA;AACrB,IAAA,MAAMC,QAAQC,QAAS,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,QAAAA,CAAS,MAAMP,KAAAA,CAAMY,aAAa,CAAA,CAAA;AAExD,IAAA,MAAMC,eAAe,YAAY;AAC/B,MAAI,IAAA;AACF,QAAA,MAAMC,YAAe,GAAA,MAAMC,KAAMH,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,SAAAA,CAAAA,KAAAA,CAAMN,aAAaO,GAAG,CAAA,CAAA;AAAA,eACzBC,CAAG,EAAA;AACVC,QAAAA,OAAAA,CAAQH,MAAME,CAAC,CAAA,CAAA;AACfH,QAAAA,SAAAA,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,YAAA,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;;;;"}
@@ -92,24 +92,30 @@ class PageManager {
92
92
  if (!userSession) {
93
93
  return;
94
94
  }
95
+ const router = userSession.router;
95
96
  const addedExtendsPageNames = [];
96
- if (!this.extendsPages.find((page) => page.name === "notFound")) {
97
- this.addExtendsPage({
98
- name: "notFound",
99
- // path: ":pathMatch(.*)*",
100
- path: "",
101
- component: () => import('../page/index/404.vue.js')
102
- });
103
- }
104
97
  for (const extendsPage of this.extendsPages) {
98
+ const routeInfo = router.getRouteByName(extendsPage.name);
99
+ if (!routeInfo) {
100
+ continue;
101
+ }
105
102
  const vueRoute = vueRoutes.find(
106
103
  (vueRoute2) => vueRoute2.name === extendsPage.name
107
104
  );
108
105
  if (!vueRoute) {
106
+ extendsPage.path = routeInfo.route || extendsPage.path;
109
107
  addedExtendsPageNames.push(extendsPage.name);
110
108
  vueRouter.addRoute("mk-ms-layout", extendsPage);
111
109
  }
112
110
  }
111
+ if (!this.extendsPages.find((page) => page.name === "notFound")) {
112
+ this.addExtendsPage({
113
+ name: "notFound",
114
+ // path: ":pathMatch(.*)*",
115
+ path: "",
116
+ component: () => import('../page/index/404.vue.js')
117
+ });
118
+ }
113
119
  userSession.register(
114
120
  createDisposable(() => {
115
121
  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 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 for (const extendsPage of this.extendsPages) {\n const vueRoute = vueRoutes.find(\n (vueRoute) => vueRoute.name === extendsPage.name\n );\n\n if (!vueRoute) {\n addedExtendsPageNames.push(extendsPage.name as string);\n vueRouter.addRoute(\"mk-ms-layout\", extendsPage);\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":["vueRoute"],"mappings":"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"}
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":["vueRoute"],"mappings":"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"}
@@ -31,7 +31,7 @@ class Router extends Disposable {
31
31
  case "normal":
32
32
  vueRouter.addRoute("mk-ms-layout", {
33
33
  name: defaultPageRoute.name,
34
- path: `/dv/${name}`,
34
+ path: defaultPageRoute.route || `/dv/${name}`,
35
35
  component: () => import('../page/index/dv/default/single/list/normal.vue.js'),
36
36
  meta: { name }
37
37
  });
@@ -39,7 +39,7 @@ class Router extends Disposable {
39
39
  case "dialog":
40
40
  vueRouter.addRoute("mk-ms-layout", {
41
41
  name: defaultPageRoute.name,
42
- path: `/dv/${name}`,
42
+ path: defaultPageRoute.route || `/dv/${name}`,
43
43
  component: () => import('../page/index/dv/default/single/list/dialog.vue.js'),
44
44
  meta: { name }
45
45
  });
@@ -51,7 +51,7 @@ class Router extends Disposable {
51
51
  case "dialog":
52
52
  vueRouter.addRoute("mk-ms-layout", {
53
53
  name: defaultPageRoute.name,
54
- path: `/dv/${name}`,
54
+ path: defaultPageRoute.route || `/dv/${name}`,
55
55
  component: () => import('../page/index/dv/default/single/tree/dialog.vue.js'),
56
56
  meta: { name }
57
57
  });
@@ -63,7 +63,7 @@ class Router extends Disposable {
63
63
  case "dialog":
64
64
  vueRouter.addRoute("mk-ms-layout", {
65
65
  name: defaultPageRoute.name,
66
- path: `/dv/${name}`,
66
+ path: defaultPageRoute.route || `/dv/${name}`,
67
67
  component: () => import('../page/index/dv/default/single/table-tree/dialog.vue.js'),
68
68
  meta: { name }
69
69
  });
@@ -74,7 +74,7 @@ class Router extends Disposable {
74
74
  case "list":
75
75
  vueRouter.addRoute("mk-ms-layout", {
76
76
  name: defaultPageRoute.name,
77
- path: `/dv/${name}`,
77
+ path: defaultPageRoute.route || `/dv/${name}`,
78
78
  component: () => import('../page/index/dv/default/table.vue.js'),
79
79
  meta: { name }
80
80
  });
@@ -82,7 +82,7 @@ class Router extends Disposable {
82
82
  case "edit":
83
83
  vueRouter.addRoute("mk-ms-layout", {
84
84
  name: defaultPageRoute.name,
85
- path: `/dv/${name}/:id`,
85
+ path: defaultPageRoute.route || `/dv/${name}/:id`,
86
86
  component: () => import('../page/index/dv/default/edit.vue.js'),
87
87
  meta: { name }
88
88
  });
@@ -90,7 +90,7 @@ class Router extends Disposable {
90
90
  case "add":
91
91
  vueRouter.addRoute("mk-ms-layout", {
92
92
  name: defaultPageRoute.name,
93
- path: `/dv/${name}/add`,
93
+ path: defaultPageRoute.route || `/dv/${name}/add`,
94
94
  component: () => import('../page/index/dv/default/add.vue.js'),
95
95
  meta: { name }
96
96
  });
@@ -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":[],"mappings":"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"}
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":[],"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
- path?: string;
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
- path: string;
19
+ route: string;
20
20
  };
21
21
  export declare class RouteForm extends DataForm<RouteResult, Route> {
22
22
  constructor(options?: DataFormOptions);