123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499 |
- MWF.xDesktop.requireApp("process.Xform", "$Module", null, false);
- /** @class Subform 子表单组件。
- * @o2cn 子表单
- * @example
- * //可以在脚本中获取该组件
- * //方法1:
- * var subform = this.form.get("fieldId"); //获取组件
- * //方法2
- * var subform = this.target; //在组件本身的脚本中获取
- * @extends MWF.xApplication.process.Xform.$Module
- * @o2category FormComponents
- * @o2range {Process|CMS}
- * @hideconstructor
- */
- MWF.xApplication.process.Xform.Subform = MWF.APPSubform = new Class(
- /** @lends MWF.xApplication.process.Xform.Subform# */
- {
- Extends: MWF.APP$Module,
- options: {
- /**
- * 子表单的设计已经获取到,但还没有插入html及生成内部组件。
- * @event MWF.xApplication.process.Xform.Subform#beforeModulesLoad
- * @see {@link https://www.yuque.com/o2oa/ixsnyt/hm5uft#i0zTS|组件事件说明}
- */
- /**
- * 子表单的设计已经获取到,已经插入html,组件json已经获取到,但未生成内部组件。
- * @example
- * //获取子表单所有组件id
- * var moduleIdList = Object.keys(this.target.subformData.json.moduleList);
- * @event MWF.xApplication.process.Xform.Subform#modulesLoad
- * @see {@link https://www.yuque.com/o2oa/ixsnyt/hm5uft#i0zTS|组件事件说明}
- */
- /**
- * 子表单内部组件加载完成。
- * @example
- * //获取子表单所有组件id
- * var moduleIdList = Object.keys(this.target.subformData.json.moduleList);
- * //获取子表单所有组件
- * var moduleList = moduleIdList.map(function(id){
- * return this.form.get(id, subformId); //subformId为当前子表单ID,布局组件有可能id冲突,通过subformId来确定当前子表单的组件
- * }.bind(this))
- * @event MWF.xApplication.process.Xform.Subform#afterModulesLoad
- * @see {@link https://www.yuque.com/o2oa/ixsnyt/hm5uft#i0zTS|组件事件说明}
- */
- "moduleEvents": ["load", "queryLoad", "postLoad", "beforeModulesLoad", "modulesLoad", "afterModulesLoad"]
- },
- _loadUserInterface: function () {
- /**
- * @ignore
- * @member parentLine
- * @memberOf MWF.xApplication.process.Xform.Subform#
- */
- this.node.empty();
- this.modules = [];
- this.moduleList = {};
- if (this.json.isDelay) {
- if (this.form.subformLoadedCount) {
- this.form.subformLoadedCount++;
- } else {
- this.form.subformLoadedCount = 1
- }
- this.form.checkSubformLoaded();
- this.checked = true;
- } else {
- this.getSubform(function () {
- this.loadSubform();
- }.bind(this));
- }
- },
- /**
- * @summary 当子表单被设置为延迟加载,通过active方法激活
- * @param {Function} callback 激活后的回调方法,另外已经激活过该方法还会被执行。
- * @example
- * var subform = this.form.get("fieldId");
- * subform.active(function(){
- * //do someting
- * })
- */
- active: function (callback) {
- if (!this.loaded) {
- this.reload(callback)
- } else {
- if (callback) callback();
- }
- },
- /**
- * @summary 重新加载子表单
- * @param {Function} callback
- * @example
- * this.form.get("fieldId").reload(function(){
- * //do someting
- * })
- */
- reload: function (callback) {
- this.clean();
- this.getSubform(function () {
- this.loadSubform();
- if (callback) callback();
- }.bind(this));
- },
- clean: function(){
- (this.modules || []).each(function(module){
- if( module.json && module.json.type === "Subform" ){
- if(module.clean)module.clean();
- }
- if (this.form.all[module.json.id]) delete this.form.all[module.json.id];
- if (this.form.forms[module.json.id])delete this.form.forms[module.json.id];
- this.form.modules.erase(module);
- }.bind(this));
- Object.each(this.moduleList || {}, function (module, formKey) {
- delete this.form.json.moduleList[formKey];
- }.bind(this));
- if( this.subformData && this.subformData.json.id ){
- var id = this.subformData.json.id;
- if( this.form.subformLoaded && this.form.subformLoaded.length ){
- this.form.subformLoaded.erase(id);
- }
- if( this.parentformIdList && this.parentformIdList.length){
- this.parentformIdList.erase(id);
- }
- }
- this.modules = [];
- this.moduleList = {};
- this.node.empty();
- },
- loadCss: function () {
- if (this.subformData.json.css && this.subformData.json.css.code) {
- var cssText = this.subformData.json.css.code;
- //删除注释
- cssText = cssText.replace(/\/\*[\s\S]*?\*\/\n|([^:]|^)\/\/.*\n$/g, '').replace(/\\n/, '');
- cssText = this.form.parseCSS(cssText);
- var rex = new RegExp("(.+)(?=\\{)", "g");
- var match;
- var id = this.form.json.id.replace(/\-/g, "");
- var prefix = ".css" + id + " ";
- while ((match = rex.exec(cssText)) !== null) {
- var rulesStr = match[0];
- var startWith = rulesStr.substring(0, 1);
- if (startWith === "@" || startWith === ":" || rulesStr.indexOf("%") !== -1) {
- }else if (rulesStr.trim()==='from' || rulesStr.trim()==='to'){
- } else {
- if (rulesStr.indexOf(",") != -1) {
- //var rules = rulesStr.split(/\s*,\s*/g);
- var rules = rulesStr.split(/,/g);
- rules = rules.map(function (r) {
- return prefix + r;
- });
- var rule = rules.join(",");
- cssText = cssText.substring(0, match.index) + rule + cssText.substring(rex.lastIndex, cssText.length);
- rex.lastIndex = rex.lastIndex + (prefix.length * rules.length);
- } else {
- var rule = prefix + match[0];
- cssText = cssText.substring(0, match.index) + rule + cssText.substring(rex.lastIndex, cssText.length);
- rex.lastIndex = rex.lastIndex + prefix.length;
- }
- }
- }
- var styleNode = $("style" + this.form.json.id);
- if (!styleNode) {
- var styleNode = document.createElement("style");
- styleNode.setAttribute("type", "text/css");
- styleNode.id = "style" + this.form.json.id;
- styleNode.inject(this.form.container, "before");
- }
- if (styleNode.styleSheet) {
- var setFunc = function () {
- styleNode.styleSheet.cssText += cssText;
- };
- if (styleNode.styleSheet.disabled) {
- setTimeout(setFunc, 10);
- } else {
- setFunc();
- }
- } else {
- var cssTextNode = document.createTextNode(cssText);
- styleNode.appendChild(cssTextNode);
- }
- }
- },
- checkSubformNested: function (id) {
- if (!id) return true;
- if (this.parentformIdList) {
- return !this.parentformIdList.contains(id);
- } else {
- return ![this.form.json.id].contains(id);
- }
- },
- checkSubformUnique: function (id) {
- if (!id) return true;
- if (!this.form.subformLoaded) return true;
- return !this.form.subformLoaded.contains(id);
- },
- getParentformIdList: function () {
- var parentformIdList;
- if (this.parentformIdList) {
- parentformIdList = Array.clone(this.parentformIdList);
- parentformIdList.push(this.subformData.json.id)
- } else {
- parentformIdList = [this.form.json.id, this.subformData.json.id];
- }
- return parentformIdList;
- },
- loadSubform: function () {
- if (this.subformData) {
- if (!this.checkSubformNested(this.subformData.json.id)) {
- this.form.notice(MWF.xApplication.process.Xform.LP.subformNestedError, "error");
- } else if (!this.checkSubformUnique(this.subformData.json.id)) {
- this.form.notice(MWF.xApplication.process.Xform.LP.subformUniqueError, "error");
- } else {
- //this.form.addEvent("postLoad", function(){
- this.fireEvent("beforeModulesLoad");
- this.loadCss();
- this.modules = [];
- this.moduleList = {};
- this.node.set("html", this.subformData.html);
- Object.each(this.subformData.json.moduleList, function (module, key) {
- var formKey = key;
- if (this.form.json.moduleList[key]) {
- formKey = this.json.id + "_" + key;
- var moduleNode = this.node.getElement("#" + key);
- if (moduleNode) moduleNode.set("id", formKey);
- module.id = formKey;
- module._originId = key;
- module._subform = this.json.id;
- }
- this.form.json.moduleList[formKey] = module;
- this.moduleList[formKey] = module;
- }.bind(this));
- this.fireEvent("modulesLoad");
- var moduleNodes = this.form._getModuleNodes(this.node);
- moduleNodes.each(function (node) {
- if (node.get("MWFtype") !== "form") {
- var _self = this;
- var json = this.form._getDomjson(node);
- //if( json.type === "Subform" || json.moduleName === "subform" )this.form.subformCount++;
- var module = this.form._loadModule(json, node, function () {
- this.parentformIdList = _self.getParentformIdList();
- });
- this.form.modules.push(module);
- this.modules.push(module);
- }
- }.bind(this));
- this.form.subformLoaded.push(this.subformData.json.id);
- this.fireEvent("afterModulesLoad");
- //}.bind(this));
- }
- }
- if (!this.checked) {
- if (this.form.subformLoadedCount) {
- this.form.subformLoadedCount++;
- } else {
- this.form.subformLoadedCount = 1
- }
- this.form.checkSubformLoaded();
- }
- //console.log( "add subformLoadedCount , this.form.subformLoadedCount = "+ this.form.subformLoadedCount)
- /**
- * @summary 表单是否加载(激活)过。
- * @member {Boolean}
- * @example
- * if( !this.form.get("fieldId").loaded ){ //判断子表单是否加载过
- * this.form.get("fieldId").active(); //没有加载过则激活
- * }
- */
- this.loaded = true;
- this.checked = true;
- },
- getSubform: function (callback) {
- var method = (this.form.json.mode !== "Mobile" && !layout.mobile) ? "getForm" : "getFormMobile";
- if (this.json.subformType === "script") {
- if (this.json.subformScript && this.json.subformScript.code) {
- var data = this.form.Macro.exec(this.json.subformScript.code, this);
- if (data) {
- var formName, app;
- if (typeOf(data) === "string") {
- formName = data;
- } else {
- if (data.application) app = data.application;
- if (data.subform) formName = data.subform;
- }
- if (formName) {
- if (!app) app = (this.form.businessData.work || this.form.businessData.workCompleted).application;
- MWF.Actions.get("x_processplatform_assemble_surface")[method](formName, app, function (json) {
- this.getSubformData(json.data);
- if (callback) callback();
- }.bind(this));
- } else {
- if (callback) callback();
- }
- } else {
- if (callback) callback();
- }
- }
- } else {
- if (this.json.subformSelected && this.json.subformSelected !== "none") {
- var subformData = (this.form.app.relatedFormMap) ? this.form.app.relatedFormMap[this.json.subformSelected] : null;
- if (subformData) {
- this.getSubformData({"data": subformData.data});
- if (callback) callback();
- } else {
- var app;
- if (this.json.subformAppSelected) {
- app = this.json.subformAppSelected;
- } else {
- app = (this.form.businessData.work || this.form.businessData.workCompleted).application;
- }
- MWF.Actions.get("x_processplatform_assemble_surface")[method](this.json.subformSelected, app, function (json) {
- this.getSubformData(json.data);
- if (callback) callback();
- }.bind(this));
- }
- } else {
- if (callback) callback();
- }
- }
- },
- getSubformData: function (data) {
- if (!data || typeOf(data) !== "object") return;
- var subformDataStr = null;
- // if ( this.form.json.mode !== "Mobile" && !layout.mobile){
- // subformDataStr = data.data;
- // }else{
- // subformDataStr = data.mobileData;
- // }
- subformDataStr = data.data;
- this.subformData = null;
- if (subformDataStr) {
- if( this.form.isParseLanguage ) {
- var jsonStr = o2.bindJson(MWF.decodeJsonString(subformDataStr), {"lp": MWF.xApplication.process.Xform.LP.form});
- this.subformData = JSON.decode(jsonStr);
- }else{
- this.subformData = JSON.decode(MWF.decodeJsonString(subformDataStr));
- }
- this.subformData.updateTime = data.updateTime;
- }
- }
- });
- MWF.xApplication.process.Xform.SubmitForm = MWF.APPSubmitform = new Class({
- Extends: MWF.APPSubform,
- _loadUserInterface: function () {
- // this.node.empty();
- this.getSubform(function () {
- this.loadSubform();
- }.bind(this));
- },
- reload: function () {
- // this.node.empty();
- this.getSubform(function () {
- this.loadSubform();
- }.bind(this));
- },
- show: function ( defaultRoute ) {
- if (this.json.submitScript && this.json.submitScript.code) {
- this.form.Macro.environment.defaultRoute = defaultRoute;
- this.form.Macro.exec(this.json.submitScript.code, this);
- }
- // this.fireSubFormEvent("load");
- },
- // fireSubFormEvent : function( name ){
- // var events = this.subformData.json.events;
- // if( events && events[name] && events[name]["code"] ){
- // this.form.Macro.exec(events[name]["code"], this);
- // }
- // },
- loadSubform: function () {
- if (this.subformData) {
- if (!this.checkSubformUnique(this.subformData.json.id)) { //如果提交表单已经嵌入到表单中,那么把这个表单弹出来
- // this.form.notice(MWF.xApplication.process.Xform.LP.subformUniqueError, "error");
- this.isEmbedded = true;
- this.fireEvent("afterModulesLoad");
- } else if (!this.checkSubformNested(this.subformData.json.id)) {
- this.form.notice(MWF.xApplication.process.Xform.LP.subformNestedError, "error");
- } else {
- //this.form.addEvent("postLoad", function(){
- // this.fireSubFormEvent("queryLoad");
- this.fireEvent("beforeModulesLoad");
- this.loadCss();
- this.node.set("html", this.subformData.html);
- Object.each(this.subformData.json.moduleList, function (module, key) {
- var formKey = key;
- if (this.form.json.moduleList[key]) {
- formKey = this.json.id + "_" + key;
- var moduleNode = this.node.getElement("#" + key);
- if (moduleNode) moduleNode.set("id", formKey);
- module.id = formKey;
- module._originId = key;
- module._subform = this.json.id;
- }
- this.form.json.moduleList[formKey] = module;
- }.bind(this));
- var moduleNodes = this.form._getModuleNodes(this.node);
- moduleNodes.each(function (node) {
- if (node.get("MWFtype") !== "form") {
- var _self = this;
- var json = this.form._getDomjson(node);
- //if( json.type === "Subform" || json.moduleName === "subform" )this.form.subformCount++;
- var module = this.form._loadModule(json, node, function () {
- this.parentformIdList = _self.getParentformIdList();
- });
- this.form.modules.push(module);
- }
- }.bind(this));
- this.form.subformLoaded.push(this.subformData.json.id);
- this.fireEvent("afterModulesLoad");
- // this.fireSubFormEvent("postLoad");
- // this.fireSubFormEvent("load");
- // this.fireSubFormEvent("afterLoad");
- }
- }
- // if( this.form.subformLoadedCount ){
- // this.form.subformLoadedCount++;
- // }else{
- // this.form.subformLoadedCount = 1
- // }
- // this.form.checkSubformLoaded();
- },
- getSubform: function (callback) {
- var method = (this.form.json.mode !== "Mobile" && !layout.mobile) ? "getForm" : "getFormMobile";
- if (this.json.submitFormType === "script") {
- if (this.json.submitFormScript && this.json.submitFormScript.code) {
- var data = this.form.Macro.exec(this.json.submitFormScript.code, this);
- if (data) {
- var formName, app;
- if (typeOf(data) === "string") {
- formName = data;
- } else {
- if (data.application) app = data.application;
- if (data.form) formName = data.form;
- }
- if (formName) {
- if (!app) app = (this.form.businessData.work || this.form.businessData.workCompleted).application;
- MWF.Actions.get("x_processplatform_assemble_surface")[method](formName, app, function (json) {
- this.getSubformData(json.data);
- if (callback) callback();
- }.bind(this));
- } else {
- if (callback) callback();
- }
- } else {
- if (callback) callback();
- }
- }
- } else {
- if (this.json.submitFormSelected && this.json.submitFormSelected !== "none") {
- var app;
- if (this.json.submitFormAppSelected) {
- app = this.json.submitFormAppSelected;
- } else {
- app = (this.form.businessData.work || this.form.businessData.workCompleted).application;
- }
- MWF.Actions.get("x_processplatform_assemble_surface")[method](this.json.submitFormSelected, app, function (json) {
- this.getSubformData(json.data);
- if (callback) callback();
- }.bind(this));
- } else {
- if (callback) callback();
- }
- }
- }
- });
|