/** * Work 数据结构,流程实例对象 * @typedef {Object} Work * @example * { "id": "854e2c22-718e-48bb-98db-96f4b43e7ee8", //流程实例ID "splitValue": "xxxxxxxxxxxxxx", //流程拆分后的拆分依据 "title": "xx7月北京出差报销审批", //流程实例名称 "startTime": "2018-09-07 14:03:22", //流程启动时间 "startTimeMonth": "2018-09", //流程启动的月份 "creatorPerson": "xx@huqi@P", //流程实例创建人 "creatorIdentity": "xx@481c9edc-5fb5-41f1-b5c2-6ea609082cdb@I", //流程实例创建人身份 "creatorUnit": "xx@c448d8bb-98b8-4305-9d3f-12537723cfcc@U", //流程实例创建人所在组织 "creatorUnitLevelName": "浙江兰德纵横/开发部", //流程实例创建人所在组织层次 "application": "1dc23336-6be6-402b-bed6-36e707a1dd17", //流程应用ID "applicationName": "财务管理", //流程应用名称 "applicationAlias": "finance", //流程应用别名 "process": "2207db11-dddf-4ebd-864d-3819f3e173c6", //流程ID "processName": "报销审批流程", //流程名称 "processAlias": "", //流程别名 "activity": "13d15daf-2ac5-4c1b-a669-1607a0e5ed15", //当前活动ID "activityType": "manual", //当前活动类型 "activityName": "部门领导审核", //当前活动名称 "activityAlias": "", //当前活动别名 "activityDescription": "", //当前活动描述 "activityArrivedTime": "2018-09-27 22:49:21", //当前活动到达时间 "serial": "", //编号 "workStatus": "processing", //流程实例状态 "errorRetry": 0, //流转失败重试次数 "splitting": false, //流程是否拆分 "form": "db3b2766-93a1-4058-b522-0edb922bd84f", //流程展现所使用的表单 "manualTaskIdentityList" : "张三@db3b2766-93a1-4058-b522-0edb922bd84f@I", //预期的处理人 "manualTaskIdentityText" : "张三" //当前处理人身份合并文本,用','分割,超长截断,此字段仅用于显示当前工作的处理人,不索引. } */ /** * WorkCompleted 数据结构,已结束流程实例对象 * @typedef {Object} WorkCompleted * @example * { "id": "be0195f1-f2e2-4eac-911c-99897a43ff8f", //流程实例ID "title": "xx7月北京出差报销审批", //流程实例名称 "startTime": "2018-09-19 16:14:16", //流程启动时间 "startTimeMonth": "2018-09", //流程启动的月份 "completedTime": "2018-09-19 16:15:28", //流程完成时间 "completedTimeMonth": "2018-09", //流程完成的月份 "creatorPerson": "xx@huqi@P", //流程实例创建人 "creatorIdentity": "xx@481c9edc-5fb5-41f1-b5c2-6ea609082cdb@I", //流程实例创建人身份 "creatorUnit": "xx@c448d8bb-98b8-4305-9d3f-12537723cfcc@U", //流程实例创建人所在组织 "creatorUnitLevelName": "浙江兰德纵横/开发部", //流程实例创建人所在组织层次 "application": "1dc23336-6be6-402b-bed6-36e707a1dd17", //流程应用ID "applicationName": "财务管理", //流程应用名称 "applicationAlias": "finance", //流程应用别名 "process": "2207db11-dddf-4ebd-864d-3819f3e173c6", //流程ID "processName": "报销审批流程", //流程名称 "processAlias": "", //流程别名 "serial": "", //编号 "form": "320be1ca-ee49-478f-a751-f65ab67cf818", //流程展现所使用的表单 } */ /** * Task数据结构,待办任务对象 * @typedef {Object} Task * @example * { "id": "dd476045-7c79-44f7-9dba-f51d322de40f", //待办ID "title": "XX7月北京出差报销审批", //流程实例标题 "startTime": "2018-09-27 22:49:22", //待办到达时间 "startTimeMonth": "2018-09", //待办到达的月份 "work": "854e2c22-718e-48bb-98db-96f4b43e7ee8", //流程实例ID "application": "1dc23336-6be6-402b-bed6-36e707a1dd17", //流程应用ID "applicationName": "财务管理", //流程应用名称 "applicationAlias": "finance", //流程应用别名 "process": "2207db11-dddf-4ebd-864d-3819f3e173c6", //流程ID "processName": "报销审批流程", //流程名称 "processAlias": "", //流程别名 "serial": "", //流程编号 "person": "XXX@huqi@P", //待办人名称 "identity": "XX@481c9edc-5fb5-41f1-b5c2-6ea609082cdb@I", //待办人身份 "unit": "XX@c448d8bb-98b8-4305-9d3f-12537723cfcc@U", //待办人所在组织 "activity": "13d15daf-2ac5-4c1b-a669-1607a0e5ed15", //当前活动的ID "activityName": "部门领导审核", //当前活动的名称 "activityAlias": "", //当前活动的别名 "activityDescription": "", //当前活动描述 "activityType": "manual", //当前活动类型 "creatorPerson": "XX@huqi@P", //流程实例创建人 "creatorIdentity": "XX@481c9edc-5fb5-41f1-b5c2-6ea609082cdb@I", //流程实例创建人的身份 "creatorUnit": "XX@c448d8bb-98b8-4305-9d3f-12537723cfcc@U", //流程实例创建人所在组织 "expired": false, //是否已超时 "urged": false, //是否进行催办 "routeList": [ //可选的路由ID "89b58fe0-6dcb-4fe7-8c2e-3f77204df6d4", "f3105b7a-2929-4682-aab8-15fef5ea0f23" ], "routeNameList": [ //可选的路由名称 "退回申请人", "送财务部门复审" ], "routeOpinionList": [ //可选路由的默认意见 "", "" ], "first" : true, //是否是第一条待办. "properties": { //属性对象存储字段 "prevTaskIdentity": "张三@903dbb04-085c-4bb1-9c24-3009bd5f7372@I", //提交的处理人 "prevTaskIdentityList": [ //上一步处理人 "张三@903dbb04-085c-4bb1-9c24-3009bd5f7372@I" ], "prevTaskList": [ //上一步任务信息 { "routeName": "送办理", "unit": "产品研发组@320189216@U", "identity": "张三@903dbb04-085c-4bb1-9c24-3009bd5f7372@I", "person": "张三@zhangsan@P", "opinion": "", "startTime": "2020-09-29 17:03:14", "completedTime": "2020-09-29 17:04:38" } ], "prevTask": { //提交的任务信息 "routeName": "送办理", "unit": "产品研发组@320189216@U", "identity": "张三@903dbb04-085c-4bb1-9c24-3009bd5f7372@I", "person": "张三@zhangsan@P", "opinion": "", "startTime": "2020-09-29 17:03:14", "completedTime": "2020-09-29 17:04:38" } } * } */ /** * Read 数据结构,待阅任务对象 * @typedef {Object} Read * @example * { "id": "dd476045-7c79-44f7-9dba-f51d322de40f", //待阅ID "title": "XX7月北京出差报销审批", //流程实例标题 "startTime": "2018-09-27 22:49:22", //待阅产生时间 "startTimeMonth": "2018-09", //待阅产生的月份 "work": "854e2c22-718e-48bb-98db-96f4b43e7ee8", //流程实例ID "application": "1dc23336-6be6-402b-bed6-36e707a1dd17", //流程应用ID "applicationName": "财务管理", //流程应用名称 "applicationAlias": "finance", //流程应用别名 "process": "2207db11-dddf-4ebd-864d-3819f3e173c6", //流程ID "processName": "报销审批流程", //流程名称 "processAlias": "", //流程别名 "completed": false, //流程是否已完成 "serial": "", //流程编号 "person": "XXX@huqi@P", //待阅人名称 "identity": "XX@481c9edc-5fb5-41f1-b5c2-6ea609082cdb@I", //待阅人身份 "unit": "XX@c448d8bb-98b8-4305-9d3f-12537723cfcc@U", //待阅人所在组织 "activity": "13d15daf-2ac5-4c1b-a669-1607a0e5ed15", //当前活动的ID "activityName": "部门领导审核", //当前活动的名称 "activityAlias": "", //当前活动的别名 "activityDescription": "", //当前活动描述 "activityType": "manual", //当前活动类型 "creatorPerson": "XX@huqi@P", //流程实例创建人 "creatorIdentity": "XX@481c9edc-5fb5-41f1-b5c2-6ea609082cdb@I", //流程实例创建人的身份 "creatorUnit": "XX@c448d8bb-98b8-4305-9d3f-12537723cfcc@U" //流程实例创建人所在组织 } */ /** * Activity 数据结构,流程实例所在的活动节点对象 * @typedef {Object} Activity * @example * { "id": "801087c5-a4e6-4b91-bf4d-a81cdaa04471", //节点ID "name": "办理", //节点名称 "description": "", //节点描述 "alias": "", //节点别名 "resetRange": "department", //重置处理人范围 "resetCount": 0, //重置处理人数字 "allowReset": true, //是否允许重置 "manualMode": "single" //处理方式 单人single, 并行parallel, 串行queue, grab抢办 } */ /** WorkControl  流程实例的权限对象。 * @typedef {Object} WorkControl * @example * { "allowVisit": true, //是否允许访问 "allowProcessing": true, //是否允许流转 "allowReadProcessing": false, //是否有待阅 "allowSave": true, //是否允许保存业务数据 "allowReset": false, //是否允许重置处理人 "allowRetract": false, //是否允许撤回 "allowReroute": false, //是否允许调度 "allowDelete": true, //是否允许删除流程实例 "allowRollback": false, //是否允许流程回溯 "allowAddSplit": false, //是否允许增加分支 "allowPress": false, //是否允许催办 } */ /** * FormInfor  表单的基本信息。 * @typedef {Object} FormInfor * @example { "id": "db3b2766-93a1-4058-b522-0edb922bd84f", //表单ID "name": "报销申请表单", //表单名称 "alias": "报销申请表单", //表单别名 "description": "", //表单描述 "application": "1dc23336-6be6-402b-bed6-36e707a1dd17", //应用ID "lastUpdatePerson": "XX@huqi@P", //最后修改人 "lastUpdateTime": "2018-09-30 22:46:30", //最后修改时间 "icon": "...", //表单图标 } */ MWF.xScript = MWF.xScript || {}; MWF.xScript.Environment = function(ev){ var _data = ev.data; var _form = ev.form; var _forms = ev.forms; this.library = COMMON; //this.library.version = "4.0"; this.power = { "isManager": MWF.AC.isProcessManager() || _form.businessData.control.allowReroute, "isReseter": _form.businessData.control.allowReset, "isDelete": _form.businessData.control.allowDeleteWork, "isPront": true, "isPrint": true }; //data var getJSONData = function(jData){ return new MWF.xScript.JSONData(jData, function(data, key, _self){ var p = {"getKey": function(){return key;}, "getParent": function(){return _self;}}; while (p && !_forms[p.getKey()]) p = p.getParent(); if (p) if (p.getKey()) if (_forms[p.getKey()]) _forms[p.getKey()].resetData(); }, "", null, _form); }; this.setData = function(data){ /** * data对象是流程平台中,流程实例的业务数据,以及内容管理平台中,实例的业务数据。
* 这些数据一般情况下是通过您创建的表单收集而来的,也可以通过脚本创建和增删改查。
* data对象基本上是一个JSON对象,您可以用访问JSON对象的方法访问他对象的所有数据,但增加和删除数据时略有不同。 * @module data * @example * //您可以在表单或流程的各个嵌入脚本中,通过this来获取当前实例的业务数据,如下: * var data = this.data; */ this.data = getJSONData(data); /** * 访问或修改data对象的数据。

* data数据用于存储表单获取的数据,所有属性都是动态的,其格式和访问方式都和JSON类似。
* 在表单脚本中使用data对象,实现了data和表单可编辑元素的双向绑定。
* 改变data对象,会自动更新表单元素,修改表单可编辑元素,也会自动修改data对象。 * @member {String|Number} [[property]] * @memberOf module:data * @instance * @example * var value = this.data.subject; //获取名为subject的数据值 * * //将subject的值修改为'123'。 * //需要注意的是,用这种方式创建新字段,必须要在当前表单上有一个名为‘subject’的字段组件。 * //如果表单上没有该组件,可以使用this.data.add('subject','123',true)。给已有字段赋值则没有这个限制。 * this.data.subject = '123'; * * @example * * 获取流程文档中的数据网格的值
* 如有以下数据网格: * * 其数据网格设计如下(数据网格id为:datagrid): * * * //获取流程文档中的数据网格的值 * var data = this.data.datagrid; * * //获取到的data值格式如下: * { * "data": [ * { * "amountCol": { "amount": "12000" }, * "countCol": { "number": "10" }, * "nameCol": { "name": "手机" }, * "priceCol": { "price": "1200" } * }, * { * "amountCol": { "amount": "15000" }, * "countCol": { "number": "5" }, * "nameCol": { "name": "电脑" }, * "priceCol": { "price": "3000" } * } * ], * "total": { * "amountCol": "27000", * "countCol": "15" * } * } * * * //获取到数据网格中的其他数据: * * //获取数据网格中的第一条数据 * var data = this.data.datagrid.data[0]; * * //获取数据网格中的第一条数据的 nameCol 列的值 * var data = this.data.datagrid.data[0].nameCol.name; * * //获取数据网格中的 amountCol 列的总计值 * var data = this.data.datagrid.total.amountCol; * *@example * * 修改数据网格中的数据
* 经过本样例修改后,数据网格将变为:
* * * //修改数据网格中的第一条数据的 nameCol 列的值 * this.data.datagrid.data[0].nameCol.name='平板电脑'; */ /**保存data对象。 * @instance * @method add * @memberOf module:data * @param {(String|Number)} key - 要添加的新的数据节点名称或数组索引号。 * @param {(String|Number|Array|JsonObject)} value - 新的数据节点的值。 * @param {Boolean} [overwrite] - 如果要添加的节点已经存在,是否覆盖。默认为 false。 * @return {(String|Number|Array|JsonObject)} 新添加的数据节点或原有的同名节点。 * @example * var newData = this.data.add(key, value, overwrite); * @example * //为data添加一个名为"remark"值为"I am remark"的数据 * this.data.add("remark", "I am remark"); * @example * //为data添加一个名为"person"的Object对象数据 * var person = this.data.add("person", {}); * person.add("name", "Tom"); * person.add("age", 23); * * //或者可以这样 * var person = this.data.add("person", {name: "Tom", "age": "23"}); * @example * //为data添加一个名为"orders"的数组对象数据 * var orders = this.data.add("orders", []); * orders.add({name: "phone", count: 5}); * orders.add({name: "computer", count: 10}); * orders[0].add("count", 10, true); //将第一条数据的count修改为10 * * //或者可以这样 * var orders = this.data.add("orders", [ * {name: "phone", count: 5}, * {name: "computer", count: 10} * ]); * //将第一条数据修改为name为mobile; count为10 * orders.add(0, {name: "mobile", count: 10}, true); */ /**保存data对象。 * @method save * @static * @memberOf module:data * @param {Function} [callback] - 保存成功后的回调函数。 * @example * this.data.save(function(json){ * this.form.notice("save success!", "success") *}); */ this.data.save = function(callback){ _form.saveFormData(callback) // var formData = { // "data": data, // "sectionList": _form.getSectionList() // }; // _form.workAction.saveSectionData(function(){if (callback) callback();}.bind(this), null, (ev.work.id || ev.workCompleted.id), formData); } }; this.setData(_data); //task //this.task = ev.task; //this.task.process = function(routeName, opinion, callback){ // _form.submitWork(routeName, opinion, callback); //}; //inquiredRouteList //this.inquiredRouteList = null; //workContext /** * 你可以通过workContext获取和流程相关的流程实例对象数据。 * @module workContext * @example * //您可以在表单或流程的各个嵌入脚本中,通过this来获取当前流程实例数据,如下: * var context = this.workContext; */ this.workContext = { /** * 获取当前流程实例对象:work对象或workCompleted对象。 * @method getWork * @static * @return {(Work|WorkCompleted)} 流程实例对象;如果流程已结束,返回已结束的流程实例对象. * @example * var work = this.workContext.getWork(); */ "getWork": function(){return ev.work || ev.workCompleted;}, /** * 获取当前流程实例所在的活动节点对象:activity对象。 * @method getActivity * @static * @return {(Activity|Null)} 当前流程实例所在的活动节点对象,如果当前流程实例已流转完成,则返回null. * @example * var activity = this.workContext.getActivity(); */ "getActivity": function(){return ev.activity || null;}, /** * 当前流程实例正在流转中,并且当前用户有待办,则返回当前用户的待办对象,否则返回null。 * @summary 获取当前流程与当前用户相关的待办对象:task对象。 * @method getTask * @static * @return {(Task|Null)} 当前用户的待办任务对象:task。当前用户没有对此流程实例的待办时,或流程实例已经流转结束,返回null. * @example * var task = this.workContext.getTask(); */ "getTask": function(){return ev.task || null;}, /** * 获取当前流程实例的所有待办对象。如果流程实例已流转完成,则返回一个空数组。 * @method getTaskList * @static * @param {Function} [callback] 正确获取待办数组的回调,如果有此参数,本方法以异步执行,否则同步执行 * @param {Function} [error] 获取待办数组出错时的回调。 * @return {(Task[])} 待办任务列表. * @example * //本样例以同步执行 * var taskList = this.workContext.getTaskList(); * @example * //本样例以异步执行 * this.workContext.getTaskList( function(taskList){ * //taskList 为待办数组 * }); */ "getTaskList": function(callback, error){ var cb = (callback && o2.typeOf(callback)==="function") ? callback : null; var ecb = (error && o2.typeOf(error)==="function") ? error : null; var list; o2.Actions.get("x_processplatform_assemble_surface").listTaskByWork(ev.work.id, function(json){ list = json.data; if (cb) cb(list); }, ecb, !!cb); return list; }, /** * 根据当前工作的job获取当前流程实例的所有待办对象。如果流程实例已流转完成,则返回一个空数组。 * @method getTaskListByJob * @static * @param {Function} [callback] 正确获取待办数组的回调,如果有此参数,本方法以异步执行,否则同步执行 * @param {Function} [error] 获取待办数组出错时的回调。 * @return {(Task[])} 待办任务列表. * @example * //本样例以同步执行 * var taskList = this.workContext.getTaskListByJob(); * @example * //本样例以异步执行 * this.workContext.getTaskListByJob( function(taskList){ * //taskList 为待办数组 * }); */ "getTaskListByJob": function(callback, error){ var cb = (callback && o2.typeOf(callback)==="function") ? callback : null; var ecb = (error && o2.typeOf(error)==="function") ? error : null; var list; o2.Actions.get("x_processplatform_assemble_surface").listTaskByJob(ev.work.job, function(json){ list = json.data; if (cb) cb(list); }, ecb, !!cb); return list; }, /** * 获取当前流程实例的所有已办对象。如果流程实例没有任何人处理过,则返回一个空数组。 * @method getTaskCompletedList * @static * @param {Function} [callback] 正确获取已办数组的回调,如果有此参数,本方法以异步执行,否则同步执行 * @param {Function} [error] 获取已办数组出错时的回调。 * @return {(TaskCompleted[])} 已办任务列表. * @example * //本样例以同步执行 * var taskCompletedList = this.workContext.getTaskCompletedList(); * @example * //本样例以异步执行 * this.workContext.getTaskCompletedList( function(taskCompletedList){ * //taskCompletedList 为待办数组 * }); */ "getTaskCompletedList": function(callback, error){ var cb = (callback && o2.typeOf(callback)==="function") ? callback : null; var ecb = (error && o2.typeOf(error)==="function") ? error : null; var list; o2.Actions.get("x_processplatform_assemble_surface").listTaskCompletedByWork(ev.work.id, function(json){ list = json.data; if (cb) cb(list); }, ecb, !!cb); return list; }, /** * 根据当前工作的job获取当前流程实例的所有已办对象。如果流程实例没有任何人处理过,则返回一个空数组。 * @method getTaskCompletedListByJob * @static * @param {Function} [callback] 正确获取已办数组的回调,如果有此参数,本方法以异步执行,否则同步执行 * @param {Function} [error] 获取已办数组出错时的回调。 * @return {(TaskCompleted[])} 已办任务列表. * @example * //本样例以同步执行 * var taskCompletedList = this.workContext.getTaskCompletedListByJob(); * @example * //本样例以异步执行 * this.workContext.getTaskCompletedListByJob( function(taskCompletedList){ * //taskCompletedList 为待办数组 * }); */ "getTaskCompletedListByJob": function(callback, error){ var cb = (callback && o2.typeOf(callback)==="function") ? callback : null; var ecb = (error && o2.typeOf(error)==="function") ? error : null; var list; o2.Actions.get("x_processplatform_assemble_surface").listTaskCompletedByJob(ev.work.job, function(json){ list = json.data; if (cb) cb(list); }, ecb, !!cb); return list; }, /** * @summary 获取当前流程实例的所有待阅对象数组。如果流程实例无待阅,则返回一个空数组。 * @method getReadList * @static * @param {Function} [callback] 正确获取待阅数组的回调,如果有此参数,本方法以异步执行,否则同步执行 * @param {Function} [error] 获取待阅数组出错时的回调。 * @return {(Read[])} 当前流程实例的所有待阅对象数组. * @example * //本样例以同步执行 * var readList = this.workContext.getReadList(); * @example * //本样例以异步执行 * this.workContext.getReadList( function(readList){ * //readList 为待阅数组 * }); */ "getReadList": function(callback, error){ var cb = (callback && o2.typeOf(callback)==="function") ? callback : null; var ecb = (error && o2.typeOf(error)==="function") ? error : null; var list; o2.Actions.get("x_processplatform_assemble_surface").listReadByWork(ev.work.id, function(json){ list = json.data; if (cb) cb(list); }, ecb, !!cb); return list; }, /** * @summary 根据当前工作的job获取当前流程实例的所有待阅对象。如果流程实例无待阅,则返回一个空数组。 * @method getReadListByJob * @static * @param {Function} [callback] 正确获取待阅数组的回调,如果有此参数,本方法以异步执行,否则同步执行 * @param {Function} [error] 获取待阅数组出错时的回调。 * @return {(Read[])} 当前流程实例的所有待阅对象数组. * @example * //本样例以同步执行 * var readList = this.workContext.getReadListByJob(); * @example * //本样例以异步执行 * this.workContext.getReadListByJob( function(readList){ * //readList 为待阅数组 * }); */ "getReadListByJob": function(callback, error){ var cb = (callback && o2.typeOf(callback)==="function") ? callback : null; var ecb = (error && o2.typeOf(error)==="function") ? error : null; var list; o2.Actions.get("x_processplatform_assemble_surface").listReadByJob(ev.work.job, function(json){ list = json.data; if (cb) cb(list); }, ecb, !!cb); return list; }, /** * @summary 获取当前流程实例的所有已阅对象。如果流程实例没有已阅,则返回一个空数组。 * @method getReadCompletedList * @static * @param {Function} [callback] 正确获取已阅数组的回调,如果有此参数,本方法以异步执行,否则同步执行 * @param {Function} [error] 获取已阅数组出错时的回调。 * @return {(ReadCompleted[])} 当前流程实例的所有已阅对象数组. * @example * //本样例以同步执行 * var readCompletedList = this.workContext.getReadCompletedList(); * @example * //本样例以异步执行 * this.workContext.getReadCompletedList( function(readCompletedList){ * //readCompletedList 为已阅数组 * }); */ "getReadCompletedList": function(callback, error){ var cb = (callback && o2.typeOf(callback)==="function") ? callback : null; var ecb = (error && o2.typeOf(error)==="function") ? error : null; var list; o2.Actions.get("x_processplatform_assemble_surface").listReadCompletedByWork(ev.work.id, function(json){ list = json.data; if (cb) cb(list); }, ecb, !!cb); return list; }, /** * @summary 根据当前工作的job获取当前流程实例的所有已阅对象。如果流程实例没有已阅,则返回一个空数组。 * @method getReadCompletedListByJob * @static * @param {Function} [callback] 正确获取已阅数组的回调,如果有此参数,本方法以异步执行,否则同步执行 * @param {Function} [error] 获取已阅数组出错时的回调。 * @return {(ReadCompleted[])} 当前流程实例的所有已阅对象数组. * @example * //本样例以同步执行 * var readCompletedList = this.workContext.getReadCompletedListByJob(); * @example * //本样例以异步执行 * this.workContext.getReadCompletedListByJob( function(readCompletedList){ * //readCompletedList 为已阅数组 * }); */ "getReadCompletedListByJob": function(callback, error){ var cb = (callback && o2.typeOf(callback)==="function") ? callback : null; var ecb = (error && o2.typeOf(error)==="function") ? error : null; var list; o2.Actions.get("x_processplatform_assemble_surface").listReadCompletedByJob(ev.work.job, function(json){ list = json.data; if (cb) cb(list); }, ecb, !!cb); return list; }, "getJobTaskList": this.getTaskListByJob, "getJobReadList": this.getReadListByJob, "getJobTaskCompletedList": this.getTaskCompletedListByJob, "getJobReadCompletedList": this.getReadCompletedListByJob, /** * @summary 获取当前人对流程实例的权限。 * @method getControl * @static * @return {WorkControl} 流程实例权限对象. * @example * var control = this.workContext.getControl(); */ "getControl": function(){return ev.control;}, /** * @summary 获取当前流程实例的所有流程记录(WorkLog)。 * @method getWorkLogList * @static * @return {WorkLog[]} 流程记录对象. * @example * var workLogList = this.workContext.getWorkLogList(); */ "getWorkLogList": function(){return ev.workLogList;}, /** * @summary 获取当前流程实例的所有流程记录(Record)。 * @method getRecordList * @static * @return {Record[]} 流程记录(Record)对象. * @example * var workLogList = this.workContext.getRecordList(); */ "getRecordList": function(){return ev.recordList;}, /** * @summary 获取当前流程实例的附件对象列表。 * @method getAttachmentList * @static * @return {WorkAttachmentData[]} 附件数据. * @example * var attachmentList = this.workContext.getAttachmentList(); */ "getAttachmentList": function(){return ev.attachmentList;}, /** * @summary 获取当前待办的可选路由。与task对象中的routeNameList取值相同。 * @method getRouteList * @static * @return {String[]} 路由字符串数组. * @example * var routeList = this.workContext.getRouteList(); */ "getRouteList": function(){return (ev.task) ? ev.task.routeNameList: null;}, "getInquiredRouteList": function(){return null;}, /** * @summary 重新设置流程实例标题。。 * @method setTitle * @static * @param {String} title - 路由字符串数组. * @example * this.workContext.setTitle("标题"); */ "setTitle": function(title){ if (!this.workAction){ MWF.require("MWF.xScript.Actions.WorkActions", null, false); this.workAction = new MWF.xScript.Actions.WorkActions(); } this.workAction.setTitle(ev.work.id, {"title": title}); } }; this.workContent = this.workContext; var _redefineWorkProperties = function(work){ if (work){ work.creatorPersonDn = work.creatorPerson ||""; work.creatorUnitDn = work.creatorUnit ||""; work.creatorUnitDnList = work.creatorUnitList ||""; work.creatorIdentityDn = work.creatorIdentity ||""; var o = { "creatorPerson": {"get": function(){return this.creatorPersonDn.substring(0, this.creatorPersonDn.indexOf("@"));}}, "creatorUnit": {"get": function(){return this.creatorUnitDn.substring(0, this.creatorUnitDn.indexOf("@"));}}, "creatorDepartment": {"get": function(){return this.creatorUnitDn.substring(0, this.creatorUnitDn.indexOf("@"));}}, "creatorIdentity": {"get": function(){return this.creatorIdentityDn.substring(0, this.creatorIdentityDn.indexOf("@"));}}, // "creatorUnitList": { // "get": function(){ // var v = []; // this.creatorUnitDnList.each(function(dn){ // v.push(dn.substring(0, dn.indexOf("@"))) // }); // return v; // } // }, "creatorCompany": {"get": function(){ if (this.creatorUnitLevel){ var level = this.creatorUnitLevel.split("/"); return level[0]; }else{ return this.creatorUnitDn.substring(0, this.creatorUnitDn.indexOf("@")); } }} }; MWF.defineProperties(work, o); } return work; }; var _redefineTaskProperties = function(task){ if (task){ task.personDn = task.person || ""; task.unitDn = task.unit || ""; task.unitDnList = task.unitList || ""; task.identityDn = task.identity || ""; var o = { "person": {"get": function(){return this.personDn.substring(0, this.personDn.indexOf("@"));}}, "unit": {"get": function(){return this.unitDn.substring(0, this.unitDn.indexOf("@"));}}, "department": {"get": function(){return this.unitDn.substring(0, this.unitDn.indexOf("@"));}}, "identity": {"get": function(){return this.identityDn.substring(0, this.identityDn.indexOf("@"));}}, // "unitList": { // "get": function(){ // var v = []; // this.unitDnList.each(function(dn){ // v.push(dn.substring(0, dn.indexOf("@"))) // }); // return v; // } // }, "company": {"get": function(){return this.unitList[0];}} }; MWF.defineProperties(task, o); } return task; }; _redefineWorkProperties(this.workContext.getWork()); _redefineTaskProperties(_redefineWorkProperties(this.workContext.getTask())); //dict this.Dict = MWF.xScript.createDict(_form.json.application); //unit var orgActions = null; var getOrgActions = function(){ // if (!orgActions){ // MWF.xDesktop.requireApp("Org", "Actions.RestActions", null, false); // orgActions = new MWF.xApplication.Org.Actions.RestActions (); // } if (!orgActions){ MWF.require("MWF.xScript.Actions.UnitActions", null, false); orgActions = new MWF.xScript.Actions.UnitActions(); } }; var getNameFlag = function(name){ var t = typeOf(name); if (t==="array"){ var v = []; name.each(function(id){ v.push((typeOf(id)==="object") ? (id.distinguishedName || id.id || id.unique || id.name) : id); }); return v; }else{ return [(t==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name]; } }; /** * 你可以通过workContext获取和流程相关的流程实例对象数据。 * @module this.org * @example * //您可以在表单或流程的各个嵌入脚本中,通过this来获取当前流程实例数据,如下: * var context = this.workContext; */ this.org = { //群组*************** //获取群组--返回群组的对象数组 /** 根据群组标识获取对应的群组对象数组:group对象数组 */ getGroup: function(name, async){ getOrgActions(); var data = {"groupList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; v = (v && v.length===1) ? v[0] : v if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listGroup(data, cb, null, !!async); return (!!async) ? promise : v; // var v = null; // orgActions.listGroup(data, function(json){v = json.data;}, null, false); // return (v && v.length===1) ? v[0] : v; }, //查询下级群组--返回群组的对象数组 //nested 布尔 true嵌套下级;false直接下级;默认false; listSubGroup: function(name, nested, async){ getOrgActions(); var data = {"groupList": getNameFlag(name)}; var v = null; // var cb = ((async && o2.typeOf(async)=="function") ? (async.isAG ? async : async.ag()) : null) || function(json){ // v = json.data; // return v; // }.ag().catch(function(json){ return json; }); var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise; if (nested){ promise = orgActions.listSubGroupNested(data, cb, null, !!async); }else{ promise = orgActions.listSubGroupDirect(data, cb, null, !!async); } return (!!async) ? promise : v; // var v = null; // if (nested){ // orgActions.listSubGroupNested(data, function(json){v = json.data;}, null, false); // }else{ // orgActions.listSubGroupDirect(data, function(json){v = json.data;}, null, false); // } // return v; }, //查询上级群组--返回群组的对象数组 //nested 布尔 true嵌套上级;false直接上级;默认false; listSupGroup:function(name, nested, async){ getOrgActions(); var data = {"groupList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise if (nested){ var promise = orgActions.listSupGroupNested(data, cb, null, !!async); }else{ var promise = orgActions.listSupGroupDirect(data, cb, null, !!async); } return (!!async) ? promise : v; // var v = null; // if (nested){ // orgActions.listSupGroupNested(data, function(json){v = json.data;}, null, false); // }else{ // orgActions.listSupGroupDirect(data, function(json){v = json.data;}, null, false); // } // return v; }, //人员所在群组(嵌套)--返回群组的对象数组 listGroupWithPerson:function(name, async){ getOrgActions(); var data = {"personList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listGroupWithPerson(data, cb, null, !!async); return (!!async) ? promise : v; // var v = null; // orgActions.listGroupWithPerson(data, function(json){v = json.data;}, null, false); // return v; }, //群组是否拥有角色--返回true, false groupHasRole: function(name, role, async){ getOrgActions(); nameFlag = (typeOf(name)==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name; var data = {"group":nameFlag,"roleList":getNameFlag(role)}; var v = false; var cb = function(json){ v = json.data.value; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.groupHasRole(data, cb, null, !!async); return (!!async) ? promise : v; // var v = false; // orgActions.groupHasRole(data, function(json){v = json.data.value;}, null, false); // return v; }, //角色*************** //获取角色--返回角色的对象数组 getRole: function(name, async){ getOrgActions(); var data = {"roleList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; v = (v && v.length===1) ? v[0] : v; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listRole(data, cb, null, !!async); return (!!async) ? promise : v; // var v = null; // orgActions.listRole(data, function(json){v = json.data;}, null, false); // return (v && v.length===1) ? v[0] : v; }, //人员所有角色(嵌套)--返回角色的对象数组 listRoleWithPerson:function(name, async){ getOrgActions(); var data = {"personList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listRoleWithPerson(data, cb, null, !!async); return (!!async) ? promise : v; // var v = null; // orgActions.listRoleWithPerson(data, function(json){v = json.data;}, null, false); // return v; }, //人员*************** //人员是否拥有角色--返回true, false personHasRole: function(name, role, async){ getOrgActions(); nameFlag = (typeOf(name)==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name; var data = {"person":nameFlag,"roleList":getNameFlag(role)}; var v = false; var cb = function(json){ v = json.data.value; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listRoleWithPerson(data, cb, null, !!async); return (!!async) ? promise : v; // var v = false; // orgActions.personHasRole(data, function(json){v = json.data.value;}, null, false); // return v; }, //获取人员--返回人员的对象数组 getPerson: function(name, async){ getOrgActions(); var data = {"personList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; v = (v && v.length===1) ? v[0] : v; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listPerson(data, cb, null, !!async); return (!!async) ? promise : v; // var v = null; // orgActions.listPerson(data, function(json){v = json.data;}, null, false); // return (v && v.length===1) ? v[0] : v; }, //查询下级人员--返回人员的对象数组 //nested 布尔 true嵌套下级;false直接下级;默认false; listSubPerson: function(name, nested, async){ getOrgActions(); var data = {"personList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise; if (nested){ promise = orgActions.listPersonSubNested(data, cb, null, !!async); }else{ promise = orgActions.listPersonSubDirect(data, cb, null, !!async); } return (!!async) ? promise : v; }, //查询上级人员--返回人员的对象数组 //nested 布尔 true嵌套上级;false直接上级;默认false; listSupPerson: function(name, nested, async){ getOrgActions(); var data = {"personList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise; if (nested){ promise = orgActions.listPersonSupNested(data, cb, null, !!async); }else{ promise = orgActions.listPersonSupDirect(data, cb, null, !!async); } return (!!async) ? promise : v; }, //获取群组的所有人员--返回人员的对象数组 listPersonWithGroup: function(name, async){ getOrgActions(); var data = {"groupList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listPersonWithGroup(data, cb, null, !!async); return (!!async) ? promise : v; }, //获取角色的所有人员--返回人员的对象数组 listPersonWithRole: function(name, async){ getOrgActions(); var data = {"roleList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise promise = orgActions.listPersonWithRole(data, cb, null, !!async); return (!!async) ? promise : v; }, //获取身份的所有人员--返回人员的对象数组 listPersonWithIdentity: function(name, async){ getOrgActions(); var data = {"identityList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listPersonWithIdentity(data, cb, null, !!async); return (!!async) ? promise : v; }, //获取身份的所有人员--返回人员的对象数组或人员对象 getPersonWithIdentity: function(name, async){ getOrgActions(); var data = {"identityList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; v = (v && v.length===1) ? v[0] : v; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listPersonWithIdentity(data, cb, null, !!async); return (!!async) ? promise : v; }, //查询组织成员的人员--返回人员的对象数组 //nested 布尔 true嵌套的所有成员;false直接成员;默认false; listPersonWithUnit: function(name, nested, async){ getOrgActions(); var data = {"unitList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise; if (nested){ promise = orgActions.listPersonWithUnitNested(data, cb, null, !!async); }else{ promise = orgActions.listPersonWithUnitDirect(data, cb, null, !!async); } return (!!async) ? promise : v; }, //根据属性查询人员--返回人员的对象数组 //name string 属性名 //value string 属性值 listPersonWithAttribute: function(name, value, async){ getOrgActions(); var data = {"name": name, "attribute": value}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listPersonWithAttribute(data, cb, null, !!async); return (!!async) ? promise : v; }, //根据属性查询人员--返回人员的全称数组 //name string 属性名 //value string 属性值 listPersonNameWithAttribute: function(name, value, async){ getOrgActions(); var data = {"name": name, "attribute": value}; var v = null; var cb = function(json){ v = json.data.personList; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listPersonWithAttributeValue(data, cb, null, !!async); return (!!async) ? promise : v; }, //人员属性************ //添加人员属性值(在属性中添加values值,如果没有此属性,则创建一个) appendPersonAttribute: function(person, attr, values, success, failure, async){ getOrgActions(); var personFlag = (typeOf(person)==="object") ? (person.distinguishedName || person.id || person.unique || person.name) : person; var data = {"attributeList":values,"name":attr,"person":personFlag}; var cb = function(json){ if (success) return success(json); }.ag().catch(function(xhr, text, error){ if (failure) return failure(xhr, text, error); }); orgActions.appendPersonAttribute(data, cb, null, !!async); }, //设置人员属性值(将属性值修改为values,如果没有此属性,则创建一个) setPersonAttribute: function(person, attr, values, success, failure, async){ getOrgActions(); var personFlag = (typeOf(person)==="object") ? (person.distinguishedName || person.id || person.unique || person.name) : person; var data = {"attributeList":values,"name":attr,"person":personFlag}; var cb = function(json){ if (success) return success(json); }.ag().catch(function(xhr, text, error){ if (failure) return failure(xhr, text, error); }); orgActions.setPersonAttribute(data, cb, null, !!async); }, //获取人员属性值 getPersonAttribute: function(person, attr, async){ getOrgActions(); var personFlag = (typeOf(person)==="object") ? (person.distinguishedName || person.id || person.unique || person.name) : person; var data = {"name":attr,"person":personFlag}; var v = null; var cb = function(json){ v = json.data.attributeList; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.getPersonAttribute(data, cb, null, !!async); return (!!async) ? promise : v; }, //列出人员所有属性的名称 listPersonAttributeName: function(name, async){ getOrgActions(); var data = {"personList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data.nameList; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listPersonAttributeName(data, cb, null, !!async); return (!!async) ? promise : v; }, //列出人员的所有属性 listPersonAllAttribute: function(name, async){ getOrgActions(); var data = {"personList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listPersonAllAttribute(data, cb, null, !!async); return (!!async) ? promise : v; }, //身份********** //获取身份 getIdentity: function(name, async){ getOrgActions(); var data = {"identityList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; v = (v && v.length===1) ? v[0] : v; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listIdentity(data, cb, null, !!async); return (!!async) ? promise : v; }, //列出人员的身份 listIdentityWithPerson: function(name, async){ getOrgActions(); var data = {"personList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listIdentityWithPerson(data, cb, null, !!async); return (!!async) ? promise : v; }, //查询组织成员身份--返回身份的对象数组 //nested 布尔 true嵌套的所有成员;false直接成员;默认false; listIdentityWithUnit: function(name, nested, async){ getOrgActions(); var data = {"unitList": getNameFlag(name)}; var v = null; // var cb = function(json){ // v = json.data; // if (async && o2.typeOf(async)=="function") return async(v); // return v; // }.ag().catch(function(json){ return json; }); var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var method = (nested) ? "listIdentityWithUnitNested" : "listIdentityWithUnitDirect"; var promise = orgActions[method](data, cb, null, !!async); promise.name = "org"; // // if (nested){ // orgActions.listIdentityWithUnitNested(data, cb, null, !!async); // }else{ // orgActions.listIdentityWithUnitDirect(data, cb, null, !!async); // } return (!!async) ? promise : v; }, //组织********** //获取组织 getUnit: function(name, async){ getOrgActions(); var data = {"unitList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; v = (v && v.length===1) ? v[0] : v; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listUnit(data, cb, null, !!async); return (!!async) ? promise : v; }, //查询组织的下级--返回组织的对象数组 //nested 布尔 true嵌套下级;false直接下级;默认false; listSubUnit: function(name, nested, async){ getOrgActions(); var data = {"unitList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise; if (nested){ promise = orgActions.listUnitSubNested(data, cb, null, !!async); }else{ promise = orgActions.listUnitSubDirect(data, cb, null, !!async); } return (!!async) ? promise : v; }, //查询组织的上级--返回组织的对象数组 //nested 布尔 true嵌套上级;false直接上级;默认false; //async 布尔 true异步请求 listSupUnit: function(name, nested, async){ getOrgActions(); var data = {"unitList": getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise; if (nested){ promise = orgActions.listUnitSupNested(data, cb, null, !!async); }else{ promise = orgActions.listUnitSupDirect(data, cb, null, !!async); } return (!!async) ? promise : v; // if (callback){ // if (nested){ // orgActions.listUnitSupNested(data, function(json){v = json.data; o2.runCallback(callback, "success", [v], this);}); // }else{ // orgActions.listUnitSupDirect(data, function(json){v = json.data; o2.runCallback(callback, "success", [v], this);}); // } // }else{ // var v = null; // if (nested){ // orgActions.listUnitSupNested(data, function(json){v = json.data;}, null, false); // }else{ // orgActions.listUnitSupDirect(data, function(json){v = json.data;}, null, false); // } // return v; // } }, //根据个人身份获取组织 //flag 数字 表示获取第几层的组织 // 字符串 表示获取指定类型的组织 // 空 表示获取直接所在的组织 getUnitByIdentity: function(name, flag, async){ getOrgActions(); var getUnitMethod = "current"; var v; if (flag){ if (typeOf(flag)==="string") getUnitMethod = "type"; if (typeOf(flag)==="number") getUnitMethod = "level"; } var cb; var promise; switch (getUnitMethod){ case "current": var data = {"identityList":getNameFlag(name)}; // var cb = ((async && o2.typeOf(async)=="function") ? (async.isAG ? async : async.ag()) : null) || function(json){ // v = json.data; v=(v&&v.length===1) ? v[0] : v; return v; // }.ag().catch(function(json){ return json; }); cb = function(json){ v = json.data; v=(v&&v.length===1) ? v[0] : v; if (async && o2.typeOf(async)=="function") return async(v); return v; }; promise = orgActions.listUnitWithIdentity(data, cb, null, !!async); break; case "type": var data = {"identity":(typeOf(name)==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name,"type":flag}; cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; // var cb = ((async && o2.typeOf(async)=="function") ? (async.isAG ? async : async.ag()) : null) || function(json){ // v = json.data; return v; // }.ag().catch(function(json){ return json; }); promise = orgActions.getUnitWithIdentityAndType(data, cb, null, !!async); break; case "level": var data = {"identity":(typeOf(name)==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name,"level":flag}; cb = function(json){ v = json.data; v=(v&&v.length===1) ? v[0] : v; if (async && o2.typeOf(async)=="function") return async(v); return v; }; // var cb = ((async && o2.typeOf(async)=="function") ? (async.isAG ? async : async.ag()) : null) || function(json){ // v = json.data; return v; // }.ag().catch(function(json){ return json; }); promise = orgActions.getUnitWithIdentityAndLevel(data, cb, null, !!async); break; } return (!!async) ? promise : v; }, //列出身份所在组织的所有上级组织 listAllSupUnitWithIdentity: function(name, async){ getOrgActions(); var data = {"identityList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listUnitSupNestedWithIdentity(data, cb, null, !!async); return (!!async) ? promise : v; }, //获取人员所在的所有组织 listUnitWithPerson: function(name, async){ getOrgActions(); var data = {"personList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listUnitWithPerson(data, cb, null, !!async); return (!!async) ? promise : v; }, //列出人员所在组织的所有上级组织 listAllSupUnitWithPerson: function(name, async){ getOrgActions(); var data = {"personList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listUnitSupNestedWithPerson(data, cb, null, !!async); return (!!async) ? promise : v; }, //根据组织属性,获取所有符合的组织 listUnitWithAttribute: function(name, attribute, async){ getOrgActions(); var data = {"name":name,"attribute":attribute}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; promise = orgActions.listUnitWithAttribute(data, cb, null, !!async); return (!!async) ? promise : v; }, //根据组织职务,获取所有符合的组织 listUnitWithDuty: function(name, id, async){ getOrgActions(); var data = {"name":name,"identity":(typeOf(id)==="object") ? (id.distinguishedName || id.id || id.unique || id.name) : id}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listUnitWithDuty(data, cb, null, !!async); return (!!async) ? promise : v; }, //组织职务*********** //获取指定的组织职务的身份 getDuty: function(duty, id, async){ getOrgActions(); var data = {"name":duty,"unit":(typeOf(id)==="object") ? (id.distinguishedName || id.id || id.unique || id.name) : id}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.getDuty(data, cb, null, !!async); return (!!async) ? promise : v; }, //获取身份的所有职务名称 listDutyNameWithIdentity: function(name, async){ getOrgActions(); var data = {"identityList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data.nameList; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listDutyNameWithIdentity(data, cb, null, !!async); return (!!async) ? promise : v; }, //获取组织的所有职务名称 listDutyNameWithUnit: function(name, async){ getOrgActions(); var data = {"unitList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data.nameList; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listDutyNameWithUnit(data, cb, null, !!async); return (!!async) ? promise : v; }, //获取组织的所有职务 listUnitAllDuty: function(name, async){ getOrgActions(); var data = {"unitList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listUnitAllDuty(data, cb, null, !!async); return (!!async) ? promise : v; }, //列出顶层组织 listTopUnit: function(async){ var action = MWF.Actions.get("x_organization_assemble_control"); var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = action.listTopUnit(cb, null, !!async); return (!!async) ? promise : v; }, //组织属性************** //添加组织属性值(在属性中添加values值,如果没有此属性,则创建一个) appendUnitAttribute: function(unit, attr, values, success, failure, async){ getOrgActions(); var unitFlag = (typeOf(unit)==="object") ? (unit.distinguishedName || unit.id || unit.unique || unit.name) : unit; var data = {"attributeList":values,"name":attr,"unit":unitFlag}; var cb = function(json){ if (success) return success(json); }.ag().catch(function(xhr, text, error){ if (failure) return failure(xhr, text, error); }); orgActions.appendPersonAttribute(data, cb, null, !!async); // orgActions.appendUnitAttribute(data, function(json){ // if (json.data.value){ // if (success) success(); // }else{ // if (failure) failure(null, "", "append values failed"); // } // }, function(xhr, text, error){ // if (failure) failure(xhr, text, error); // }, false); }, //设置组织属性值(将属性值修改为values,如果没有此属性,则创建一个) setUnitAttribute: function(unit, attr, values, success, failure, async){ getOrgActions(); var unitFlag = (typeOf(unit)==="object") ? (unit.distinguishedName || unit.id || unit.unique || unit.name) : unit; var data = {"attributeList":values,"name":attr,"unit":unitFlag}; var cb = function(json){ if (success) return success(json); }.ag().catch(function(xhr, text, error){ if (failure) return failure(xhr, text, error); }); orgActions.setUnitAttribute(data, cb, null, !!async); // orgActions.setUnitAttribute(data, function(json){ // if (json.data.value){ // if (success) success(); // }else{ // if (failure) failure(null, "", "append values failed"); // } // }, function(xhr, text, error){ // if (failure) failure(xhr, text, error); // }, false); }, //获取组织属性值 getUnitAttribute: function(unit, attr, async){ getOrgActions(); var unitFlag = (typeOf(unit)==="object") ? (unit.distinguishedName || unit.id || unit.unique || unit.name) : unit; var data = {"name":attr,"unit":unitFlag}; var v = null; var cb = function(json){ v = json.data.attributeList; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.getUnitAttribute(data, cb, null, !!async); return (!!async) ? promise : v; }, //列出组织所有属性的名称 listUnitAttributeName: function(name, async){ getOrgActions(); var data = {"unitList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data.nameList; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listUnitAttributeName(data, cb, null, !!async); return (!!async) ? promise : v; }, //列出组织的所有属性 listUnitAllAttribute: function(name, async){ getOrgActions(); var data = {"unitList":getNameFlag(name)}; var v = null; var cb = function(json){ v = json.data; if (async && o2.typeOf(async)=="function") return async(v); return v; }; var promise = orgActions.listUnitAllAttribute(data, cb, null, !!async); return (!!async) ? promise : v; } }; this.Action = (function(){ var actions = []; return function(root, json){ var action = actions[root] || (actions[root] = new MWF.xDesktop.Actions.RestActions("", root, "")); action.getActions = function(callback){ if (!this.actions) this.actions = {}; Object.merge(this.actions, json); if (callback) callback(); }; this.invoke = function(option){ action.invoke(option) } } })(); this.service = { "jaxwsClient":{}, "jaxrsClient":{} }; var lookupAction = null; var getLookupAction = function(callback){ if (!lookupAction){ MWF.require("MWF.xDesktop.Actions.RestActions", function(){ lookupAction = new MWF.xDesktop.Actions.RestActions("", "x_processplatform_assemble_surface", ""); lookupAction.getActions = function(actionCallback){ this.actions = { //"lookup": {"uri": "/jaxrs/view/flag/{view}/application/flag/{application}"}, //"getView": {"uri": "/jaxrs/view/{id}/design"} "lookup": {"uri": "/jaxrs/queryview/flag/{view}/application/flag/{application}/execute", "method":"PUT"}, "getView": {"uri": "/jaxrs/queryview/flag/{view}/application/flag/{application}"} }; if (actionCallback) actionCallback(); }; if (callback) callback(); }); }else{ if (callback) callback(); } }; this.view = { "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)); }, "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)); } } }; this.statement = { "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": 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 : "", 默认为process, 可以为 portal process cms // application : "", 门户/流程/CMS的名称/别名/id, 默认为当前应用 // name : "" // 脚本名称/别名/id //} //或者name: "" // 脚本名称/别名/id // if( !window.includedScripts ){ // var includedScripts = window.includedScripts = []; // }else{ // var includedScripts = window.includedScripts; // } var includedScripts = []; var _includeSingle = function( optionsOrName , callback, async){ var options = optionsOrName; if( typeOf( options ) == "string" ){ options = { name : options }; } var name = options.name; var type = ( options.type && options.application ) ? options.type : "process"; 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, !!async); } this.include = function( optionsOrName , callback, async){ if (o2.typeOf(optionsOrName)=="array"){ if (!!async){ var count = optionsOrName.length; var loaded = 0; optionsOrName.each(function(option){ _includeSingle.apply(this, [option, function(){ loaded++; if (loaded>=count) if (callback) callback.apply(this);; }.bind(this), true]); }.bind(this)); }else{ optionsOrName.each(function(option){ _includeSingle.apply(this, [option]); }.bind(this)); if (callback) callback.apply(this); } }else{ _includeSingle.apply(this, [optionsOrName , callback, async]) } }; 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); //如果前端事件有异步调用,想要在异步调用结束后继续运行页面加载, //可在调用前执行 var resolve = this.wait(); //在异步调用结束后 执行 resolve.cb(); //目前只有表单的queryload事件支持此方法。 this.wait = function(){ var _self = this; resolve = {"cb": _self.goon.bind(_self)}; var setResolve = function(callback){ resolve.cb = callback; }.bind(this); this.target.event_resolve = setResolve; return resolve; } //和this.wait配合使用, //如果没有异步,则resolve.cb方法不存在, //所以在回调中中使用this.goon();使表单继续加载 this.goon = function(){ this.target.event_resolve = null; } //仅前台对象----------------------------------------- //form /** * form对象可在流程表单或内容管理表单中可用。(仅前端脚本可用)。 * @module form * @example * //您可以在流程表单和内容管理的前端脚本中,通过this来获取form对象,如下: * var form = this.form; */ this.page = this.form = { /** * 获取当前表单的基本信息。 * @method getInfor * @static * @return {FormInfor} 表单的基本信息. * @example * var form = this.form.getInfor(); */ "getInfor": function(){return ev.formInfor;}, "infor": ev.formInfor, /** * 获取打开当前文档的component对象。平台中每一个窗口应用,就是一个component对象。此处获取到的对象为x_component_process_Work。 * @method getApp * @static * @return {x_component_process_Work}打开当前文档的component对象. * @example * var app = this.form.getApp(); //所有component对象都有以下方法。 app.openInNewWindow(); //在新窗口中打开当前应用 app.setCurrent(); //将当前应用设置为激活状态 app.minSize(); //应用窗口最小化 app.maxSize(); //应用窗口最大化 app.restoreSize(); //应用窗口还原 app.refresh(); //刷新应用 app.close(); //关闭应用 app.setTitle(str); //设置应用标题 app.dialog(option); //弹出一个对话框(详见MWF.widget.Dialog) //显示一个通知消息 app.notice(content, type, target, where, offset); //显示一个确认框 app.confirm(type, e, title, text, width, height, ok, cancel); //弹出一个信息框 app.alert(type, e, title, text, width, height); //为应用绑定一个事件 app.addEvent(type, fun); */ "getApp": function(){return _form.app;}, "app": _form.app, /** * 获取Form对应的DOM对象。 * @method node * @static * @return {HTMLDivElement} 当前form对应的div对象. * @example * var node = this.form.node(); */ "node": function(){return _form.node;}, /** * 获取表单是否可编辑。只读。 * @member readonly * @static * @return {Boolean} 是否只读. * @example * var readonly = this.form.readonly; */ "readonly": _form.options.readonly, /** * 获取表单元素对象。
* * * * * * * * * * *
Actionbar(操作条)Address(地址输入框)Attachment(附件框)Button(按钮)
Calendar(日期输入框)Checkbox(多选按钮)Combox(组合框)Datagrid(数据网格)
Div(容器)Htmleditor(富文本编辑框)Html(内置html)Iframe(嵌入Iframe)
Image(图片)Label(文本)Log(流程意见)Monitor(流程监控)
Number(数字输入框)Office(office控件)Opinion(意见框)Org(人员组织选择)
Radio(单选按钮)Select(选择框)Sidebar(侧边操作条)Stat(统计组件)
Subform(子表单)Tab(分页)Table(表格)Textarea(多行输入)
Textfield(文本输入框)Tree(树状控件)View(视图组件)ViewSelector(视图选择组件)
Documenteditor(公文编辑器)ImageClipper(图片编辑器)
* @method get * @static * @return {FormComponent} 请查看本文档的Classes导航下的FormComponents。 * @param {String} name 字段标识 * @example * var field = this.form.get("subject"); */ "get": function(name){return (_form.all) ? _form.all[name] : null;}, /** * 获取表单中可输入的字段元素对象。
* * * * * *
Address(地址输入框)Attachment(附件框)Calendar(日期输入框)Checkbox(多选按钮)
Combox(组合框)Datagrid(数据网格)Htmleditor(富文本编辑框)Number(数字输入框)
Org(人员组织选择)Radio(单选按钮)Select(选择框)Textarea(多行输入)
Textfield(文本输入框)
* @method getField * @static * @return {FormComponent} 请查看本文档的Classes导航下的FormComponents。 * @param {String} name 字段标识 * @example * var field = this.form.getField("subject"); */ "getField": function(name){return _forms[name];}, "getAction": function(){return _form.workAction}, "getDesktop": function(){return _form.app.desktop}, /**获取业务数据 * @method getData * @static * @see module:data * @example * var data = this.form.getData(); * @return {Object} 返回表单绑定的业务数据。 */ "getData": function(){return new MWF.xScript.JSONData(_form.getData());}, /**保存当前表单所绑定的业务数据。
* this.form.save()会触发 beforeSave和afterSave事件,因此在beforeSave和afterSave中不允许使用本方法。 * @method save * @static * @param {Function} [callback] - 保存后的回调 * @param {Boolean} [silent] - 是否静默,否提示保存成功,默认为false * @example * this.form.save(function(){ * //do someting * }, true); */ "save": function(callback, silent){_form.saveWork(callback, silent); }, /** *关闭当前表单 * @method close * @static * @example * this.form.close(); */ "close": function(){_form.closeWork();}, /**本校验不包括校验意见,校验路由;通常用在弹出提交界面时候的校验 * @summary 根据表单中所有组件的校验设置和“流转校验”脚本进行校验。 * @method verify * @static * @example * if( !this.form.verify() ){ * return false; * } * @return {Boolean} 是否通过校验 */ "verify": function(){ return !(!_form.formCustomValidation("", "") || !_form.formValidation("", "")); }, /**对当前表单打开的流程实例进行流转。(仅流程表单中可用)
* 可以通过this.workContext.getControl().allowProcessing来判断当前用户是否有权限进行流转。
* this.form.process()会触发 beforeSave、afterSave、beforeProcess、afterProcess事件,因此在上述事件中不允许使用本方法。 * @method process * @static * @param {Object} [option] - 流程的相关数据,如果不带此参数,则弹出路由选择和意见填写框
* 格式如下:

     {
            "routeName": "", //流转到下一步要选择的路由名称
            "opinion": "", //流转意见
            "callback": function(){} //流转完成后的回调方法
      }
     
* @example //不带参数,弹出路由选择和意见填写框 this.form.process(); * @example //带参数,流转 this.form.process({ "routeName": "送审批", "opinion": "同意", "callback": function(json){ this.form.notice("process success", "success"); }.bind(this) }); */ "process": function(option){ var op = _form.getOpinion(); var mds = op.medias; if (option){ _form.submitWork(option.routeName, option.opinion, mds, option.callback, option.processor, null, option.appendTaskIdentityList, option.processorOrgList, option.callbackBeforeSave ); }else{ _form.processWork(); } }, /**对当前文档的待办重新设定处理人。(仅流程表单中可用)
* 可以通过this.workContext.getControl().allowReset来判断当前用户是否有权限重置处理人。
* this.form.reset()会触发 beforeReset、afterReset事件,因此在上述事件中不允许使用本方法。 * @method reset * @static * @param {Object} [option] - 进行重置处理人的相关参数,如果不带此参数,弹出重置处理人对话框
* 格式如下:

         {
            "names": "", //{Array|String} 要重置给哪些身份
            "opinion": "", //流转意见
            "success ": function(){}, //重置成功后的回调方法
            "failure ": function(){} //重置失败后的回调方法
        }
         
* @example //不带参数,弹出重置处理人对话框 this.form.reset(); * @example //带参数,直接调用后台服务重置 this.form.reset({ "names": ["张三(综合部)"], "opinion": "授权处理", "success": function(json){ this.form.notice("reset success", "success"); }.bind(this), "failure": function(xhr, text, error){ //xhr--HttpRequest请求对象 //text--HttpResponse内容文本 //error--错误信息 this.form.notice("reset failure:"+error, "error"); }.bind(this) }); */ "reset": function(option){ if (!option){ if (_form.businessData.control["allowReset"]) _form.resetWork(); }else{ _form.resetWorkToPeson(option.names, option.opinion, option.keep, option.success, option.failure); } }, /**撤回文档操作,上一个处理人收回已经流转下去的文件。(仅流程表单中可用)
* 这个操作只允许上一个处理人在流转文件之后,下一个处理人未处理的时候执行。
* 可以通过this.workContext.getControl().allowRetract来判断当前用户是否有权限撤回。
* this.form.retract()会触发 beforeRetract、afterRetract事件,因此在上述事件中不允许使用本方法。 * @method retract * @static * @param {Object} [option] - 进行撤回的相关参数,如果不提供option参数,则弹出撤回对话框。
* 格式如下:

         {
            "success ": function(){}, //撤回成功后的回调方法
            "failure ": function(){} //撤回失败后的回调方法
        }
         
* @example //不带参数,则弹出撤回对话框 this.form.retract(); * @example //带参数,直接调用后台服务撤回 this.form.retract({ "success": function(json){ this.form.notice("retract success", "success"); }.bind(this), "failure": function(xhr, text, error){ //xhr--HttpRequest请求对象 //text--HttpResponse内容文本 //error--错误信息 this.form.notice("retract failure: "+error, "error"); }.bind(this) }); */ "retract": function(option){ if (!option){ if (_form.businessData.control["allowRetract"]) _form.retractWork(); }else{ _form.doRetractWork(option.success, option.failure); } }, /**在已拆分的工作上添加分支。(仅流程表单中可用)
* 可以通过this.workContext.getControl().allowAddSplit来判断当前用户是否有权限。
* @method addSplit * @static * @param {Object} [option] - 添加分支的相关参数,如果不提供option参数,则弹出添加分支对话框。
* 格式如下:

         {
            "value" : [], //splitValueList 添加的拆分值,拆分值取决于流程拆分节点的设置
            "trimExist" : true, //排除已经存在的拆分值.
            "success ": function(){}, //执行成功后的回调方法
            "failure ": function(){} //执行失败后的回调方法
        }
         
* @example //不带参数,则弹出添加分支对话框 this.form.addSplit(); * @example //带参数,直接添加分支 this.form.addSplit({ "value" : ["开发部@kfb@U"], "trimExist" : true, "success": function(json){ this.form.notice("addSplit success", "success"); }.bind(this), "failure": function(xhr, text, error){ //xhr--HttpRequest请求对象 //text--HttpResponse内容文本 //error--错误信息 this.form.notice("addSplit failure: "+error, "error"); }.bind(this) }); */ "addSplit": function(option){ if (!option){ if (_form.businessData.control["allowAddSplit"]) _form.addSplit(); }else{ _form.addSplitWork(option.value, option.trimExist, option.success, option.failure); } }, "rollback": function(option){ if (!option){ if (_form.businessData.control["allowRollback"]) _form.rollback(); }else{ _form.doRollbackActionInvoke(option.log, option.flow, option.success, option.failure); } }, /**删除当前工作文档。(仅流程表单中可用)
* 可以通过this.workContext.getControl().allowDeleteWork来判断当前用户是否有权限删除文档。
* @method deleteWork * @static * @param {Object} [option] - 删除相关参数,如果不提供option参数,则弹出删除对话框。
* 格式如下:

         {
            "success ": function(){}, //执行成功后的回调方法
            "failure ": function(){} //执行失败后的回调方法
        }
         
* @example //不带参数,则弹出添加分支对话框 this.form.deleteWork(); * @example //带参数,直接调用服务删除 this.form.deleteWork({ "success": function(json){ this.form.notice("deleteWork success", "success"); }.bind(this), "failure": function(xhr, text, error){ //xhr--HttpRequest请求对象 //text--HttpResponse内容文本 //error--错误信息 this.form.notice("deleteWork failure: "+error, "error"); }.bind(this) }); */ "deleteWork": function(option){ if (!option){ if (_form.businessData.control["allowDelete"]) _form.deleteWork(); }else{ _form.doDeleteWork(option.success, option.failure); } }, /**弹出一个确认框,带确认和关闭按钮 * @method confirm * @static * @param {String} type - 要显示的信息类型。可选值:success 成功,info :信息,error :错误, wran : 警告 * @param {String} title - 确认框标题栏显示文本。 * @param {String} text - 确认框的内容显示文本。 * @param {Number} width - 确认框的宽度。 * @param {String} height - 确认框的高度。 * @param {Function} ok - 点击“确定”按钮后的回调函数。 * @param {Function} cancel - 点击“取消”按钮后的回调函数。 * @example this.form.confirm("wran", "删除确认", "您确定要删除吗?", 300, 100,function(){ //执行删除代码 this.close(); }, function(){ this.close(); }); */ "confirm": function(type, 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; // 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); } }, /**弹出一个带关闭按钮的信息框 * @method alert * @static * @param {String} type - 要显示的信息类型。可选值:success 成功,info :信息,error :错误, wran : 警告 * @param {String} title - 信息框标题栏显示文本。 * @param {String} text - 信息框的内容显示文本。 * @param {Number} width - 信息框宽度。 * @param {String} height - 信息框的高度。 * @example this.form.alert("wran", "必填提醒", "请填写标题?", 300, 100); */ "alert": function(type, title, text, width, height){ _form.alert(type, title, text, width, height); }, /**弹出一个提示框 * @method notice * @static * @param {String} content - 要显示的信息文本 * @param {String} [type] - 要显示的信息类型。可选值:success 成功,info :信息,error :错误, wran : 警告 * @param {Element} [target] - 信息框显示位置的参考DOM对象。 * @param {Object} [where] - 信息框显示相对于target的x轴和y轴位置。
* 如: {"x": "center", "y": "center"}
x :
 水平位置,可用“left”、“right”和“center”;可以用数组定义外部(outside)位置和内部(inside)位置,如:['right', 'inside']
y :
 垂直位置,可用“top”、“bottom”和“center”;可以用数组定义外部(outside)位置和内部(inside)位置,如:['top', 'outside']。 * @param {Object} [offset] - 相对位置的偏移量,允许负值。如:{"x": 10, "y": -10} * @param {Object} [option] - 其他选项。如: { delayClose: 5000 } 在5秒后关闭 * @example this.form.notice("this is my information", "info"); */ "notice": function(content, type, target, where, offset, option){ _form.notice(content, type, target, where, offset, option); }, /**给表单添加事件。 * @method addEvent * @static * @param {String} type - 事件名称,参考本API Classer->FormComponents->Form的事件 * @param {Function} event - 事件方法。 * @example this.form.addEvent("load", function(){ this.form.notice("表单载入完成", "success"); }.bind(this)); */ "addEvent": function(type, event ){_form.addEvent(type, event );}, /**用一个新的浏览器窗口来打开当前文档,用于打印。(仅流程表单中可用)
* 如不指定表单,则使用表单设计中指定的打印表单。
* @method print * @static * @param {String} [application] - 指定表单所在的流程应用ID或名称。省略此参数表示当前应用。 * @param {String} [form] - 指定表单ID或名称。 * @example //在新窗口中使用当前表单中配置的打印表单打开当前文档 this.form.print(); * @example //在新窗口中使用“订单打印表单”表单打开当前文档 this.form.print("订单打印表单"); * @example //在新窗口中使用“订单管理”应用中的“订单打印表单”表单打开当前文档 this.form.print("订单管理", "订单打印表单"); */ "print": function(application, form){ if (arguments.length){ var app = (arguments.length>1) ? arguments[0] : null; var formName = (arguments.length>1) ? arguments[1] : arguments[0]; _form.printWork(app, formName); }else{ _form.printWork(); } }, /**同print方法。(仅流程表单中可用)
* @method openWindow * @static * @see this.form.print() * @param {String} [application] - 指定表单所在的流程应用ID或名称。省略此参数表示当前应用。 * @param {String} [form] - 指定表单ID或名称。 * @example this.form.openWindow(); */ "openWindow": function(application, form){ if (arguments.length){ var app = (arguments.length>1) ? arguments[0] : null; var formName = (arguments.length>1) ? arguments[1] : arguments[0]; _form.openWindow(formName, app); }else{ _form.openWindow(); } }, /** 打开一个在流转或已完成的流程实例。
* @method openWork * @static * @param {String} [workId] - 在流转的流程实例ID。workId和workCompletedId两个参数必须提供其中一个 * @param {String} [workCompletedId] - 已完成的流程实例ID。 * @param {String} [title] - 手机端打开时的窗口标题。 * @example this.form.openWork(id, "", "work title"); */ "openWork": function(workId, workCompletedId, title, options){ var op = options || {}; op.workId = workId; op.workCompletedId = workCompletedId; op.docTitle = title; op.appId = "process.Work"+(op.workId || op.workCompletedId); return layout.desktop.openApplication(this.event, "process.Work", op); }, /** 使用流程的jobId打开工作。
* @method openJob * @static * @param {String} id - 流程的jobId,如果流程拆分后,有多个流程实例(workId会有多个),但jobId是唯一的。 * @param {Boolean} [choice] - 如果有多个流程实例,是否弹出界面选择。如果传入false,则直接打开第一个工作。 * @example this.form.openJob(jobId, true); */ "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 = "
" + "
"+o2.LP.widget.open+"
"+ "
"+work.title+"
" + "
"+work.activityName+"
" + "
"+work.activityArrivedTime+"
" + "
"+(work.manualTaskIdentityText || "")+"
"; workNode.set("html", html); var action = workNode.getElement(".MWFAction"); action.store("work", work); action.addEvent("click", function(e){ var work = e.target.retrieve("work"); if (work) this.openWork(work.id, null, work.title, options); dlg.close(); }.bind(this)); }.bind(this)); workData.workCompletedList.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 = "
" + "
"+o2.LP.widget.open+"
"+ "
"+work.title+"
" + "
"+o2.LP.widget.workcompleted+"
" + "
"+work.completedTime+"
"; workNode.set("html", html); var action = workNode.getElement(".MWFAction"); action.store("work", work); action.addEvent("click", function(e){ var work = e.target.retrieve("work"); if (work) this.openWork(null, work.id, work.title, options); dlg.close(); }.bind(this)); }.bind(this)); var height = node.getSize().y+20; if (height>600) height = 600; var dlg = o2.DL.open({ "title": o2.LP.widget.choiceWork, "style" : "user", "isResize": false, "content": node, "buttonList": [ { "type" : "cancel", "text": o2.LP.widget.close, "action": function(){dlg.close();} } ] }); }else{ if (workData.workList.length){ var work = workData.workList[0]; return this.openWork(work.id, null, work.title, options); }else{ var work = workData.workCompletedList[0]; return this.openWork(null, work.id, work.title, options); } } } } // var op = options || {}; // op.workId = id; // op.workCompletedId = completedId; // op.docTitle = title; // op.appId = "process.Work"+(op.workId || op.workCompletedId); // layout.desktop.openApplication(this.event, "process.Work", op); }, /** 打开一个内容管理文档。
* @method openDocument * @static * @param {String} id - 内容管理文档实例的ID。 * @param {Boolean} [title] - 手机APP端打开时的窗口标题。 * @param {Object} [options] - 其他参数,内容如下
*

         {
            "readonly": true, //是否以只读方式打开,默认为true
             "saveOnClose" : true, //关闭的时候是否自动保存
             "postPublish" : function( documentData ){ //发布前执行方法,但数据已经准备好
                //documentData 为文档数据
             },
             "afterPublish" : function( form, documentData ){ //发布后执行的方法
                //form为内容管理Form对象,documentData 为文档数据
             },
             "postDelete" : function(){ //删除文档后执行的方法
             }
         }
         * 
* @example this.form.openDocument(id, "document title"); */ "openDocument": function(id, title, options){ var op = options || {}; op.documentId = id; op.docTitle = title; layout.desktop.openApplication(this.event, "cms.Document", op); }, /**打开一个门户页面。
* @method openPortal * @static * @param {String} portal - 要打开的门户应用名称、别名或ID。 * @param {String} [page] - 要打开的页面名称、别名或ID。如果忽略,则打开门户的默认首页 * @param {Object} [par] - 打开页面可以传入参数。
在被打开的页面中,可以通过脚本this.page.parameters访问到此参数。 * @example this.form.openPortal(id, "", {"type": "my type"}); */ "openPortal": function (portal, page, par) { var action = MWF.Actions.get("x_portal_assemble_surface"); action.getApplication(portal, function (json) { if (json.data) { if (page) { action.getPageByName(page, json.data.id, function (pageJson) { var pageId = (pageJson.data) ? pageJson.data.id : ""; layout.desktop.openApplication(null, "portal.Portal", { "portalId": json.data.id, "pageId": pageId, "parameters": par, "appId": (par && par.appId) || ("portal.Portal" + json.data.id + pageId) }) }); } else { layout.desktop.openApplication(null, "portal.Portal", { "portalId": json.data.id, "parameters": par, "appId": (par && par.appId) || ("portal.Portal" + json.data.id) }) } } }); }, /**打开一个内容管理栏目(应用)。
* @method openCMS * @static * @param {String} name - 内容管理栏目的名称、别名或ID。 * @example this.form.openCMS("通知公告"); */ "openCMS": function(name){ var action = MWF.Actions.get("x_cms_assemble_control"); action.getColumn(name, function(json){ if (json.data){ layout.desktop.openApplication(null, "cms.Module", { "columnId": json.data.id, "appId": "cms.Module"+json.data.id }); } }); }, /**打开一个流程应用。
* @method openProcess * @static * @param {String} name - 流程应用的名称、别名或ID。 * @example this.form.openProcess("财务审批"); */ "openProcess": function(name){ var action = MWF.Actions.get("x_processplatform_assemble_surface"); action.getApplication(name, function(json){ if (json.data){ layout.desktop.openApplication(null, "process.Application", { "id": json.data.id, "appId": "process.Application"+json.data.id }); } }); }, /**打开任意一个component应用。
* @method openApplication * @static * @param {String} name - 要打开的component的名称。component对应的名称可以在“控制面板-系统设置-界面设置-模块部署”中找到(即“组件路径”)。 * @param {Object} options - 打开的component的相关参数 * @example //打开会议管理 this.form.openApplication("Meeting"); * @example //打开一个流转中的流程实例。与 this.form.openWork(id, "", "work title");效果相同 this.form.openApplication("process.Work", { "workId": id, //流程实例ID "width": "1200", //宽度 "height": "800", //高度 "docTitle": "work title", //APP端窗口标题 "appId": "process.Work"+id //给新打开的component实例一个唯一名称 }); */ "openApplication":function(name, options){ layout.desktop.openApplication(null, name, options); }, /**创建一条内容管理文档。 * @method createDocument * @static * @param {(String|Object)} [columnOrOptions] * 如果不传参数,则弹出范围为平台所有栏目的选中界面。
* 当使用String时为内容管理应用(栏目)的名称、别名或ID。
* 当使用Object时,本参数后面的参数省略,传入如下格式的内容: *

         {
            "column" : column, //(string)可选,内容管理应用(栏目)的名称、别名或ID
            "category" : category, //(string)可选,要创建的文档所属的分类的名称、别名或ID
            "data" : data, //(json object)可选,创建文档时默认的业务数据
            "identity" : identity, //(string)可选,创建文档所使用的身份。如果此参数为空,且当前人有多个身份的情况下,会弹出身份选择对话框;否则使用默认身份。
            "callback" : callback, //(funcation)可选,文档创建后的回调函数。
            "target" : target, //(boolean)可选,为true时,在当前页面打开创建的文档;否则打开新窗口。默认false。
            "latest" : latest, //(boolean)可选,为true时,如果当前用户已经创建了此分类的文档,并且没有发布过,直接调用此文档为新文档;否则创建一个新文档。默认true。
            "selectColumnEnable" : selectColumnEnable, //(boolean)可选,是否可以选择应用和分类进行创建文档。有category参数时为默认false,否则默认为true。
            "ignoreTitle" : ignoreTitle //(boolean)可选,值为false时,创建的时候需要强制填写标题,默认为false。
        }
         
* @param {String} [category] - 要创建的文档所属的分类的名称、别名或ID * @param {Object} [data] - 创建文档时默认的业务数据 * @param {String} [identity] - 可选,创建文档所使用的身份。如果此参数为空,且当前人有多个身份的情况下,会弹出身份选择对话框;否则使用默认身份。 * @param {Function} [callback] - 文档创建后的回调函数 * @param {Boolean} [target] - 为true时,在当前页面打开创建的文档;否则打开新窗口。默认false * @param {Boolean} [latest] - 为true时,如果当前用户已经创建了此分类的文档,并且没有发布过,直接调用此文档为新文档;否则创建一个新文档。默认true。 * @param {Boolean} [selectColumnEnable] - 为true时,如果当前用户已经创建了此分类的文档,并且没有发布过,直接调用此文档为新文档;否则创建一个新文档。默认true。 * @param {Boolean} [ignoreTitle] - 值为false时,创建的时候需要强制填写标题,默认为false。 * @example //启动一个通知公告 this.form.createDocument("", "通知公告"); * @example //启动一个通知公告,标题为:关于XX的通知,启动后提示 this.form.createDocument("", "通知公告", {"subject": "关于XX的通知"}, function(json){ this.form.notice("创建成功!", "success"); }.bind(this)); * @example //启动一个通知公告,标题为:关于XX的通知,启动后提示 this.form.createDocument({ category : "通知公告", data : {"subject": "关于XX的通知"}, callback : function(json){ this.form.notice("创建成功!", "success"); }.bind(this) }); */ "createDocument": function (columnOrOptions, category, data, identity, callback, target, latest, selectColumnEnable, ignoreTitle) { var column = columnOrOptions; var onAfterPublish, onPostPublish; if (typeOf(columnOrOptions) == "object") { column = columnOrOptions.column; category = columnOrOptions.category; data = columnOrOptions.data; identity = columnOrOptions.identity; callback = columnOrOptions.callback; target = columnOrOptions.target; latest = columnOrOptions.latest; selectColumnEnable = columnOrOptions.selectColumnEnable; ignoreTitle = columnOrOptions.ignoreTitle; onAfterPublish = columnOrOptions.onAfterPublish; onPostPublish = columnOrOptions.onPostPublish; } if (target) { if (layout.app && layout.app.inBrowser) { layout.app.content.empty(); layout.app = null; } } MWF.xDesktop.requireApp("cms.Index", "Newer", function () { var starter = new MWF.xApplication.cms.Index.Newer(null, null, _form.app, null, { "documentData": data, "identity": identity, "ignoreTitle": ignoreTitle === true, "ignoreDrafted": latest === false, "selectColumnEnable": !category || selectColumnEnable === true, "restrictToColumn": !!category && selectColumnEnable !== true, "categoryFlag": category, //category id or name "columnFlag": column, //column id or name, "onStarted": function (documentId, data) { if (callback) callback(); }, "onPostPublish": function () { if(onPostPublish)onPostPublish(); }, "onAfterPublish": function () { if(onAfterPublish)onAfterPublish(); } }); starter.load(); }) }, /**启动一个流程实例。
* @method startProcess * @static * @param {String} app - 流程应用的名称、别名或ID。 * @param {String} process - 要启动的流程的名称、别名或ID。 * @param {Object} [data] - 流程启动时默认的业务数据。 * @param {String} [identity] - 流程启动所使用的身份。如果此参数为空,且当前人有多个身份的情况下,会弹出身份选择对话框;否则使用默认身份。。 * @param {Function} [callback] - 流程启动后的回调函数。 * @param {Boolean} [target] - 为true时,在当前页面打开启动的流程实例;否则打开新窗口。默认false。 * @param {Boolean} [latest] - 为true时,如果当前用户已经创建了此流程的实例,并且没有流转过,直接调用此实例为新流程实例;否则创建一个新实例。默认false。 * @example //启动一个发文管理实例 this.form.startProcess("公文管理", "发文管理"); * @example //启动一个发文管理实例,标题为:my file title,启动后提示 this.form.startProcess("公文管理", "发文管理", {"title": "my file title"}, function(json){ this.form.notice("create file success!", "success"); }); */ "startProcess": function(app, process, data, identity, callback, target, latest){ if (arguments.length>2){ for (var i=2; i(仅流程表单中可用)。 * @member currentRouteName * @memberOf module:form * @static * @return {String} 用户选择的路由。 * @example * var currentRouteName = this.form.currentRouteName; */ this.form.currentRouteName = _form.json.currentRouteName; /** * 在用户提交的时候,输入的意见。仅在表单的“校验意见”和“校验路由”脚本中可用。只读。(仅流程表单中可用)。 * @member opinion * @memberOf module:form * @static * @return {String} 用户填写的意见. * @example * var opinion = this.form.opinion; */ this.form.opinion = _form.json.opinion; /** * 在提交的时候,用户的手写意见以及录音意见,仅在表单的“校验意见”和“校验路由”脚本中可用。只读。(仅流程表单中可用)。 * @member medias * @memberOf module:form * @static * @return {Blob[]} 手写意见以及录音意见数组。手写意见和录音意见都是 HTML5的blob类型文件。 * @example * var medias = this.form.medias; */ this.form.medias = []; this.target = ev.target; this.event = ev.event; this.status = ev.status; this.session = layout.desktop.session; this.Actions = o2.Actions; this.query = function(option){ // options = { // "name": "statementName", // "data": "json data", // "firstResult": 1, // "maxResults": 100, // "success": function(){}, // "error": function(){}, // "async": true or false, default is true // } if (option){ var json = (option.data) || {}; if (option.firstResult) json.firstResult = option.firstResult.toInt(); if (option.maxResults) json.maxResults = option.maxResults.toInt(); o2.Actions.get("x_query_assemble_surface").executeStatement(option.name, json, success, error, options.async); } } this.Table = MWF.xScript.createTable(); }; MWF.xScript.createTable = function(){ return function(name){ this.name = name; this.action = o2.Actions.get("x_query_assemble_surface"); this.listRowNext = function(id, count, success, error, async){ this.action.listRowNext(this.name, id, count, success, error, async); }; this.listRowPrev = function(id, count, success, error, async){ this.action.listRowPrev(this.name, id, count, success, error, async); }; this.listRowPrev = function(id, count, success, error, async){ this.action.listRowPrev(this.name, id, count, success, error, async); }; this.listRowSelectWhere = function(where, success, error, async){ this.action.listRowSelectWhere(this.name, where, success, error, async); }; this.listRowCountWhere = function(where, success, error, async){ this.action.listRowCountWhere(this.name, where, success, error, async); }; this.deleteRow = function(id, success, error, async){ this.action.deleteRow(this.name, id, success, error, async); }; this.deleteAllRow = function(success, error, async){ this.action.deleteAllRow(this.name, success, error, async); }; this.getRow = function(id, success, error, async){ this.action.getRow(this.name, id, success, error, async); }; this.insertRow = function(data, success, error, async){ this.action.insertRow(this.name, data, success, error, async); }; this.updateRow = function(id, data, success, error, async){ this.action.updateRow(this.name, id, data, success, error, async); }; } }; MWF.xScript.JSONData = function(data, callback, key, parent, _form){ var getter = function(data, callback, k, _self){ return function(){return (["array","object"].indexOf(typeOf(data[k]))===-1) ? data[k] : new MWF.xScript.JSONData(data[k], callback, k, _self, _form);}; }; var setter = function(data, callback, k, _self){ return function(v){ data[k] = v; //debugger; //this.add(k, v, true); if (callback) callback(data, k, _self); } }; var define = function(){ var o = {}; for (var k in data) o[k] = {"configurable": true, "enumerable": true, "get": getter.apply(this, [data, callback, k, this]),"set": setter.apply(this, [data, callback, k, this])}; o["length"] = {"get": function(){return Object.keys(data).length;}}; o["some"] = {"get": function(){return data.some;}}; MWF.defineProperties(this, o); var methods = { "getKey": {"value": function(){ return key; }}, "getParent": {"value": function(){ return parent; }}, "toString": {"value": function() { return data.toString();}}, "setSection": {"value": function(newKey, newValue){ this.add(newKey, newValue, true); try { var path = [this.getKey()]; p = this.getParent(); while (p && p.getKey()){ path.unshift(p.getKey()); p = p.getParent(); } if (path.length) _form.sectionListObj[path.join(".")] = newKey; }catch(e){ } }}, "add": {"value": function(newKey, newValue, overwrite){ var flag = true; var type = typeOf(data); if (type==="array"){ if (arguments.length<2){ data.push(newKey); newValue = newKey; newKey = data.length-1; }else{ if (!newKey && newKey!==0){ data.push(newValue); newKey = data.length-1; }else{ flag = false; } } if (flag){ var o = {}; o[newKey] = {"configurable": true, "enumerable": true, "get": getter.apply(this, [data, callback, newKey, this]),"set": setter.apply(this, [data, callback, newKey, this])}; MWF.defineProperties(this, o); } this[newKey] = newValue; }else if (type==="object"){ if (!this.hasOwnProperty(newKey)){ data[newKey] = newValue; if (flag){ var o = {}; o[newKey] = {"configurable": true, "enumerable": true, "get": getter.apply(this, [data, callback, newKey, this]),"set": setter.apply(this, [data, callback, newKey, this])}; MWF.defineProperties(this, o); } this[newKey] = newValue; }else{ if (overwrite) this[newKey] = newValue; } } return this[newKey]; }}, "del": {"value": function(delKey){ if (!this.hasOwnProperty(delKey)) return null; // delete data[delKey]; // delete this[delKey]; data[delKey] = ""; this[delKey] = ""; return this; }} }; MWF.defineProperties(this, methods); //this.getKey = function(){ return key; }; //this.getParent = function(){ return parent; }; //this.toString = function() { return data.toString();}; //this.add = function(newKey, newValue, overwrite){ // var flag = true; // var type = typeOf(data); // if (!this.hasOwnProperty(newKey)){ // if (type=="array"){ // if (arguments.length<2){ // data.push(newKey); // newValue = newKey; // newKey = data.length-1; // }else{ // debugger; // if (!newKey && newKey!=0){ // data.push(newValue); // newKey = data.length-1; // }else{ // flag == false; // } // } // }else{ // data[newKey] = newValue; // } // //var valueType = typeOf(newValue); // //var newValueData = newValue; // //if (valueType=="object" || valueType=="array") newValueData = new MWF.xScript.JSONData(newValue, callback, newKey, this); // //if (valueType=="null") newValueData = new MWF.xScript.JSONData({}, callback, newKey, this); // if (flag){ // var o = {}; // o[newKey] = {"configurable": true, "enumerable": true, "get": getter.apply(this, [data, callback, newKey, this]),"set": setter.apply(this, [data, callback, newKey, this])}; // MWF.defineProperties(this, o); // } // this[newKey] = newValue; // }else{ // if (overwrite) this[newKey] = newValue; // } // // //var valueType = typeOf(newValue); // //var newValueData = newValue; // //if (valueType=="object" || valueType=="array") newValueData = new MWF.xScript.JSONData(newValue, callback, newKey, this); // //if (valueType=="null") newValueData = new MWF.xScript.JSONData({}, callback, newKey, this); // // // //this[newKey] = newValueData; // // return this[newKey]; //}; //this.del = function(delKey){ // if (!this.hasOwnProperty(delKey)) return null; // delete data[newKey]; // delete this[newKey]; // return this; //}; }; var type = typeOf(data); if (type==="object" || type==="array") define.apply(this); }; //MWF.xScript.createDict = function(application){ // return function(name){ // var applicationId = application; // this.name = name; // //MWF.require("MWF.xScript.Actions.DictActions", null, false); // var action = MWF.Actions.get("x_processplatform_assemble_surface"); // // this.get = function(path, success, failure){ // debugger; // var value = null; // if (path){ // var arr = path.split(/\./g); // var ar = arr.map(function(v){ // return encodeURIComponent(v); // }); // //var p = path.replace(/\./g, "/"); // var p = ar.join("/"); // action.getDictData(encodeURIComponent(this.name), applicationId, p, function(json){ // value = json.data; // if (success) success(json.data); // }, function(xhr, text, error){ // if (failure) failure(xhr, text, error); // }, false); // }else{ // action.getDictRoot(encodeURIComponent(this.name), applicationId, function(json){ // value = json.data; // if (success) success(json.data); // }, function(xhr, text, error){ // if (failure) failure(xhr, text, error); // }, false); // } // // return value; // }; // // this.set = function(path, value, success, failure){ // var p = path.replace(/\./g, "/"); // action.setDictData(encodeURIComponent(this.name), applicationId, p, value, function(json){ // if (success) success(json.data); // }, function(xhr, text, error){ // if (failure) failure(xhr, text, error); // }); // }; // this.add = function(path, value, success, failure){ // var p = path.replace(/\./g, "/"); // action.addDictData(encodeURIComponent(this.name), applicationId, p, value, function(json){ // if (success) success(json.data); // }, function(xhr, text, error){ // if (failure) failure(xhr, text, error); // }); // }; // this["delete"] = function(path, success, failure){ // var p = path.replace(/\./g, "/"); // action.deleteDictData(encodeURIComponent(this.name), applicationId, p, function(json){ // if (success) success(json.data); // }, function(xhr, text, error){ // if (failure) failure(xhr, text, error); // }); // }; // this.destory = this["delete"]; // } //}; // var dictLoaded = {}; if( !MWF.xScript.dictLoaded )MWF.xScript.dictLoaded = {}; MWF.xScript.addDictToCache = function ( options, path, json ) { if( !path )path = "root"; if( path.indexOf("root") !== 0 )path = "root." + path ; var type = options.appType || "process"; var enableAnonymous = options.enableAnonymous || false; var appFlagList = []; if( options.application )appFlagList.push( options.application ); if( options.appId )appFlagList.push( options.appId ); if( options.appName )appFlagList.push( options.appName ); if( options.appAlias )appFlagList.push( options.appAlias ); var dictFlagList = []; if( options.id )dictFlagList.push( options.id ); if( options.name )dictFlagList.push( options.name ); if( options.alias )dictFlagList.push( options.alias ); var cache = {}; cache[path] = json; for( var i=0; i