/**
* StatementInfor 查询配置信息
* @typedef {Object} StatementInfor
* @example
* {
"query": "26d21c71-5114-4496-8ca1-a69e56324841", //所属应用id
"id": "ee334220-66d3-4f78-afce-8ccf6b995c8c", //查询id
"name": "测试查询", //名称
"alias": "", //别名
"description": "", //描述
"table": "", //自建表的id
"entityClassName": "com.x.processplatform.core.entity.content.Task", //系统表表名
"entityCategory": "official", //表类型 official(系统表) 或 dynamic(自建表)
"format": "jpql", //语句类型,jpql 或者 script(脚本)
"type": "select", //select/update/delete
"data": "SELECT o FROM Task o where o.person = :person", //查询语句
"countData": "SELECT count(o.id) FROM Task o where o.person = :person", //总数语句
"countScriptText" : "", //总数语句脚本
"scriptText" : "", //查询语句脚本
"viewJson": { ... } //视图相关信息
}
*/
/**
* ViewInfor 视图配置信息
* @typedef {Object} ViewInfor
* @example
* {
"application": "db9fc893-7dbc-4e0f-a617-99089d2c6323", //视图所在应用
"query": "db9fc893-7dbc-4e0f-a617-99089d2c6323", //视图所在应用,同application
"name": "视图自定义测试", //视图名称
"viewName": "视图自定义测试", //视图名称,同name
"isExpand": "no", //如果有分类,默认是否展开开
"id": "705ce967-2f9c-425c-8873-3bd729249e1d", //视图id
"alias": "", //视图别名
"description": "", //视图描述
"display": true, //视图是否显示
"type": "cms", //视图嵌入的数据类型, cms 或 process
"count": 2000, //最多返回2000条
"pageSize": 20, //每页的条数
"createTime": "2019-09-02 10:18:27",
"updateTime": "2020-03-26 15:53:03"
}
*/
/**
* @readonly
* @enum {String} ViewFilterDataLogic
* @property {String} or color for a white square or piece.
* @property {String} and color for a black square or piece.
*/
/**
* ViewFilter 视图过滤条件
* @typedef {Object} ViewFilter
* @property {String} logic - 可选值:“and”或者“or”,表示和前一个条件的逻辑运算关系。
* @property {String} path - 要过滤的data数据的路径。
* @property {String} comparison - 比较运算符,可选值:
*
* {
* "view" : "testView", //(String)必选,视图的名称、别名或ID
* "application" : "test数据中心应用", //(String)必选,视图所在数据应用的名称、别名或ID
* "filter": [ //(Array of Object)可选,对视图进行过滤的条件。json数组格式,每个数组元素描述一个过滤条件。
* {
* "logic":"and",
* "path":"$work.title",
* "comparison":"like",
* "value":"7月",
* "formatType":"textValue"
* }
* ]
* }
*
* @param {Function} callback - 访问成功后的回调函数
* @param {Boolean} [async] - 同步或异步调用。true:异步;false:同步。默认为true。
* @example
* this.view.lookup(view, callback, async);
* @example
* //获取“财务管理”应用中“报销审批数据”视图中的数据
* //过滤条件为标题($work.title)包含包含(like))“7月”。
* this.view.lookup({
* "view": "报销审批数据",
* "application": "财务管理",
* "filter": [
* {
* "logic":"and",
* "path":"$work.title",
* "comparison":"like",
* "value":"7月",
* "formatType":"textValue"
* }
* ]
*}, function(data){
* var result = data.grid; //得到过滤后的数据
* //......
*});
* @example
* //获取“财务管理”应用中“报销审批数据”视图中的数据
* //过滤条件为标题($work.title)包含包含(like))“7月”,并且总金额大于500小于5000
* this.view.lookup({
* "view": "报销审批数据",
* "application": "财务管理",
* "filter": [
* {
* "logic":"and",
* "path":"$work.title",
* "comparison":"like",
* "value":"7月",
* "formatType":"textValue"
* },
* {
* "logic":"and",
* "path":"amount",
* "comparison":"range",
* "value":500,
* "otherValue":5000,
* "formatType":"numberValue"
* },
* ]
*}, function(data){
* var result = data.grid; //得到过滤后的数据
* //......
*});
*/
"lookup": function (view, callback, async) {
var filterList = { "filterList": (view.filter || null) };
MWF.Actions.get("x_query_assemble_surface").loadView(view.view, view.application, filterList, function (json) {
var data = {
"grid": json.data.grid || json.data.groupGrid,
"groupGrid": json.data.groupGrid
};
if (callback) callback(data);
}, null, async);
},
"lookupV1": function (view, callback) {
getLookupAction(function () {
lookupAction.invoke({
"name": "lookup", "async": true, "parameter": { "view": view.view, "application": view.application }, "success": function (json) {
var data = {
"grid": json.data.grid,
"groupGrid": json.data.groupGrid
};
if (callback) callback(data);
}.bind(this)
});
}.bind(this));
},
/**
* 通过视图进行数据选择。
* @method select
* @static
* @param {Object} view - 要访问的视图信息。数据格式如下:
* {
* "view" : "testView", //(String)必选,视图的名称、别名或ID
* "application" : "test数据中心应用", //(String)必选,视图所在数据应用的名称、别名或ID
* "isTitle" : true, //(Boolean)可选,是否显示视图标题。默认true
* "isMulti" : true, //(Boolean)可选,是否允许多选。默认true
* "width" : 700, //(Number)可选,选择框的宽度。默认700
* "height" : 400, //(Number)可选,选择框的高度。默认400
* "caption" : "标题", //(String)可选,选择框的标题
* "filter": [ //(Array of Object)可选,对视图进行过滤的条件。json数组格式,每个数组元素描述一个过滤条件。
* {
* "logic":"and",
* "path":"$work.title",
* "comparison":"like",
* "value":"7月",
* "formatType":"textValue"
* }
* ]
* }
*
* @param {Function} callback - 必选,当选择完成,点击“确定”之后的回调函数。
* @example
* this.view.select(view, callback);
* @example
* this.view.select({
* "application": "物业材料", //数据中心中的应用
* "view": "物业材料视图", //视图的名称
* "isMulti": false, //只允许单选
* }, function(items) {
* //如果选择了某个数据,将数据赋值给表单输入框
* if (items.length) {
* //物料名称,表单中输入框名为“materialName”, 视图中列的名称为“ylmc”
* this.data.materialName = items[0].data.ylmc;
* //规格,表单中输入框名为“specification”, 视图中列的名称为“gg”
* this.data.specification = items[0].data.gg;
* //单价,表单中输入框名为“price”, 视图中列的名称为“dj”
* this.data.price = items[0].data.dj;
* }
* }.bind(this));
*/
"select": function (view, callback, options) {
if (view.view) {
var viewJson = {
"application": view.application || _form.json.application,
"viewName": view.view || "",
"isTitle": (view.isTitle === false) ? "no" : "yes",
"select": (view.isMulti === false) ? "single" : "multi",
"filter": view.filter
};
if (!options) options = {};
options.width = view.width;
options.height = view.height;
options.title = view.caption;
var width = options.width || "700";
var height = options.height || "400";
if (layout.mobile) {
var size = document.body.getSize();
width = size.x;
height = size.y;
options.style = "viewmobile";
}
width = width.toInt();
height = height.toInt();
var size = _form.app.content.getSize();
var x = (size.x - width) / 2;
var y = (size.y - height) / 2;
if (x < 0) x = 0;
if (y < 0) y = 0;
if (layout.mobile) {
x = 20;
y = 0;
}
var _self = this;
MWF.require("MWF.xDesktop.Dialog", function () {
var dlg = new MWF.xDesktop.Dialog({
"title": options.title || "select view",
"style": options.style || "view",
"top": y,
"left": x - 20,
"fromTop": y,
"fromLeft": x - 20,
"width": width,
"height": height,
"html": "",
"maskNode": _form.app.content,
"container": _form.app.content,
"buttonList": [
{
"text": MWF.LP.process.button.ok,
"action": function () {
//if (callback) callback(_self.view.selectedItems);
if (callback) callback(_self.view.getData());
this.close();
}
},
{
"text": MWF.LP.process.button.cancel,
"action": function () { this.close(); }
}
]
});
dlg.show();
if (layout.mobile) {
var backAction = dlg.node.getElement(".MWF_dialod_Action_back");
var okAction = dlg.node.getElement(".MWF_dialod_Action_ok");
if (backAction) backAction.addEvent("click", function (e) {
dlg.close();
}.bind(this));
if (okAction) okAction.addEvent("click", function (e) {
//if (callback) callback(this.view.selectedItems);
if (callback) callback(this.view.getData());
dlg.close();
}.bind(this));
}
MWF.xDesktop.requireApp("query.Query", "Viewer", function () {
this.view = new MWF.xApplication.query.Query.Viewer(dlg.content.getFirst(), viewJson, { "style": "select" }, _form.app, _form.Macro);
}.bind(this));
}.bind(this));
}
}
};
/**
* 你可以通过statement对象,获取执行查询语句或者对查询结果进行选择。
* {
* "name" : "tesStatement", //(String)必选,查询配置的名称、别名或ID
* "mode" : "all", //(String)必选,“all”、“data”或者“count”,all表示同时执行查询语句和总数语句,data表示执行查询语句,count表示执行总数语句
* "page" : 1, //(number)可选,当前页码,默认为1
* "pageSize" : 20, //(number)可选,每页的数据条数,默认为20
* "filter": [ //(Array)可选,对查询进行过滤的条件。json数组格式,每个数组元素描述一个过滤条件,每个元素数据格式如下:
* {
* "path":"o.title",
* "comparison":"like",
* "value":"关于",
* "formatType":"textValue"
* }
* ],
* parameter : {
* "person" : "", //参数名称为下列值时,后台默认赋值,person(当前人),identityList(当前人身份列表),unitList(当前人所在直接组织), unitAllList(当前人所在所有组织), groupList(当前人所在群组)
* "startTime" : (new Date("2020-01-01")), //如果对比的是日期,需要传入 Date 类型
* "applicationName" : "%test%", //如果运算符用的是 like, noLike,模糊查询
* "processName" : "test流程" //其他写确定的值
* }
* }
*
* @param {Function} callback - 访问成功后的回调函数
* @param {Boolean} [async] - 同步或异步调用。true:异步;false:同步。默认为true。
* @example
* this.statement.execute(statement, callback, async);
* @example
* //获取“task”查询中的数据
* //查询语句为 select o from Task o where (o.person = :person) and (o.startTime > :startTime) and (o.applicationName like :applicationName) and (o.processName = :processName)
* //总数语句为 select count(o.id) from Task o where (o.person = :person) and (o.startTime > :startTime) and (o.applicationName like :applicationName) and (o.processName = :processName)
* //过滤条件为标题o.title包含包含(like))“7月”。
* this.statement.execute({
* "name": "task",
* "mode" : "all",
* "filter": [
* {
* "path":"o.title",
* "comparison":"like",
* "value":"7月",
* "formatType":"textValue"
* }
* ],
* "parameter" : {
* "person" : "", //参数名称为下列值时,后台默认赋值,person(当前人),identityList(当前人身份列表),unitList(当前人所在直接组织), unitAllList(当前人所在所有组织), groupList(当前人所在群组)
* "startTime" : (new Date("2020-01-01")), //如果对比的是日期,需要传入 Date 类型
* "applicationName" : "%test%", //如果运算符用的是 like, noLike,模糊查询
* "processName" : "test流程" //其他写确定的值
* }
* }, function(json){
* var count = json.count; //总数语句执行后返回的数字
* var list = json.data; //查询语句后返回的数组
* //......
* });
*/
"execute": function (statement, callback, async) {
var parameter = this.parseParameter(statement.parameter);
var filterList = this.parseFilter(statement.filter, parameter);
var obj = {
"filterList": filterList,
"parameter" : parameter
};
MWF.Actions.load("x_query_assemble_surface").StatementAction.executeV2(
statement.name, statement.mode || "data", statement.page || 1, statement.pageSize || 20, obj,
function (json) {
if (callback) callback(json);
}, null, async);
},
parseFilter : function( filter, parameter ){
if( typeOf(filter) !== "array" )return [];
var filterList = [];
( filter || [] ).each( function (d) {
var parameterName = d.path.replace(/\./g, "_");
var value = d.value;
if( d.comparison === "like" || d.comparison === "notLike" ){
if( value.substr(0, 1) !== "%" )value = "%"+value;
if( value.substr(value.length-1,1) !== "%" )value = value+"%";
parameter[ parameterName ] = value; //"%"+value+"%";
}else{
if( d.formatType === "dateTimeValue" || d.formatType === "datetimeValue"){
value = "{ts '"+value+"'}"
}else if( d.formatType === "dateValue" ){
value = "{d '"+value+"'}"
}else if( d.formatType === "timeValue" ){
value = "{t '"+value+"'}"
}
parameter[ parameterName ] = value;
}
d.value = parameterName;
filterList.push( d );
}.bind(this));
return filterList;
},
parseParameter : function( obj ){
if( typeOf(obj) !== "object" )return {};
var parameter = {};
//传入的参数
for( var p in obj ){
var value = obj[p];
if( typeOf( value ) === "date" ){
value = "{ts '"+value.format("db")+"'}"
}
parameter[ p ] = value;
}
return parameter;
},
/**
* 如果查询的类型是"select",并且配置了查询视图,可以通过本方法进行数据选择。
* @method select
* @static
* @param {Object} statement - 要访问的查询配置的信息。数据格式如下:
*
* {
* "name" : "tesStatement", //(String)必选,查询配置的名称、别名或ID
* "isTitle" : true, //(Boolean)可选,是否显示视图标题。默认true
* "isMulti" : true, //(Boolean)可选,是否允许多选。默认true
* "width" : 700, //(Number)可选,选择框的宽度。默认700
* "height" : 400, //(Number)可选,选择框的高度。默认400
* "caption" : "标题", //(String)可选,选择框的标题
* "filter": [ //(Array)可选,对查询进行过滤的条件。json数组格式,每个数组元素描述一个过滤条件,每个元素数据格式如下:
* {
* "path":"o.title",
* "comparison":"like",
* "value":"关于",
* "formatType":"textValue"
* }
* ],
* parameter : {
* "person" : "", //参数名称为下列值时,后台默认赋值,person(当前人),identityList(当前人身份列表),unitList(当前人所在直接组织), unitAllList(当前人所在所有组织), groupList(当前人所在群组)
* "startTime" : (new Date("2020-01-01")), //如果对比的是日期,需要传入 Date 类型
* "applicationName" : "%test%", //如果运算符用的是 like, noLike,模糊查询
* "processName" : "test流程" //其他写确定的值
* }
* }
*
* @param {Function} callback - 访问成功后的回调函数
* @example
* this.statement.select(statement, callback);
* @example
* this.statement.select({
* "name": "物业材料查询", //查询的名称
* "isMulti": false, //只允许单选
* }, function(items) {
* //如果选择了某个数据,将数据赋值给表单输入框
* if (items.length) {
* //物料名称,表单中输入框名为“materialName”, 查询语句返回的字段名为“ylmc”
* this.data.materialName = items[0].ylmc;
* //规格,表单中输入框名为“specification”, 查询语句返回的字段名为“gg”
* this.data.specification = items[0].gg;
* //单价,表单中输入框名为“price”, 查询语句返回的字段名为“dj”
* this.data.price = items[0].dj;
* }
* }.bind(this));
*/
"select": function (statement, callback, options) {
if (statement.name) {
// var parameter = this.parseParameter(statement.parameter);
// var filterList = this.parseFilter(statement.filter, parameter);
var statementJson = {
"statementId": statement.name || "",
"isTitle": (statement.isTitle === false) ? "no" : "yes",
"select": (statement.isMulti === false) ? "single" : "multi",
"filter": statement.filter,
"parameter": statement.parameter
};
if (!options) options = {};
options.width = statement.width;
options.height = statement.height;
options.title = statement.caption;
var width = options.width || "700";
var height = options.height || "400";
if (layout.mobile) {
var size = document.body.getSize();
width = size.x;
height = size.y;
options.style = "viewmobile";
}
width = width.toInt();
height = height.toInt();
var size = _form.app.content.getSize();
var x = (size.x - width) / 2;
var y = (size.y - height) / 2;
if (x < 0) x = 0;
if (y < 0) y = 0;
if (layout.mobile) {
x = 20;
y = 0;
}
var _self = this;
MWF.require("MWF.xDesktop.Dialog", function () {
var dlg = new MWF.xDesktop.Dialog({
"title": options.title || "select statement view",
"style": options.style || "view",
"top": y,
"left": x - 20,
"fromTop": y,
"fromLeft": x - 20,
"width": width,
"height": height,
"html": "",
"maskNode": _form.app.content,
"container": _form.app.content,
"buttonList": [
{
"text": MWF.LP.process.button.ok,
"action": function () {
//if (callback) callback(_self.view.selectedItems);
if (callback) callback(_self.statement.getData());
this.close();
}
},
{
"text": MWF.LP.process.button.cancel,
"action": function () { this.close(); }
}
]
});
dlg.show();
if (layout.mobile) {
var backAction = dlg.node.getElement(".MWF_dialod_Action_back");
var okAction = dlg.node.getElement(".MWF_dialod_Action_ok");
if (backAction) backAction.addEvent("click", function (e) {
dlg.close();
}.bind(this));
if (okAction) okAction.addEvent("click", function (e) {
//if (callback) callback(this.view.selectedItems);
if (callback) callback(this.statement.getData());
dlg.close();
}.bind(this));
}
MWF.xDesktop.requireApp("query.Query", "Statement", function () {
this.statement = new MWF.xApplication.query.Query.Statement(dlg.content.getFirst(), statementJson, { "style": "select" }, _form.app, _form.Macro);
}.bind(this));
}.bind(this));
}
}
};
//include 引用脚本
//optionsOrName : {
// type : "", 默认为portal, 可以为 portal process cms
// application : "", 门户/流程/CMS的名称/别名/id, 默认为当前应用
// name : "" // 脚本名称/别名/id
//}
//或者name: "" // 脚本名称/别名/id
// if( !window.includedScripts ){
// var includedScripts = window.includedScripts = [];
// }else{
// var includedScripts = window.includedScripts;
// }
var includedScripts = [];
this.include = function (optionsOrName, callback) {
var options = optionsOrName;
if (typeOf(options) == "string") {
options = { name: options };
}
var name = options.name;
var type = (options.type && options.application) ? options.type : "portal";
var application = options.application || _form.json.application;
var key = type + "-" + application + "-" + name;
if (includedScripts.indexOf(key) > -1) {
if (callback) callback.apply(this);
return;
}
//if (includedScripts.indexOf( name )> -1){
// if (callback) callback.apply(this);
// return;
//}
var scriptAction;
switch (type) {
case "portal":
if (this.scriptActionPortal) {
scriptAction = this.scriptActionPortal;
} else {
MWF.require("MWF.xScript.Actions.PortalScriptActions", null, false);
scriptAction = this.scriptActionPortal = new MWF.xScript.Actions.PortalScriptActions();
}
break;
case "process":
if (this.scriptActionProcess) {
scriptAction = this.scriptActionProcess;
} else {
MWF.require("MWF.xScript.Actions.ScriptActions", null, false);
scriptAction = this.scriptActionProcess = new MWF.xScript.Actions.ScriptActions();
}
break;
case "cms":
if (this.scriptActionCMS) {
scriptAction = this.scriptActionCMS;
} else {
MWF.require("MWF.xScript.Actions.CMSScriptActions", null, false);
scriptAction = this.scriptActionCMS = new MWF.xScript.Actions.CMSScriptActions();
}
break;
}
scriptAction.getScriptByName(application, name, includedScripts, function (json) {
if (json.data) {
includedScripts.push(key);
//名称、别名、id
json.data.importedList.each( function ( flag ) {
if( type === "portal" ){
includedScripts.push( type + "-" + json.data.portal + "-" + flag );
if( json.data.portalName )includedScripts.push( type + "-" + json.data.portalName + "-" + flag );
if( json.data.portalAlias )includedScripts.push( type + "-" + json.data.portalAlias + "-" + flag );
}else if( type === "cms" ){
includedScripts.push( type + "-" + json.data.appId + "-" + flag );
if( json.data.appName )includedScripts.push( type + "-" + json.data.appName + "-" + flag );
if( json.data.appAlias )includedScripts.push( type + "-" + json.data.appAlias + "-" + flag );
}else if( type === "process" ){
includedScripts.push( type + "-" + json.data.application + "-" + flag );
if( json.data.appName )includedScripts.push( type + "-" + json.data.appName + "-" + flag );
if( json.data.appAlias )includedScripts.push( type + "-" + json.data.appAlias + "-" + flag );
}
});
includedScripts = includedScripts.concat(json.data.importedList);
MWF.Macro.exec(json.data.text, this);
if (callback) callback.apply(this);
} else {
if (callback) callback.apply(this);
}
}.bind(this), null, false);
};
this.define = function (name, fun, overwrite) {
var over = true;
if (overwrite === false) over = false;
var o = {};
o[name] = { "value": fun, "configurable": over };
MWF.defineProperties(this, o);
}.bind(this);
//仅前台对象-----------------------------------------
//form
/**
* 当查询设计中使用了select语句,并且配置了视图,可以在查询视图中使用本章API。{
* "pages": 3, //总页数
* "perPageCount": 50, //每页的条数
* "currentPageNumber": 1 // 当前页数
* }
*
* @example
* this.queryStatement.getPageInfor();
*/
/**
* 获取当前页的数据。
* @method getPageData
* @memberOf module:queryStatement
* @static
* @return {Object[]} 当前页数据。
* [
{
"id" : "id1",
"title" : "title1"
},
{
"id" : "id2",
"title" : "title2"
},
...
*]
*
* 如:"select id, title from table o" 返回 二维数组:
*[
["id1", "title1"],
["id2", "title2"],
...
*]
*
* @example
* var data = this.queryStatement.getPageData();
*/
/**
* 跳转到指定的页面。
* @method toPage
* @memberOf module:queryStatement
* @static
* @param {Number} pageNumber - 需要跳转的页码。
* @param {Function} [callback ] - 跳转的页面数据加载完成以后的回调方法。
* @example
* var data = this.queryStatement.toPage( pageNumber, callback );
* @example
* // 跳转到第2页并且获取该页的数据。
* this.queryStatement.toPage( 2, function(){
* var data = this.queryStatement.getPageData();
* }.bind(this) )
*/
/**
* 当查询视图设置了允许多选的时候,可以通过这个方法全部选中当前页面的条目。
* @method selectAll
* @memberOf module:queryStatement
* @static
* @example
* this.queryStatement.selectAll();
*/
/**
* 当查询视图设置了允许多选的时候,可以通过这个方法取消选中的条目。
* @method unSelectAll
* @memberOf module:queryStatement
* @static
* @example
* this.queryStatement.unSelectAll();
*/
/**
* 获取选中的条目的数据。
* @method getSelectedData
* @memberOf module:queryStatement
* @static
* @return {Object[]} 选中的条目的数据。
* [
{
"id" : "id1",
"title" : "title1"
},
{
"id" : "id2",
"title" : "title2"
},
...
*]
*
* 如:"select id, title from table o" 返回 二维数组:
*[
["id1", "title1"],
["id2", "title2"],
...
*]
*
* @example
* var data = this.queryStatement.getSelectedData();
*/
/**获取queryStatement对应的DOM对象。
* @method node
* @static
* @methodOf module:queryStatement
* @see module:form.node
*/
/**
* queryView对象可在视图中可用。它的很多方法与form类似。(仅前端脚本可用){
* "pages": 3, //总页数
* "perPageCount": 50, //每页的条数
* "currentPageNumber": 1 // 当前页数
* }
*
* @example
* this.queryView.getPageInfor();
*/
"getPageInfor" : function () { return _form.getPageInfor(); },
/**
* 获取当前页的数据。
* @method getPageData
* @memberOf module:queryView
* @static
* @return {Object[]} 当前页数据。
* [
* {
* "bundle": "099ed3c9-dfbc-4094-a8b7-5bfd6c5f7070", //cms 的 documentId, process 的 jobId
* "data": { //视图中配置的数据
* "title": "考勤管理-配置-统计周期设置", //列名称及列值
* "time": "2018-08-25 11:29:45"
* }
* },
* ...
*]
*
* 有分类的时候,数据格式如下:
*[
* {
* "group": "工作日志", //分类1
* "list": [ //分类下的数据
* {
* "bundle": "001257be-725a-43cf-9679-3892bbab696a", //cms 的 documentId, process 的 jobId
* "data": { //视图中配置的数据
* "title": "标题", //列名称及列值
* "time": "2018-07-31 15:39:13",
* "category": "工作日志"
* }
* },
* ...
* ]
* },
* ...
*]
*
* @example
* var data = this.queryView.getPageData();
*/
"getPageData" : function () { return _form.getPageData(); },
/**
* 跳转到指定的页面。
* @method toPage
* @memberOf module:queryView
* @static
* @param {Number} pageNumber - 需要跳转的页码。
* @param {Function} [callback ] - 跳转的页面数据加载完成以后的回调方法。
* @example
* var data = this.queryView.toPage( pageNumber, callback );
* @example
* // 跳转到第2页并且获取该页的数据。
* this.queryView.toPage( 2, function(){
* var data = this.queryView.getPageData();
* }.bind(this) )
*/
"toPage" : function ( pageNumber, callback ) { return _form.toPage(pageNumber, callback); },
/**
* 当视图设置了允许多选的时候,可以通过这个方法全部选中当前页面的条目。
* @method selectAll
* @memberOf module:queryView
* @static
* @example
* this.queryView.selectAll();
*/
"selectAll" : function () { return _form.selectAll(); },
/**
* 当视图设置了允许多选的时候,可以通过这个方法取消选中的条目。
* @method unSelectAll
* @memberOf module:queryView
* @static
* @example
* this.queryView.unSelectAll();
*/
"unSelectAll" : function () { return _form.unSelectAll(); },
/**
* 获取选中的条目的数据。
* @method getSelectedData
* @memberOf module:queryView
* @static
* @return {Object[]} 选中的条目的数据。
*
* [
{
"bundle": "099ed3c9-dfbc-4094-a8b7-5bfd6c5f7070", //cms 的 documentId, process 的 jobId
"data": { //视图中配置的数据
"title": "考勤管理-配置-统计周期设置", //列名称及列值
"time": "2018-08-25 11:29:45"
}
},
...
* ]
* @example
* var data = this.queryView.getSelectedData();
*/
"getSelectedData" : function () { return _form.getSelectedData(); },
/**
* 设置视图的过滤条件,该方法不能修改视图中默认的过滤条件(在开发视图的时候添加的过滤条件),而是在这上面新增。
* @method setFilter
* @memberOf module:queryView
* @static
* @param {(ViewFilter[]|ViewFilter|Null)} [filter] 过滤条件。[
* {
* "logic":"and",
* "path":"$work.title",
* "comparison":"like",
* "value":"7月",
* "formatType":"textValue"
* }
*]
*
* @param {Function} [callback] 过滤完成并重新加载数据后的回调方法。
* @example
* this.queryView.setFilter( filter );
*/
"setFilter" : function ( filter, callback ) { return _form.setFilter(filter, callback); },
/**
* 增加查询语句where子句的过滤条件。
* @method setStatementFilter
* @memberOf module:queryStatement
* @static
* @param {(StatementFilter[]|Null)} [filter] 过滤条件。[
* {
* "path":"o.title",
* "comparison":"like",
* "value":"关于",
* "formatType":"textValue"
* }
*]
*
* @param {StatementParameter} [parameter] 过滤条件。对查询语句where子句的形如":person"的参数部分进行赋值,参数如下:
*
* //假设语句为 select count(o.id) from Read o where (o.person = :person) and (o.startTime > :startTime) and (o.applicationName like :applicationName) and (o.processName = :processName)。
* //那么可能的参数如下:
* {
* "person" : "", //出于安全考虑参数名称为下列值时,不需要填写参数值,后台默认赋值,person(当前人),identityList(当前人身份列表),unitList(当前人所在直接组织), unitAllList(当前人所在所有组织), groupList(当前人所在群组)
* "startTime" : (new Date("2020-01-01")), //如果对比的是日期,需要传入 Date 类型
* "applicationName" : "%test%", //如果运算符用的是 like, noLike,模糊查询
* "processName" : "test流程" //其他写确定的值
* }
*
* @param {Function} [callback] 过滤完成并重新加载数据后的回调方法。
* @example
* this.queryStatement.setStatementFilter( filter, parameter, callback );
*/
"setStatementFilter" : function ( filter , parameter, callback) { return _form.setFilter(filter, parameter, callback); },
/**
* 把当前视图切换成另外一个视图。
* @method switchView
* @memberOf module:queryView
* @static
* @param {Object} options 需要跳转的参数配置。参数说明如下:
* {
* "application": application, //必选,视图的所在应用id
* "viewName": viewName, //必选,视图的名称
* "filter": [
* {
* "logic":"and",
* "path":"$work.title",
* "comparison":"like",
* "value":"7月",
* "formatType":"textValue"
* }
* ], //可选,增加视图的过滤条件(ViewFilter),如果不传,则使用原视图的配置;如果需要去掉原视图的配置,则传入空数组 []
* "isTitle": "yes", //可选,是否显示t视图的标题行,可选值有:yes no
* "select": "none", //可选,是否允许新视图选择,如果不传,则使用原视图的配置, 可选值有: 不允许选择 none, 单选 single,多选 multi
* "titleStyles": {
* "color" : "red",
* "font-size" : "14px"
* }, //可选,标题行样式,如果不传,则使用原视图的配置
* "itemStyles": {
* "color" : "#333",
* "font-size" : "12px"
* }, //可选,内容行样式,如果不传,则使用原视图的配置
* "isExpand": "no", //可选,默认是否展开分类,如果不传,则使用原视图的配置, 可选值有:yes no
* }
*
* @example
* this.queryView.switchView( options );
*/
"switchView" : function ( options ) { return _form.switchView(options); },
/**
* 把当前查询视图切换成另外一个查询视图。
* @method switchStatement
* @memberOf module:queryStatement
* @static
* @param {Object} options 需要跳转的参数配置。参数说明如下:
* this.queryStatement.switchStatement({
* "statementId": statementId, //必选,查询的名称、别名、id
* "isTitle": "yes", //可选,是否显示视图的标题行,可选值有:yes no
* "select": "multi", //可选,是否允许新视图选择,如果不传,则使用原视图的配置, 可选值有: 不允许选择 none, 单选 single,多选 multi
* "showActionbar": false, //可选,是否显示操作条
* "filter": [ //可选,增加查询语句where子句的过滤条件
* {
* "path": "o.title",
* "title": "标题",
* "type": "filter",
* "comparison": "like",
* "formatType": "textValue",
* "value": "测试"
* }
* ],
* //假设语句为 select count(o.id) from Read o where (o.person = :person) and (o.startTime > :startTime) and (o.applicationName like :applicationName) and (o.processName = :processName)
* "parameter" : { //可选,对查询语句where语句的形如":person"的参数部分进行赋值
* "person" : "", //出于安全考虑参数名称为下列值时,不需要填写参数值,后台默认赋值,person(当前人),identityList(当前人身份列表),unitList(当前人所在直接组织), unitAllList(当前人所在所有组织), groupList(当前人所在群组)
* "startTime" : (new Date("2020-01-01")), //如果对比的是日期,需要传入 Date 类型
* "applicationName" : "%test%", //如果运算符用的是 like, noLike,模糊查询
* "processName" : "test流程" //其他写确定的值
* }
* })
*
* @example
* this.queryStatement.switchStatement( options );
*/
"switchStatement" : function ( options ) { if(_form.switchStatement)_form.switchStatement(options) ; },
/**
* 重新加载视图。
* @method reload
* @methodOf module:queryView
* @static
* @example
* this.queryView.reload();
*/
"reload" : function () { _form.reload(); },
// "getInfor": function () { return ev.pageInfor; },
// "infor": ev.pageInfor,
// "getApp": function () { return _form.app; },
// "app": _form.app,
/**获取queryView对应的DOM对象。
* @method node
* @static
* @methodOf module:queryView
* @see module:form.node
*/
"node": function () { return _form.node; },
// "get": function (name) { return (_form.all) ? _form.all[name] : null; },
// "getWidgetModule": function (widget, moduleName) {
// if (!_form.widgetModules || !_form.widgetModules[widget]) return null;
// var module = _form.widgetModules[widget][moduleName];
// return module || null;
// },
// "getField": function (name) { return _forms[name]; },
// "getAction": function () { return _form.workAction },
"getDesktop": function () { return _form.app ? _form.app.desktop : null},
// "getData": function () { return new MWF.xScript.JSONData(_form.getData()); },
//"save": function(callback){_form.saveWork(callback);},
// "close": function () { _form.closeWork(); },
// "print": function (application, form) {
// _form.printWork(application, form);
// },
/**弹出一个确认框。
* @method confirm
* @static
* @methodOf module:queryView
* @see module:form.confirm
*/
"confirm": function (type, title, text, width, height, ok, cancel, callback, mask, style) {
// var p = MWF.getCenter({"x": width, "y": height});
// e = {"event": {"clientX": p.x,"x": p.x,"clientY": p.y,"y": p.y}};
// _form.confirm(type, e, title, text, width, height, ok, cancel, callback, mask, style);
if ((arguments.length <= 1) || o2.typeOf(arguments[1]) === "string") {
var p = MWF.getCenter({ "x": width, "y": height });
e = { "event": { "clientX": p.x, "x": p.x, "clientY": p.y, "y": p.y } };
_form.confirm(type, e, title, text, width, height, ok, cancel, callback, mask, style);
} else {
e = (arguments.length > 1) ? arguments[1] : null;
title = (arguments.length > 2) ? arguments[2] : null;
text = (arguments.length > 3) ? arguments[3] : null;
width = (arguments.length > 4) ? arguments[4] : null;
height = (arguments.length > 5) ? arguments[5] : null;
ok = (arguments.length > 6) ? arguments[6] : null;
cancel = (arguments.length > 7) ? arguments[7] : null;
callback = (arguments.length > 8) ? arguments[8] : null;
mask = (arguments.length > 9) ? arguments[9] : null;
style = (arguments.length > 10) ? arguments[10] : null;
_form.confirm(type, e, title, text, width, height, ok, cancel, callback, mask, style);
}
},
/**显示一个带关闭按钮的信息框。
* @method alert
* @static
* @methodOf module:queryView
* @see module:form.alert
*/
"alert": function(type, title, text, width, height){
_form.alert(type, title, text, width, height);
},
/**显示一个信息框。
* @method notice
* @static
* @methodOf module:queryView
* @see module:form.notice
*/
"notice": function (content, type, target, where, offset, option) {
_form.notice(content, type, target, where, offset, option);
},
/** 给视图添加事件。
* @method addEvent
* @static
* @methodOf module:queryView
* @see module:form.addEvent
*/
"addEvent": function (e, f) { _form.addEvent(e, f); },
// "openWindow": function (form, app) {
// _form.openWindow(form, app);
// },
// "toPage": function (name, par, nohis) {
// _form.app.toPage(name, par, nohis);
// },
// "toPortal": function (portal, page, par) {
// _form.app.toPortal(portal, page, par);
// },
/**打开一个在流转或已完成的流程实例。
* @method openWork
* @static
* @methodOf module:queryView
* @see module:form.openWork
*/
"openWork": function (id, completedId, title, options) {
var op = options || {};
op.workId = id;
op.workCompletedId = completedId;
op.docTitle = title;
op.appId = "process.Work" + (op.workId || op.workCompletedId);
return layout.desktop.openApplication(this.event, "process.Work", op);
},
/**根据流程的jobId打开工作。
* @method openJob
* @static
* @methodOf module:queryView
* @see module:form.openJob
*/
"openJob": function (id, choice, options) {
var workData = null;
o2.Actions.get("x_processplatform_assemble_surface").listWorkByJob(id, function (json) {
if (json.data) workData = json.data;
}.bind(this), null, false);
if (workData) {
var len = workData.workList.length + workData.workCompletedList.length;
if (len) {
if (len > 1 && choice) {
var node = new Element("div", { "styles": { "padding": "20px", "width": "500px" } }).inject(_form.node);
workData.workList.each(function (work) {
var workNode = new Element("div", {
"styles": {
"background": "#ffffff",
"border-radius": "10px",
"clear": "both",
"margin-bottom": "10px",
"height": "40px",
"padding": "10px 10px"
}
}).inject(node);
var html = "" +
"{
* "id": "267a7bcc-f27a-49c8-8364-f1c12061085a", //人员ID
* "genderType": "m", //性别
* "icon": "...", //头像
* "signature": "", //个人签名
* "name": "胡起", //姓名
* "employee": "huqi", //员工号
* "unique": "huqi", //唯一标识
* "distinguishedName": "xx@huqi@P", //人员全称
* "superior": "", //上级人员id
* "changePasswordTime": "2017-03-13", //修改密码时间
* "lastLoginTime": "2019-01-02", //最后登录时间
* "mail": "huqi@zoneland.net", //邮件地址
* "weixin": "", //微信号
* "qq": "", //QQ
* "mobile": "18057190078", //手机号码
* "officePhone": "", //办公电话
* "createTime": "2017-03-13 12:27:04", //人员创建时间
* "updateTime": "2019-01-02 13:00:04", //人员修改时间
* "token": "...", //当前用户token
* "roleList": [ //人员角色
* "ProcessPlatformCreator@ProcessPlatformCreatorSystemRole@R",
* "ProcessPlatformManager@ProcessPlatformManagerSystemRole@R",
* "Manager@ManagerSystemRole@R"
* ],
* "identityList": [ //人员身份列表
* {
* "id": "709328c8-44a0-4f5d-a3fa-3c31208232d5", //身份ID
* "name": "xx", //身份名称
* "unique": "709328c8-44a0-4f5d-a3fa-3c31208232d5", //身份唯一标识
* "distinguishedName": "xx@709328c8-44a0-4f5d-a3fa-3c31208232d5@I", //身份全称
* "person": "267a7bcc-f27a-49c8-8364-f1c12061085a", //人员ID
* "unit": "d5356fd4-6675-45ad-9a00-5eff20b83dfa", //所属组织ID
* "unitName": "开发部", //所属组织名称
* "unitLevel": 2, //所属组织层级
* "unitLevelName": "兰德纵横/开发部", //所属组织层次名
* "major": true //是否是主身份
* },
* {
* "id": "343510af-57c2-4a55-a1f2-f30d7af6d284",
* "description": "",
* "name": "xx",
* "unique": "343510af-57c2-4a55-a1f2-f30d7af6d284",
* "distinguishedName": "xx@343510af-57c2-4a55-a1f2-f30d7af6d284@I",
* "person": "267a7bcc-f27a-49c8-8364-f1c12061085a",
* "unit": "108b1b7c-cc78-49ab-9ab1-e67073bd6541",
* "unitName": "开发部",
* "unitLevel": 2,
* "unitLevelName": "浙江兰德纵横/开发部",
* "major": false
* }
* ]
* }
*
*/
this.session = layout.desktop.session;
/**
* 本文档说明如何在前台脚本中使用Actions调用平台的RESTful服务。
* "x_processplatform_assemble_surface" //流程平台相关服务根
*
* @return {String} 对应服务根的host。如:http://127.0.0.1:20020
* @example
* var actions = this.Actions.getHost( root );
*/
/**
* 平台预置了Actions对象用于调用平台提供的服务,您可以使用this.Actions.load来获取这些方法。
* @method load
* @methodOf module:Actions
* @static
* @param {String} root 平台RESTful服务根,具体服务列表参见:http://server:20030/x_program_center/jest/list.html。
* 如:
*
* "x_processplatform_assemble_surface" //流程平台相关服务根
*
* @return {Object} 返回action对象,用于后续服务调用
* @example
* var actions = o2.Actions.load( root );
* //或
* var actions = this.Actions.load( root );
* @example
* //获取流程平台服务对象。
* var processAction = this.Actions.load("x_processplatform_assemble_surface");
* @example
*
* 我们可以找到TaskAction的V2ListPaging服务是列式当前用户待办的服务。
* "x_processplatform_assemble_surface" //流程平台相关服务根
*
* @return {String} 对应服务根的host。如:http://127.0.0.1:20020
* @example
* var actions = o2.Actions.get( root );
* actions[ methodName ]( arguements );
*
* or
*
* o2.Actions.get( root )[methodName]( arguements );
* @example
* methodName :(string)方法名称。
* arguements : 见load方法的arguements说明
* @example
*