提交 1bf03e3f 编写于 作者: WodahsOrez's avatar WodahsOrez

add: 关系路径

上级 7669dc2f
package cn.ibizlab.codegen.model; package cn.ibizlab.codegen.model;
import cn.ibizlab.codegen.utils.Inflector;
import cn.ibizlab.codegen.utils.StringAdvUtils; import cn.ibizlab.codegen.utils.StringAdvUtils;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import lombok.Getter; import lombok.Getter;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import lombok.Setter; import lombok.Setter;
...@@ -23,6 +26,49 @@ public class AppEntityModel extends BaseModel{ ...@@ -23,6 +26,49 @@ public class AppEntityModel extends BaseModel{
this.setName(appDataEntity.getName()); this.setName(appDataEntity.getName());
this.setId(String.format("%1$s-%2$s",app.getCodeName(),appDataEntity.getCodeName())); this.setId(String.format("%1$s-%2$s",app.getCodeName(),appDataEntity.getCodeName()));
// 初始化应用实体资源数据
if(getAppDataEntity().getMinorPSAppDERSs() != null){
// 遍历多个主从关系
getAppDataEntity().getMinorPSAppDERSs().forEach(appDERS ->{
JSONObject appEntityResource = new JSONObject();
String majorCodeName = appDERS.getMajorPSAppDataEntity().getCodeName();
String minorCodeName = appDERS.getMinorPSAppDataEntity().getCodeName();
String path = String.format("%1$s/:%2$s?/%3$s/:%4$s?", Inflector.getInstance().pluralize(majorCodeName),majorCodeName,Inflector.getInstance().pluralize(minorCodeName),minorCodeName).toLowerCase();
appEntityResource.put("majorCodeName",majorCodeName.toLowerCase());
appEntityResource.put("curCodeName",minorCodeName.toLowerCase());
appEntityResource.put("path",path);
// 实体关系路径集合
List deResPaths = new JSONArray();
// 主关系路径节点
JSONObject majorResNode = new JSONObject();
majorResNode.put("pathName", Inflector.getInstance().pluralize(majorCodeName).toLowerCase());
majorResNode.put("parameterName", majorCodeName.toLowerCase());
deResPaths.add(majorResNode);
// 从关系路径节点
JSONObject minorResNode = new JSONObject();
minorResNode.put("pathName", Inflector.getInstance().pluralize(minorCodeName).toLowerCase());
minorResNode.put("parameterName", minorCodeName.toLowerCase());
deResPaths.add(minorResNode);
appEntityResource.put("deResPaths", deResPaths);
appEntityResources.add(appEntityResource);
});
}else{
// 没有主从关系,路径就只有自己本身一个
JSONObject appEntityResource = new JSONObject();
appEntityResource.put("curCodeName",appDataEntity.getCodeName().toLowerCase());
appEntityResource.put("path",String.format("%1$s/:%2$s?",Inflector.getInstance().pluralize(appDataEntity.getCodeName()),appDataEntity.getCodeName()).toLowerCase());
// 路由关系路径集合
List deResPaths = new JSONArray();
// 实体本身关系路径节点
JSONObject curResNode = new JSONObject();
curResNode.put("pathName", Inflector.getInstance().pluralize(appDataEntity.getCodeName()).toLowerCase());
curResNode.put("parameterName", appDataEntity.getCodeName().toLowerCase());
deResPaths.add(curResNode);
appEntityResource.put("deResPaths", deResPaths);
appEntityResource.put("deResPathsString", deResPaths.toString());
appEntityResources.add(appEntityResource);
}
} }
public IPSAppDataEntity getAppDataEntity() public IPSAppDataEntity getAppDataEntity()
...@@ -64,4 +110,10 @@ public class AppEntityModel extends BaseModel{ ...@@ -64,4 +110,10 @@ public class AppEntityModel extends BaseModel{
return ctrlsMap.values(); return ctrlsMap.values();
} }
/**
* 应用实体资源数据
*/
private List<JSONObject> appEntityResources =new ArrayList<>();
} }
...@@ -61,40 +61,6 @@ public class AppModel extends BaseModel{ ...@@ -61,40 +61,6 @@ public class AppModel extends BaseModel{
}); });
} }
// 初始化应用实体关系数据Set
if(getApplication().getAllPSAppDataEntities()!=null){
getApplication().getAllPSAppDataEntities().forEach(appDataEntity ->{
JSONObject tempObj = new JSONObject();
tempObj.put("appDataEntity",appDataEntity);
if(appDataEntity.getMinorPSAppDERSs() != null){
List deResLinks = new ArrayList<JSONObject>();
appDataEntity.getMinorPSAppDERSs().forEach(appDERS ->{
JSONObject deResLink = new JSONObject();
String majorCodeName = appDERS.getMajorPSAppDataEntity().getCodeName();
String minorCodeName = appDERS.getMinorPSAppDataEntity().getCodeName();
String path = String.format("%1$s/:%2$s?/%3$s/:%4$s?",Inflector.getInstance().pluralize(majorCodeName),majorCodeName,Inflector.getInstance().pluralize(minorCodeName),minorCodeName).toLowerCase();
deResLink.put("majorCodeName",majorCodeName.toLowerCase());
deResLink.put("path",path);
// 路由关系参数数组
List deResParameters = new ArrayList();
JSONObject majorResObj = new JSONObject();
majorResObj.put("pathName", Inflector.getInstance().pluralize(majorCodeName).toLowerCase());
majorResObj.put("parameterName", majorCodeName.toLowerCase());
deResParameters.add(majorResObj);
JSONObject minorResObj = new JSONObject();
minorResObj.put("pathName", Inflector.getInstance().pluralize(minorCodeName).toLowerCase());
minorResObj.put("parameterName", minorCodeName.toLowerCase());
deResParameters.add(minorResObj);
deResLink.put("deResParameters", deResParameters);
deResLinks.add(deResLink);
});
tempObj.put("deResLinks", deResLinks);
}else{
tempObj.put("path",String.format("%1$s/:%2$s?",Inflector.getInstance().pluralize(appDataEntity.getCodeName()),appDataEntity.getCodeName()).toLowerCase());
}
appDeResSet.add(tempObj);
});
}
} }
...@@ -145,11 +111,6 @@ public class AppModel extends BaseModel{ ...@@ -145,11 +111,6 @@ public class AppModel extends BaseModel{
*/ */
private Map<String, JSONObject> appEntityResourceMap =new LinkedHashMap<>(); private Map<String, JSONObject> appEntityResourceMap =new LinkedHashMap<>();
/**
* 应用实体关系对象Set
*/
private Set<JSONObject> appDeResSet =new HashSet<>();
/** /**
* 获取应用实体资源数据 * 获取应用实体资源数据
* @return * @return
......
{{!-- {
{{#each app.appEntityResources as |appEntityResource|}}
{{#if appEntityResource.appDataEntity.allPSAppViews}}
{{#each appEntityResource.appDataEntity.allPSAppViews as |appView|}}
"{{appView.codeName}}":{
"name": "{{appView.name}}",
"codeName": "{{appView.codeName}}",
"openMode": "{{#if appView.openMode}}{{appView.openMode}}{{else}}INDEXVIEWTAB{{/if}}",
"redirectView": {{appView.redirectView}},
"path": "{{appEntityResource.path}}/views/{{lowerCase appView.codeName}}",
{{#if appView.capPSLanguageRes}}
"captionTag": "{{appView.capPSLanguageRes.lanResTag}}",
{{/if}}
"caption": "{{appView.caption}}",
{{#if appView.psSysImage}}
"imgPath": "{{appView.psSysImage.imagePath}}",
"iconCls": "{{appView.psSysImage.cssClass}}",
{{/if}}
"viewType": "{{appView.viewType}}",
"fileDir": "@page/{{#if psAppDataEntity}}{{spinalCase psAppDataEntity.codeName}}{{else}}default{{/if}}/{{spinalCase appView.codeName}}"
}{{#unless (and @last ../@last)}},{{/unless}}
{{/each}}
{{/if}}
{{/each}}
} --}}
{ {
{{#each app.appDeResSet as |appDeRes|}} {{#each app.pages as |appView|}}
{{#if appDeRes.deResLinks}}
{{#each appDeRes.appDataEntity.allPSAppViews as |appView|}}
"{{appView.codeName}}":{ "{{appView.codeName}}":{
"name": "{{appView.name}}", "name": "{{appView.name}}",
"codeName": "{{appView.codeName}}", "codeName": "{{appView.codeName}}",
"openMode": "{{#if appView.openMode}}{{appView.openMode}}{{else}}INDEXVIEWTAB{{/if}}", "openMode": "{{#if appView.openMode}}{{appView.openMode}}{{else}}INDEXVIEWTAB{{/if}}",
"redirectView": {{appView.redirectView}}, "redirectView": {{appView.redirectView}},
"deResLinks": [ "deResPaths": [
{{#each appDeRes.deResLinks as |deResLink| }} {{#each appView.appEntity.appEntityResources as |appEntityResource| }}
[ {{appEntityResource.deResPaths}}{{#unless @last}},{{/unless}}
{{#each deResLink.deResParameters as |deResParameter| }}
{ "pathName": "{{deResParameter.pathName}}", "parameterName": "{{deResParameter.parameterName}}" }{{#unless @last}},{{/unless}}
{{/each}}
]{{#unless @last}},{{/unless}}
{{/each}} {{/each}}
], ],
"parameters": [ "parameters": [
{{#if appDeRes.appDataEntity}}
{ "pathName": "{{pluralize appDeRes.appDataEntity.codeName}}", "parameterName": "{{appDeRes.appDataEntity.codeName}}" },
{{/if}}
{ "pathName": "views", "parameterName": "{{lowerCase appView.codeName}}" } { "pathName": "views", "parameterName": "{{lowerCase appView.codeName}}" }
], ],
{{#if appView.capPSLanguageRes}} {{#if appView.capPSLanguageRes}}
...@@ -58,7 +24,5 @@ ...@@ -58,7 +24,5 @@
"viewType": "{{appView.viewType}}", "viewType": "{{appView.viewType}}",
"fileDir": "@page/{{#if psAppDataEntity}}{{spinalCase psAppDataEntity.codeName}}{{else}}default{{/if}}/{{spinalCase appView.codeName}}" "fileDir": "@page/{{#if psAppDataEntity}}{{spinalCase psAppDataEntity.codeName}}{{else}}default{{/if}}/{{spinalCase appView.codeName}}"
}{{#unless (and @last ../@last)}},{{/unless}} }{{#unless (and @last ../@last)}},{{/unless}}
{{/each}}
{{/if}}
{{/each}} {{/each}}
} }
<script setup lang="ts"> <script setup lang="ts">
// This starter template is using Vue 3 <script setup> SFCs // This starter template is using Vue 3 <script setup> SFCs
// Check out https://v3.vuejs.org/api/sfc-script-setup.html#sfc-script-setup // Check out https://v3.vuejs.org/api/sfc-script-setup.html#sfc-script-setup
import {App} from '@service'
onMounted(async ()=>{
await App.init();
// App.openViewService.openView({codeName: 'ExampleEditorEditView'},{context: {},viewParams:{}})
})
</script> </script>
<template> <template>
......
export * from './control-service' export * from './control-service'
export * from './entity' export * from './entity'
export * from './singleton' \ No newline at end of file
\ No newline at end of file
/**
* 单例基类
*
* @export
* @class Singleton
*/
export class Singleton{
/**
* 唯一实例
*
* @private
* @static
* @memberof Singleton
*/
private static readonly instance = new Singleton();
/**
* 获取唯一实例
*
* @static
* @return {*} {Singleton}
* @memberof Singleton
*/
public static getInstance(): Singleton {
return Singleton.instance;
}
}
\ No newline at end of file
export * from './util'; export * from './util';
export * from './view-util'; export * from './view-util';
export * from './route-tool';
export { Http } from './net/http'; export { Http } from './net/http';
\ No newline at end of file
import { useRoute } from 'vue-router';
import { notEmpty } from '@ibiz-core'; import { notEmpty } from '@ibiz-core';
import qs from 'qs'; import qs from 'qs';
...@@ -9,336 +8,348 @@ import qs from 'qs'; ...@@ -9,336 +8,348 @@ import qs from 'qs';
* @class RouteTool * @class RouteTool
*/ */
export class RouteTool { export class RouteTool {
/**
* 处理路由路径
*
* @static
* @param {Route} route 路由
* @param {*} [viewParam={}]
* @param {any[]} deResPaths 关系实体参数对象
* @param {any[]} parameters 当前应用视图参数对象
* @param {any[]} args 多项数据
* @param {*} data 行为参数
* @returns {string}
* @memberof RouteTool
*/
/**
* 处理路由路径
* @static
* @param view 视图信息
* @param context 上下文
* @param viewParams 视图参数
* @return {*}
*/
public static buildUpRoutePath(view: any, context: any, viewParams: any, route: any): string {
const { deResPaths, parameters } = view;
const indexRoutePath = this.getIndexRoutePath(route);
const deResRoutePath = this.getDeResRoutePath(context, deResPaths);
const deRoutePath = this.getActiveRoutePath(parameters, context, viewParams);
return `${indexRoutePath}${deResRoutePath}${deRoutePath}`;
}
/** /**
* 处理路由路径 * 获取首页根路由路径
* *
* @static * @static
* @param {Route} route 路由 * @param {Route} route 路由对象
* @param {*} [viewParam={}] * @returns {string}
* @param {any[]} deResParameters 关系实体参数对象 * @memberof RouteTool
* @param {any[]} parameters 当前应用视图参数对象 */
* @param {any[]} args 多项数据 public static getIndexRoutePath(route: any): string {
* @param {*} data 行为参数 const parameterName = route.meta?.parameters?.[0] || "apps";
* @returns {string} const param = route.params[parameterName];
* @memberof RouteTool if (notEmpty(param)) {
*/ return `/${parameterName}/${param}`;
/**
* 处理路由路径
* @static
* @param view 视图信息
* @param context 上下文
* @param viewParams 视图参数
* @return {*}
*/
public static buildUpRoutePath(view: any, context: any, viewParams: any): string {
const route = useRoute()
const { deResLinks, parameters } = view;
const deResParameters = deResLinks[0];
const indexRoutePath = this.getIndexRoutePath(route);
const deResRoutePath = this.getDeResRoutePath(context, deResParameters);
const deRoutePath = this.getActiveRoutePath(parameters, context, viewParams);
return `${indexRoutePath}${deResRoutePath}${deRoutePath}`;
} }
return `/${parameterName}`;
}
/** /**
* 获取首页根路由路径 * 获取关系实体路径
* *
* @static * @static
* @param {Route} route 路由对象 * @param {*} [viewParam={}] 视图上下文
* @returns {string} * @param {any[]} deResPaths 关系实体参数对象数组
* @memberof RouteTool * @returns {string}
*/ * @memberof RouteTool
public static getIndexRoutePath(route: any): string { */
const { parameters: _parameters }: { parameters: any[] } = route.meta; public static getDeResRoutePath(context: any = {}, deResPaths: any[]): string {
const { pathName: _pathName, parameterName: _parameterName }: { pathName: string, parameterName: string } = _parameters[0]; let routePath: string = '';
const param = route.params[_parameterName]; // 首先给deResPaths排序,关系多的排前面。
if (notEmpty(param)) { deResPaths.sort((a: any[], b: any[]) => a.length - b.length);
return `/${_parameterName}/${param}`;
}
return `/${_parameterName}`;
}
/** // 最多匹配路径节点数
* 获取关系实体路径 let maxMatch: number = 0;
* // 开始匹配,先遍历关系路径,在遍历关系路径的每个节点
* @static deResPaths.some((deResPath: any[]) => {
* @param {*} [viewParam={}] 视图上下文 // 如果节点个数小于最大匹配,则后面都无需在计算了。
* @param {any[]} deResParameters 关系实体参数对象数组 if (maxMatch > deResPath.length) {
* @returns {string} return true;
* @memberof RouteTool }
*/
public static getDeResRoutePath(context: any = {}, deResParameters: any[]): string {
let routePath: string = '';
if (deResParameters && deResParameters.length > 0) {
deResParameters.forEach(({ pathName, parameterName }: { pathName: string, parameterName: string }) => {
let value: any = null;
if (context[parameterName] && !Object.is(context[parameterName], '') && !Object.is(context[parameterName], 'null')) {
value = context[parameterName];
}
routePath = `${routePath}/${pathName}` + (notEmpty(value) ? `/${value}` : '');
});
}
return routePath;
}
/** // 当前匹配路径节点数
* 当前激活路由路径 let curMatch: number = 0;
* let curRoutPath: string = '';
* @static
* @param parameters 当前视图参数对象 deResPath.some((deResNode: any, index: number) => {
* @param context 视图上下文 let value: any = context[deResNode.parameterName];
* @param [viewParams={}] 视图参数 if (notEmpty(value)) {
* @return {*} curMatch++;
*/ curRoutPath += `/${deResNode.pathName}/${value}`;
public static getActiveRoutePath(parameters: any[], context: any, viewParams: any = {}): string { } else if (curMatch != 0 || index == deResPath.length) {
let routePath: string = ''; // 如果前面一个路径节点已经匹配则前一段路径作废,继续匹配后面的。
if (parameters && parameters.length > 0) { // 如果最后一个节点也没值,则整个路径作废。
// 不存在应用实体 curMatch = 0;
if (parameters.length === 1) { curRoutPath = '';
const [{ parameterName }] = parameters;
routePath = `/views/${parameterName}`;
if (Object.keys(viewParams).length > 0) {
routePath = `${routePath}?${qs.stringify(viewParams, { delimiter: ';' })}`;
}
} else if (parameters.length === 2) {
let [arg] = args;
arg = arg ? arg : {};
const [{ pathName: _pathName, parameterName: _parameterName }, { pathName: _pathName2, parameterName: _parameterName2 }] = parameters;
const _value: any = context[_parameterName] || null;
routePath = `/${_pathName}${notEmpty(_value) ? `/${_value}` : ''}/views/${_parameterName2}`;
if (Object.keys(viewParams).length > 0) {
routePath = `${routePath}?${qs.stringify(viewParams, { delimiter: ';' })}`;
}
}
} }
return routePath; });
// 当前匹配个数大于最大匹配时,修改最大匹配和最终结果
if (curMatch > maxMatch) {
maxMatch = curMatch;
routePath = curRoutPath;
}
});
return routePath;
}
/**
* 当前激活路由路径
*
* @static
* @param parameters 当前视图参数对象
* @param context 视图上下文
* @param [viewParams={}] 视图参数
* @return {*}
*/
public static getActiveRoutePath(parameters: any[], context: any, viewParams: any = {}): string {
let routePath: string = '';
const [{ parameterName }] = parameters;
routePath = `/views/${parameterName}`;
if (Object.keys(viewParams).length > 0) {
routePath = `${routePath}?${qs.stringify(viewParams, { delimiter: ';' })}`;
} }
return routePath;
}
/** /**
* 格式化路由参数 * 格式化路由参数
* *
* @static * @static
* @param {*} params * @param {*} params
* @returns {*} * @returns {*}
* @memberof RouteTool * @memberof RouteTool
*/ */
public static formatRouteParams(params: any, route: any, context: any, viewparams: any): void { public static formatRouteParams(params: any, route: any, context: any, viewparams: any): void {
Object.keys(params).forEach((key: string, index: number) => { Object.keys(params).forEach((key: string, index: number) => {
const param: string | null | undefined = params[key]; const param: string | null | undefined = params[key];
if (!param || Object.is(param, '') || Object.is(param, 'null')) { if (!param || Object.is(param, '') || Object.is(param, 'null')) {
return; return;
} }
if (param.indexOf('=') > 0) { if (param.indexOf('=') > 0) {
const _param = qs.parse(param, { delimiter: ';' }); const _param = qs.parse(param, { delimiter: ';' });
Object.assign(context, _param); Object.assign(context, _param);
} else { } else {
Object.assign(context, { [key]: param }); Object.assign(context, { [key]: param });
} }
});
if (route && route.fullPath && route.fullPath.indexOf('?') > -1) {
const _viewparams: any = route.fullPath.slice(route.fullPath.indexOf('?') + 1);
const _viewparamArray: Array<string> = decodeURIComponent(_viewparams).split(';');
if (_viewparamArray.length > 0) {
_viewparamArray.forEach((item: any) => {
Object.assign(viewparams, qs.parse(item));
}); });
if (route && route.fullPath && route.fullPath.indexOf("?") > -1) { }
const _viewparams: any = route.fullPath.slice(route.fullPath.indexOf("?") + 1);
const _viewparamArray: Array<string> = decodeURIComponent(_viewparams).split(";")
if (_viewparamArray.length > 0) {
_viewparamArray.forEach((item: any) => {
Object.assign(viewparams, qs.parse(item));
})
}
}
} }
}
/** /**
* 首页路由结构参数 * 首页路由结构参数
* *
* @private * @private
* @static * @static
* @type {any[]} * @type {any[]}
* @memberof RouteTool * @memberof RouteTool
*/ */
private static indexParameters: any[] = []; private static indexParameters: any[] = [];
/** /**
* 设置首页路由结构参数 * 设置首页路由结构参数
* *
* @static * @static
* @param {any[]} parameters * @param {any[]} parameters
* @memberof RouteTool * @memberof RouteTool
*/ */
public static setIndexParameters(parameters: any[]): void { public static setIndexParameters(parameters: any[]): void {
this.indexParameters = [...parameters] this.indexParameters = [...parameters];
} }
/** /**
* 获取首页路由结构参数 * 获取首页路由结构参数
* *
* @static * @static
* @returns {any[]} * @returns {any[]}
* @memberof RouteTool * @memberof RouteTool
*/ */
public static getIndexParameters(): any[] { public static getIndexParameters(): any[] {
return this.indexParameters; return this.indexParameters;
} }
/** /**
* 首页视图参数 * 首页视图参数
* *
* @static * @static
* @type {*} * @type {*}
* @memberof RouteTool * @memberof RouteTool
*/ */
public static indexViewParam: any = {}; public static indexViewParam: any = {};
/** /**
* 设置首页视图参数 * 设置首页视图参数
* *
* @static * @static
* @param {*} [viewParam={}] * @param {*} [viewParam={}]
* @memberof RouteTool * @memberof RouteTool
*/ */
public static setIndexViewParam(viewParam: any = {}): void { public static setIndexViewParam(viewParam: any = {}): void {
Object.assign(this.indexViewParam, viewParam); Object.assign(this.indexViewParam, viewParam);
} }
/** /**
* 获取首页视图参数 * 获取首页视图参数
* *
* @static * @static
* @returns {*} * @returns {*}
* @memberof RouteTool * @memberof RouteTool
*/ */
public static getIndexViewParam(): any { public static getIndexViewParam(): any {
return this.indexViewParam; return this.indexViewParam;
} }
/** /**
* 计算界面行为项权限状态 * 计算界面行为项权限状态
* *
* @static * @static
* @param {*} [data] 传入数据 * @param {*} [data] 传入数据
* @param {*} [ActionModel] 界面行为模型 * @param {*} [ActionModel] 界面行为模型
* @param {*} [UIService] 界面行为服务 * @param {*} [UIService] 界面行为服务
* @memberof RouteTool * @memberof RouteTool
*/ */
public static calcActionItemAuthState(data: any, ActionModel: any, UIService: any) { public static calcActionItemAuthState(data: any, ActionModel: any, UIService: any) {
let result: any[] = []; let result: any[] = [];
if (!UIService) if (!UIService) return;
return; for (const key in ActionModel) {
for (const key in ActionModel) { if (!ActionModel.hasOwnProperty(key)) {
if (!ActionModel.hasOwnProperty(key)) {
return result;
}
const _item = ActionModel[key];
let dataActionResult: any;
if (_item && _item['dataAccessAction']) {
if (Object.is(_item['actionTarget'], "NONE") || Object.is(_item['actionTarget'], "")) {
dataActionResult = UIService.getAllOPPrivs(undefined, _item['dataAccessAction']);
} else {
if (data && Object.keys(data).length > 0) {
dataActionResult = UIService.getAllOPPrivs(data, _item['dataAccessAction']);
}
}
} else {
dataActionResult = 1;
}
// 无权限:0;有权限:1
if (dataActionResult === 0) {
// 禁用:1;隐藏:2;隐藏且默认隐藏:6
if (_item.getNoPrivDisplayMode === 1) {
_item.disabled = true;
}
if ((_item.getNoPrivDisplayMode === 2) || (_item.getNoPrivDisplayMode === 6)) {
_item.visabled = false;
} else {
_item.visabled = true;
}
}
if (dataActionResult === 1) {
_item.visabled = true;
_item.disabled = false;
}
// 返回权限验证的结果
_item.dataActionResult = dataActionResult;
result.push(dataActionResult);
}
return result; return result;
}
const _item = ActionModel[key];
let dataActionResult: any;
if (_item && _item['dataAccessAction']) {
if (Object.is(_item['actionTarget'], 'NONE') || Object.is(_item['actionTarget'], '')) {
dataActionResult = UIService.getAllOPPrivs(undefined, _item['dataAccessAction']);
} else {
if (data && Object.keys(data).length > 0) {
dataActionResult = UIService.getAllOPPrivs(data, _item['dataAccessAction']);
}
}
} else {
dataActionResult = 1;
}
// 无权限:0;有权限:1
if (dataActionResult === 0) {
// 禁用:1;隐藏:2;隐藏且默认隐藏:6
if (_item.getNoPrivDisplayMode === 1) {
_item.disabled = true;
}
if (_item.getNoPrivDisplayMode === 2 || _item.getNoPrivDisplayMode === 6) {
_item.visabled = false;
} else {
_item.visabled = true;
}
}
if (dataActionResult === 1) {
_item.visabled = true;
_item.disabled = false;
}
// 返回权限验证的结果
_item.dataActionResult = dataActionResult;
result.push(dataActionResult);
} }
return result;
}
/** /**
* 计算界面行为项权限状态(树节点版本) * 计算界面行为项权限状态(树节点版本)
* *
* @static * @static
* @param {*} [data] 传入数据 * @param {*} [data] 传入数据
* @param {*} [ActionModel] 界面行为模型 * @param {*} [ActionModel] 界面行为模型
* @param {*} [UIService] 界面行为服务 * @param {*} [UIService] 界面行为服务
* @memberof RouteTool * @memberof RouteTool
*/ */
public static calcTreeActionItemAuthState(data: any, ActionModel: any, UIService: any) { public static calcTreeActionItemAuthState(data: any, ActionModel: any, UIService: any) {
let result: any[] = []; let result: any[] = [];
if (!UIService) if (!UIService) return;
return; for (const key in ActionModel) {
for (const key in ActionModel) { if (!ActionModel.hasOwnProperty(key)) {
if (!ActionModel.hasOwnProperty(key)) {
return result;
}
const _item = ActionModel[key];
let dataActionResult: any;
if (Object.is(_item['actiontarget'], "NONE") || Object.is(_item['actiontarget'], "")) {
dataActionResult = UIService.getAllOPPrivs(undefined, _item['dataaccaction']);
} else {
if (_item && _item['dataaccaction'] && UIService.isEnableDEMainState) {
if (data && Object.keys(data).length > 0) {
dataActionResult = UIService.getAllOPPrivs(data, _item['dataaccaction']);
}
}
}
// 无权限:0;有权限:1
if (dataActionResult === 0) {
// 禁用:1;隐藏:2;隐藏且默认隐藏:6
if (_item.noprivdisplaymode === 1) {
_item.disabled = true;
}
if ((_item.noprivdisplaymode === 2) || (_item.noprivdisplaymode === 6)) {
_item.visabled = false;
} else {
_item.visabled = true;
}
}
if (dataActionResult === 1) {
_item.visabled = true;
_item.disabled = false;
}
// 返回权限验证的结果
_item.dataActionResult = dataActionResult;
result.push(dataActionResult);
}
return result; return result;
}
const _item = ActionModel[key];
let dataActionResult: any;
if (Object.is(_item['actiontarget'], 'NONE') || Object.is(_item['actiontarget'], '')) {
dataActionResult = UIService.getAllOPPrivs(undefined, _item['dataaccaction']);
} else {
if (_item && _item['dataaccaction'] && UIService.isEnableDEMainState) {
if (data && Object.keys(data).length > 0) {
dataActionResult = UIService.getAllOPPrivs(data, _item['dataaccaction']);
}
}
}
// 无权限:0;有权限:1
if (dataActionResult === 0) {
// 禁用:1;隐藏:2;隐藏且默认隐藏:6
if (_item.noprivdisplaymode === 1) {
_item.disabled = true;
}
if (_item.noprivdisplaymode === 2 || _item.noprivdisplaymode === 6) {
_item.visabled = false;
} else {
_item.visabled = true;
}
}
if (dataActionResult === 1) {
_item.visabled = true;
_item.disabled = false;
}
// 返回权限验证的结果
_item.dataActionResult = dataActionResult;
result.push(dataActionResult);
} }
return result;
}
/** /**
* 计算重定向上下文 * 计算重定向上下文
* *
* @static * @static
* @param {*} [tempContext] 上下文 * @param {*} [tempContext] 上下文
* @param {*} [data] 传入数据 * @param {*} [data] 传入数据
* @param {*} [redirectAppEntity] 应用实体对象 * @param {*} [redirectAppEntity] 应用实体对象
* @memberof RouteTool * @memberof RouteTool
*/ */
public static async calcRedirectContext(tempContext: any, data: any, redirectAppEntity: any) { public static async calcRedirectContext(tempContext: any, data: any, redirectAppEntity: any) {
if (redirectAppEntity && redirectAppEntity.getMinorPSAppDERSs() && ((redirectAppEntity.getMinorPSAppDERSs() as []).length > 0)) { if (
for (const item of redirectAppEntity.getMinorPSAppDERSs()) { redirectAppEntity &&
const parentPSAppDEFieldCodeName: string = item.M.getParentPSAppDEField?.codeName; redirectAppEntity.getMinorPSAppDERSs() &&
if (parentPSAppDEFieldCodeName) { (redirectAppEntity.getMinorPSAppDERSs() as []).length > 0
const curData: any = data; ) {
if (curData && curData[parentPSAppDEFieldCodeName.toLowerCase()]) { for (const item of redirectAppEntity.getMinorPSAppDERSs()) {
const majorAppEntity: any = item.getMajorPSAppDataEntity(); const parentPSAppDEFieldCodeName: string = item.M.getParentPSAppDEField?.codeName;
await majorAppEntity.fill(); if (parentPSAppDEFieldCodeName) {
if (!tempContext[majorAppEntity.codeName.toLowerCase()]) { const curData: any = data;
Object.assign(tempContext, { [majorAppEntity.codeName.toLowerCase()]: curData[parentPSAppDEFieldCodeName.toLowerCase()] }); if (curData && curData[parentPSAppDEFieldCodeName.toLowerCase()]) {
} const majorAppEntity: any = item.getMajorPSAppDataEntity();
} await majorAppEntity.fill();
} if (!tempContext[majorAppEntity.codeName.toLowerCase()]) {
Object.assign(tempContext, {
[majorAppEntity.codeName.toLowerCase()]: curData[parentPSAppDEFieldCodeName.toLowerCase()],
});
} }
}
} }
}
} }
}
} }
\ No newline at end of file
import { AppModal } from '@/utils';
import { Http, deepCopy } from '@ibiz-core';
import { OpenViewService } from '@service';
export class App{
/**
* 打开视图服务
* @static
*/
public static openViewService: OpenViewService = OpenViewService.getInstance();
/**
* 打开视图服务
* @static
*/
public static modalService: AppModal = AppModal.getInstance();
/**
* 所有视图信息
*
* @static
*/
public static allViewInfos: any;
/**
* 获取视图信息
*
* @static
* @param codeName 视图codeName
* @return {*}
*/
public static getViewInfo(codeName: string){
return App.allViewInfos[codeName] ? deepCopy(App.allViewInfos[codeName]) : undefined;
}
/**
* 初始化
*
* @static
*/
public static async init(){
const response = await Http.getInstance().get('./assets/json/views.json')
App.allViewInfos = response.data;
}
}
\ No newline at end of file
export * from './open-view/open-view-service';
export * from './app/app';
\ No newline at end of file
import { deepCopy, IParam, Singleton, RouteTool } from "@ibiz-core"; import { deepCopy, IParam, RouteTool } from '@ibiz-core';
import { useRouter } from "vue-router"; import { App } from '@service';
const allViews= require('./views.json') import router from '@/router';
interface View extends IParam{ interface View extends IParam {
codeName: string, codeName: string;
openMode ?: string, openMode?: string;
} }
interface Params extends IParam{ interface Params extends IParam {
context: any, context: any;
viewParams: any, viewParams: any;
} }
/** /**
...@@ -17,7 +17,26 @@ interface Params extends IParam{ ...@@ -17,7 +17,26 @@ interface Params extends IParam{
* @export * @export
* @class OpenViewService * @class OpenViewService
*/ */
export class OpenViewService extends Singleton{ export class OpenViewService {
/**
* 唯一实例
*
* @private
* @static
* @memberof OpenViewService
*/
private static readonly instance = new OpenViewService();
/**
* 获取唯一实例
*
* @static
* @return {*} {OpenViewService}
* @memberof OpenViewService
*/
public static getInstance(): OpenViewService {
return OpenViewService.instance;
}
/** /**
* 打开视图 * 打开视图
...@@ -25,26 +44,24 @@ interface Params extends IParam{ ...@@ -25,26 +44,24 @@ interface Params extends IParam{
* @param view 视图信息 * @param view 视图信息
* @param params 相关参数 * @param params 相关参数
*/ */
public openView(view: View, params: Params){ public openView(view: View, params: Params) {
// 获取详细视图信息 // 获取详细视图信息
let _view: any = allViews[view.codeName]; let _view: any = App.getViewInfo(view.codeName);
if(!_view){ if (!_view) {
console.error(`应用中不存在${view.codeName}视图`); console.error(`应用中不存在${view.codeName}视图`);
return return;
} }
// 拷贝防污染,view的openMode覆盖配置的 // view的openMode覆盖配置的
_view = deepCopy(_view); if (view.openMode) {
if(view.openMode){
_view.openMode = view.openMode; _view.openMode = view.openMode;
} }
// 重定向视图走重定向逻辑,其他根据openMode打开 // 重定向视图走重定向逻辑,其他根据openMode打开
if(_view.redirectView){ if (_view.redirectView) {
this.openRedirectView(_view, params); this.openRedirectView(_view, params);
}else{ } else {
this.openByOpenMode(_view, params) this.openByOpenMode(_view, params);
} }
} }
/** /**
...@@ -53,30 +70,26 @@ interface Params extends IParam{ ...@@ -53,30 +70,26 @@ interface Params extends IParam{
* @param view 视图信息 * @param view 视图信息
* @param params 相关参数 * @param params 相关参数
*/ */
public openByOpenMode(view: any, params: Params){ public openByOpenMode(view: any, params: Params) {
const { openMode } = view; const { openMode } = view;
const { viewParams, context } = params const { viewParams, context } = params;
// 路由打开视图 // 路由打开视图
if(openMode == 'INDEXVIEWTAB' || openMode == 'POPUPAPP'){ if (openMode == 'INDEXVIEWTAB' || openMode == 'POPUPAPP') {
// TODO 视图关系参数处理 // TODO 视图关系参数处理
const router = useRouter(); const routePath = RouteTool.buildUpRoutePath(view, context, viewParams, router.currentRoute.value);
const routePath = RouteTool.buildUpRoutePath(view, context,viewParams); if (openMode == 'INDEXVIEWTAB') {
if(openMode == 'INDEXVIEWTAB'){
router.push(routePath); router.push(routePath);
}else{ } else {
window.open('./#' + routePath, '_blank'); window.open('./#' + routePath, '_blank');
} }
}else if(openMode == 'POPUPMODAL'){ } else if (openMode == 'POPUPMODAL') {
} else if (openMode.indexOf('DRAWER') !== -1) {
}else if(openMode.indexOf('DRAWER') !== -1){
// TODO PMS上面抽屉DRAWER_TOP // TODO PMS上面抽屉DRAWER_TOP
} else if (openMode == 'POPOVER') {
}else if(openMode == 'POPOVER'){
// TODO 打开气泡卡片 // TODO 打开气泡卡片
}else{ } else {
console.error(`未支持${openMode}打开方式`); console.error(`未支持${openMode}打开方式`);
} }
} }
/** /**
...@@ -85,7 +98,7 @@ interface Params extends IParam{ ...@@ -85,7 +98,7 @@ interface Params extends IParam{
* @param view 视图信息 * @param view 视图信息
* @param params 相关参数 * @param params 相关参数
*/ */
public openRedirectView(view: any, params: Params){ public openRedirectView(view: any, params: Params) {
// TODO 重定向视图处理 // TODO 重定向视图处理
} }
} }
\ No newline at end of file
...@@ -4,7 +4,6 @@ import Antd from 'ant-design-vue'; ...@@ -4,7 +4,6 @@ import Antd from 'ant-design-vue';
// import { AppServiceBase, LogUtil } from 'ibiz-core'; // import { AppServiceBase, LogUtil } from 'ibiz-core';
import AppModalComponent from "./app-modal.vue"; import AppModalComponent from "./app-modal.vue";
import IbizLoading from '@components/render/IbizLoading.vue'; import IbizLoading from '@components/render/IbizLoading.vue';
import './app-modal.scss';
export class AppModal { export class AppModal {
......
...@@ -234,7 +234,3 @@ const handleShowState = ($event: any) => { ...@@ -234,7 +234,3 @@ const handleShowState = ($event: any) => {
></component> ></component>
</a-modal> </a-modal>
</template> </template>
<style lang="scss" scoped>
@import './app-modal.scss';
</style>
\ No newline at end of file
...@@ -56,10 +56,10 @@ export class ControlVO extends ControlVOBase { ...@@ -56,10 +56,10 @@ export class ControlVO extends ControlVOBase {
{{/neq}} {{/neq}}
{{/each}} {{/each}}
// 表单里没有映射实体属性的字段 // 表单里没有映射实体属性的字段(srfuf除外)
{{#each ctrl.psDEFormItems as | formItem | }} {{#each ctrl.psDEFormItems as | formItem | }}
{{#eq formItem.psAppDEField null }} {{#if (and (eq formItem.psAppDEField null) (neq formItem.id "srfuf" )) }}
{{lowerCase formItem.id}}: any; {{lowerCase formItem.id}}: any;
{{/eq}} {{/if}}
{{/each}} {{/each}}
} }
\ No newline at end of file
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册