Main.js 54 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569
  1. MWF.xApplication.FindDesigner.options.multitask = false;
  2. MWF.xApplication.FindDesigner.Main = new Class({
  3. Extends: MWF.xApplication.Common.Main,
  4. Implements: [Options, Events],
  5. options: {
  6. "style": "default",
  7. "name": "FindDesigner",
  8. "mvcStyle": "style.css",
  9. "icon": "icon.png",
  10. "width": "1200",
  11. "height": "800",
  12. "isResize": true,
  13. "isMax": true,
  14. "layout": {
  15. "type": "leftRight",
  16. "percent": 0.3
  17. },
  18. "title": MWF.xApplication.FindDesigner.LP.title
  19. },
  20. onQueryLoad: function(){
  21. this.lp = MWF.xApplication.FindDesigner.LP;
  22. this.filterOption = {
  23. "keyword": "",
  24. "designerTypes": [],
  25. "caseSensitive": false,
  26. "matchWholeWord": false,
  27. "matchRegExp": false,
  28. "moduleList": []
  29. }
  30. this.selectedModules = [];
  31. this.selectedRange = [];
  32. o2.UD.getDataJson("findDesignerLayout", function(json){
  33. this.setOptions(json);
  34. }.bind(this), false);
  35. },
  36. loadApplication: function(callback){
  37. var url = this.path+this.options.style+"/view.html";
  38. this.content.loadHtml(url, {"bind": {"lp": this.lp}, "module": this}, function(){
  39. this.setSizeNode();
  40. this.createToolbar();
  41. if (callback) callback();
  42. }.bind(this));
  43. },
  44. createToolbar: function(){
  45. o2.require("o2.widget.Toolbar", function(){
  46. this.previewToolbar = new o2.widget.Toolbar(this.previewTitleToolbar, {"style": "findDesigner"}, this);
  47. this.previewToolbar.load();
  48. this.previewToolbar.childrenButton[0].disable();
  49. this.previewToolbar.childrenButton[1].disable();
  50. }.bind(this));
  51. },
  52. initLayout: function(){
  53. this.listNode.set("style", "");
  54. this.previewNode.set("style", "");
  55. if (this.resizeDrag) this.resizeDrag.detach();
  56. if (this.sizeNodeFun) this.removeEvent("resize", this.sizeNodeFun);
  57. if (this.options.layout.type=="leftRight"){
  58. this.toLeftRight();
  59. }else{
  60. this.toTopBottom();
  61. }
  62. },
  63. setSizeNode: function(){
  64. this.initLayout();
  65. this["sizeNode_"+this.options.layout.type]();
  66. this["setResizeNode_"+this.options.layout.type]();
  67. this.sizeNodeFun = null;
  68. this.sizeNodeFun = this["sizeNode_"+this.options.layout.type].bind(this);
  69. this.addEvent("resize", this.sizeNodeFun);
  70. },
  71. sizeResultNode: function(){
  72. var size = this.content.getSize();
  73. var filterSzie = this.filterNode.getSize();
  74. var keywordSize = this.keywordNode.getSize();
  75. var rangeSize = this.rangeNode.getSize();
  76. var h = size.y-filterSzie.y-keywordSize.y-rangeSize.y;
  77. this.resultNode.setStyle("height", ""+h+"px");
  78. return h;
  79. },
  80. sizeNode_topBottom: function(){
  81. var h = this.sizeResultNode();
  82. var listHeight = h*this.options.layout.percent;
  83. this.listNode.setStyle("height", ""+listHeight+"px");
  84. var previewHeight = h*(1-this.options.layout.percent);
  85. this.previewNode.setStyle("height", ""+previewHeight+"px");
  86. var listTitleSize = this.listTitleNode.getSize();
  87. var listContentHeight = listHeight - listTitleSize.y;
  88. this.listAreaNode.setStyle("height", ""+listContentHeight+"px");
  89. var previewSeparatorSize = this.previewSeparatorNode.getSize();
  90. var previewTitleSize = this.previewTitleNode.getSize();
  91. var previewContentHeight = previewHeight - previewSeparatorSize.y - previewTitleSize.y;
  92. this.previewContentNode.setStyle("height", ""+previewContentHeight+"px");
  93. },
  94. sizeNode_leftRight: function(){
  95. var h = this.sizeResultNode();
  96. var w = this.resultNode.getSize().x;
  97. var listWidth = w*this.options.layout.percent;
  98. this.listNode.setStyle("width", ""+listWidth+"px");
  99. this.previewNode.setStyle("margin-left", ""+listWidth+"px");
  100. var listTitleSize = this.listTitleNode.getSize();
  101. var listContentHeight = h - listTitleSize.y;
  102. this.listAreaNode.setStyle("height", ""+listContentHeight+"px");
  103. var previewTitleSize = this.previewTitleNode.getSize();
  104. var previewContentHeight = h - previewTitleSize.y;
  105. this.previewContentNode.setStyle("height", ""+previewContentHeight+"px");
  106. },
  107. setResizeNode_topBottom: function(){
  108. if (this.previewSeparatorNode){
  109. this.resizeDrag = new Drag(this.previewSeparatorNode, {
  110. "onStart": function(el, e){
  111. el.store("position", o2.eventPosition(e));
  112. el.store("initialSize", this.listNode.getSize());
  113. }.bind(this),
  114. "onDrag": function(el, e){
  115. var p = o2.eventPosition(e);
  116. var position = el.retrieve("position");
  117. var initialSize = el.retrieve("initialSize");
  118. var dy = position.y.toFloat()-p.y.toFloat();
  119. var height = initialSize.y-dy;
  120. var size = this.resultNode.getSize();
  121. this.options.layout.percent = height/size.y;
  122. if (this.options.layout.percent<0.1) this.options.layout.percent = 0.1;
  123. if (this.options.layout.percent>0.85) this.options.layout.percent = 0.85;
  124. this.sizeNode_topBottom();
  125. if (this.editor) this.editor.resize();
  126. }.bind(this),
  127. "onComplete": function(){
  128. o2.UD.putData("findDesignerLayout", {"layout": this.options.layout});
  129. }.bind(this)
  130. });
  131. }
  132. },
  133. setResizeNode_leftRight: function(){
  134. if (this.previewSeparatorNode){
  135. this.resizeDrag = new Drag(this.previewSeparatorNode, {
  136. "onStart": function(el, e){
  137. el.store("position", o2.eventPosition(e));
  138. el.store("initialSize", this.listNode.getSize());
  139. }.bind(this),
  140. "onDrag": function(el, e){
  141. var p = o2.eventPosition(e);
  142. var position = el.retrieve("position");
  143. var initialSize = el.retrieve("initialSize");
  144. var dx = position.x.toFloat()-p.x.toFloat();
  145. var width = initialSize.x-dx;
  146. var size = this.resultNode.getSize();
  147. this.options.layout.percent = width/size.x;
  148. if (this.options.layout.percent<0.1) this.options.layout.percent = 0.1;
  149. if (this.options.layout.percent>0.85) this.options.layout.percent = 0.85;
  150. this.sizeNode_leftRight();
  151. if (this.editor) this.editor.resize();
  152. }.bind(this),
  153. "onComplete": function(){
  154. o2.UD.putData("findDesignerLayout", {"layout": this.options.layout});
  155. }.bind(this)
  156. });
  157. }
  158. },
  159. checkFilter: function(e){
  160. if (e.target.hasClass("filterNode_item")) e.target.getElement("input").click();
  161. e.stopPropagation();
  162. },
  163. checkRange: function(e){
  164. if (e.target.hasClass("rangeType_Item")) e.target.getElement("input").click();
  165. e.stopPropagation();
  166. },
  167. overKeywordOption: function(e){
  168. if (e.target.hasClass("o2_findDesigner_keywordNode_optionItem")){
  169. if (!e.target.hasClass("optionItem_over")) e.target.addClass("optionItem_over");
  170. }
  171. },
  172. outKeywordOption: function(e){
  173. if (e.target.hasClass("o2_findDesigner_keywordNode_optionItem")) e.target.removeClass("optionItem_over");
  174. },
  175. setCaseSensitive: function(e){
  176. this.filterOption.caseSensitive = !this.filterOption.caseSensitive;
  177. this.caseSensitiveNode.removeClass("caseSensitiveNode_"+!this.filterOption.caseSensitive);
  178. this.caseSensitiveNode.addClass("caseSensitiveNode_"+this.filterOption.caseSensitive);
  179. },
  180. setMatchWholeWord: function(e){
  181. this.filterOption.matchWholeWord = !this.filterOption.matchWholeWord;
  182. this.matchWholeWordNode.removeClass("matchWholeWordNode_"+!this.filterOption.matchWholeWord);
  183. this.matchWholeWordNode.addClass("matchWholeWordNode_"+this.filterOption.matchWholeWord);
  184. },
  185. setMatchRegExp: function(e){
  186. this.filterOption.matchRegExp = !this.filterOption.matchRegExp;
  187. this.matchRegExpNode.removeClass("matchRegExpNode_"+!this.filterOption.matchRegExp);
  188. this.matchRegExpNode.addClass("matchRegExpNode_"+this.filterOption.matchRegExp);
  189. },
  190. layoutAddClass: function(flag){
  191. flag = flag || "";
  192. this.listNode.addClass("listNode"+flag);
  193. this.previewNode.addClass("previewNode"+flag);
  194. this.previewSeparatorNode.addClass("previewNode_separator"+flag);
  195. this.previewTitleNode.addClass("previewNode_title"+flag);
  196. this.previewTitleActionNode.addClass("previewNode_title_action"+flag);
  197. this.previewContentNode.addClass("previewNode_content"+flag);
  198. },
  199. layoutRemoveClass: function(flag){
  200. flag = flag || "";
  201. this.listNode.removeClass("listNode"+flag);
  202. this.previewNode.removeClass("previewNode"+flag);
  203. this.previewSeparatorNode.removeClass("previewNode_separator"+flag);
  204. this.previewTitleNode.removeClass("previewNode_title"+flag);
  205. this.previewTitleActionNode.removeClass("previewNode_title_action"+flag);
  206. this.previewContentNode.removeClass("previewNode_content"+flag);
  207. },
  208. toLeftRight: function(){
  209. this.layoutAddClass("_lr");
  210. this.layoutRemoveClass();
  211. this.options.layout.type="leftRight";
  212. },
  213. toTopBottom: function(){
  214. this.layoutAddClass();
  215. this.layoutRemoveClass("_lr");
  216. this.options.layout.type="topBottom";
  217. },
  218. changeLayout: function(){
  219. if (this.options.layout.type=="leftRight"){
  220. this.options.layout.type="topBottom";
  221. }else{
  222. this.options.layout.type="leftRight";
  223. }
  224. this.setSizeNode();
  225. o2.UD.putData("findDesignerLayout", {"layout": this.options.layout});
  226. },
  227. getSelectedRange: function(){
  228. this.selectedRange = [];
  229. var rangeInputs = this.rangeContentNode.getElements("input");
  230. rangeInputs.each(function(input){
  231. if (input.checked) this.selectedRange.push(input.get("value"));
  232. }.bind(this));
  233. },
  234. setSelectedRange: function(){
  235. if (this.selectedRange && this.selectedRange.length){
  236. var rangeInputs = this.rangeContentNode.getElements("input");
  237. rangeInputs.each(function(input){
  238. if (this.selectedRange.indexOf(input.get("value"))!=-1) input.set("checked", true);
  239. }.bind(this));
  240. }
  241. },
  242. removeRangeItem: function(item){
  243. item.destroy();
  244. var itemNodes = this.rangeSelectedContentNode.getChildren();
  245. if (!itemNodes.length) this.setSelectedRange();
  246. },
  247. selectFindRange: function(loadFun){
  248. debugger;
  249. o2.requireApp("Selector", "package", function(){
  250. new o2.O2Selector(this.content, {
  251. "values": this.selectedModules,
  252. "type": "PlatApp",
  253. "selectAllEnable": true,
  254. "onLoad": function(){
  255. if (loadFun && o2.typeOf(loadFun)=="function") loadFun();
  256. },
  257. "onComplete": function(list){
  258. this.rangeSelectedContentNode.empty();
  259. //this.selectedModules = [];
  260. if (list.length){
  261. this.getSelectedRange();
  262. this.rangeContentNode.getElements("input").set("checked", false);
  263. o2.require("o2.widget.O2Identity", function(){
  264. list.each(function(app){
  265. //this.selectedModules.push(app.data);
  266. app.data.name = this.lp.service + "-" + app.data.name;
  267. var item = new o2.widget.O2Other(app.data, this.rangeSelectedContentNode, {"canRemove": true, "style": "find", "onRemove": function(item){this.removeRangeItem(item);}.bind(this)});
  268. item.node.store("data", item.data);
  269. }.bind(this));
  270. }.bind(this));
  271. }else{
  272. this.setSelectedRange();
  273. }
  274. }.bind(this)
  275. });
  276. }.bind(this));
  277. },
  278. getFindOption: function(){
  279. var filterTypes = [];
  280. filterItems = this.filterNode.getElements("input");
  281. filterItems.each(function(item){
  282. if (item.checked) filterTypes.push(item.get("value"));
  283. }.bind(this));
  284. var keyword = this.keywordInputNode.get("value");
  285. var moduleList = [];
  286. var itemNodes = this.rangeSelectedContentNode.getChildren();
  287. if (!itemNodes.length){
  288. this.getSelectedRange();
  289. this.selectedRange.each(function(type){
  290. moduleList.push({"moduleType": type, "flagList": []});
  291. });
  292. }else{
  293. var rangeApp = {};
  294. itemNodes.each(function(node){
  295. var data = node.retrieve("data");
  296. if (!rangeApp[data.moduleType]) rangeApp[data.moduleType] = [];
  297. rangeApp[data.moduleType].push({"id": data.id});
  298. }.bind(this));
  299. Object.keys(rangeApp).each(function(k){
  300. moduleList.push({"moduleType": k, "flagList": rangeApp[k]});
  301. });
  302. }
  303. this.filterOption.keyword = keyword;
  304. this.filterOption.designerTypes = filterTypes;
  305. this.filterOption.moduleList = moduleList;
  306. return this.filterOption;
  307. },
  308. checkFindDesigner: function(e){
  309. if (e.keyCode===13){
  310. this.getFindOption();
  311. if (!this.filterOption.keyword){
  312. this.listInfoNode.show().removeClass("loadding").getFirst().set("text", this.lp.nothingFind_keyword);
  313. return false;
  314. }
  315. if (!this.filterOption.designerTypes.length){
  316. this.listInfoNode.show().removeClass("loadding").getFirst().set("text", this.lp.nothingFind_noFilter);
  317. return false;
  318. }
  319. if (!this.filterOption.moduleList.length){
  320. this.listInfoNode.show().removeClass("loadding").getFirst().set("text", this.lp.nothingFind_noRange);
  321. return false;
  322. }
  323. this.findDesigner();
  324. }
  325. },
  326. getFindWorker: function(){
  327. if (!this.findWorker) this.findWorker = new Worker("../x_component_FindDesigner/FindWorker.js");
  328. this.findWorker.onmessage = function(e) {
  329. if (e.data && e.data.type=="receive") this.setReceiveMessage();
  330. if (e.data && e.data.type=="ready") this.setReadyMessage(e.data);
  331. if (e.data && e.data.type=="done") this.doFindOptionResult(e.data);
  332. if (e.data && e.data.type=="find") this.doFindResult(e.data);
  333. }.bind(this);
  334. },
  335. doFindOptionResult: function(){
  336. // this.listInfoNode.hide();
  337. // this.listContentNode.show();
  338. // moduleNode = this.createResultCategroyItem("xxxx", "", this.tree);
  339. this.findOptionModuleProcessed++;
  340. this.updateFindProgress();
  341. },
  342. doFindResult: function(data){
  343. debugger
  344. if (data.data) this.showFindResult(data.data, data.option);
  345. },
  346. getResultTree: function(callback){
  347. if (!this.tree){
  348. o2.require("o2.widget.Tree", function(){
  349. this.tree = new o2.widget.Tree(this.listContentNode, {
  350. "style": "findDesigner"
  351. // "onQueryExpand": function(item){
  352. // if (item.designer) this.loadDesignerPattern(item);
  353. // }.bind(this)
  354. });
  355. this.tree.load();
  356. if (callback) callback();
  357. }.bind(this), null, false);
  358. }else{
  359. if (callback) callback();
  360. }
  361. },
  362. createResultCategroyItem: function(text, title, tree){
  363. var obj = {
  364. "title": title,
  365. "text": "<span style='font-weight: bold'>"+text+"</span>",
  366. "icon": ""
  367. }
  368. return tree.appendChild(obj);
  369. },
  370. createResultAppItem: function(text, title, tree){
  371. var obj = {
  372. "title": title,
  373. "text": "<span style='font-weight: bold; color: #0b58a2'>"+text+"</span>",
  374. "icon": ""
  375. }
  376. return tree.appendChild(obj);
  377. },
  378. createResultTypeItem: function(text, title, tree){
  379. var obj = {
  380. "title": title,
  381. "text": "<span style='color: #333333'>"+text+"</span>",
  382. "icon": ""
  383. }
  384. return tree.appendChild(obj);
  385. },
  386. createResultDesignerItem: function(text, title, tree){
  387. var obj = {
  388. "expand": false,
  389. "title": title,
  390. "text": "<span style='color: #333333'>"+text+"</span>",
  391. "icon": ""
  392. }
  393. return tree.appendChild(obj);
  394. },
  395. createResultPatternItem: function(text, title, tree, icon, action, treeNode){
  396. var obj = {
  397. "title": title,
  398. "text": "<span style='color: #000000'>"+text+"</span>",
  399. "icon": icon||"",
  400. "action": action || null
  401. }
  402. var node = (treeNode) ? treeNode.insertChild(obj) : tree.appendChild(obj);
  403. node.addEvent("unselect", function(){
  404. if (this.editor){
  405. if (this.editor.pattern.designerType === "script"){
  406. if (this.scriptDesignerDataObject && this.scriptDesignerDataObject[this.editor.pattern.designerId]){
  407. this.scriptDesignerDataObject[this.editor.pattern.designerId].text = this.editor.getValue();
  408. }
  409. }else{
  410. if (this.designerDataObject && this.designerDataObject[this.editor.pattern.designerId]){
  411. var d = this.designerDataObject[this.editor.pattern.designerId];
  412. if (this.editor.pattern.pattern.path){
  413. var path = this.editor.pattern.pattern.path;
  414. for (var i=0; i<path.length-1; i++){
  415. d = d[path[i]];
  416. }
  417. }
  418. if (path[path.length-1]=="styles"){
  419. d["recoveryStyles"] = this.editor.getValue();
  420. }else if (path[path.length-1]=="inputStyles"){
  421. d["recoveryInputStyles"] = this.editor.getValue();
  422. }else{
  423. d[path[path.length-1]] = this.editor.getValue();
  424. }
  425. //d[path[path.length-1]] = this.editor.getValue();
  426. }
  427. }
  428. this.editor.destroy();
  429. this.editor = null;
  430. this.previewInforNode.show().inject(this.previewContentNode);
  431. }
  432. }.bind(this));
  433. return node;
  434. },
  435. updatePatternCount: function(node){
  436. node.patternCount++;
  437. var textDivNode = node.textNode.getElement("div");
  438. if (textDivNode){
  439. var text = this.lp.patternCount.replace("{n}", node.patternCount)
  440. var t = node.options.text+"&nbsp;&nbsp;<span style='color: #666666'>("+text+")</span>>";
  441. //var html = item.options.text;
  442. textDivNode.set("html", t);
  443. }
  444. },
  445. subPatternCount: function(node){
  446. node.patternCount--;
  447. if (node.patternCount<0) node.patternCount=0;
  448. var textDivNode = node.textNode.getElement("div");
  449. if (textDivNode){
  450. var text = this.lp.patternCount.replace("{n}", node.patternCount)
  451. var t = node.options.text+"&nbsp;&nbsp;<span style='color: #666666'>("+text+")</span>>";
  452. //var html = item.options.text;
  453. textDivNode.set("html", t);
  454. }
  455. },
  456. addResultTitle: function(){
  457. if (!this.patternCount) this.patternCount = 0;
  458. this.patternCount++;
  459. var t = this.lp.findPatternCount.replace("{n}", this.patternCount);
  460. this.listTitleInfoNode.set("text", t);
  461. },
  462. subResultTitle: function(){
  463. if (!this.patternCount) this.patternCount = 1;
  464. this.patternCount--;
  465. var t = this.lp.findPatternCount.replace("{n}", this.patternCount);
  466. this.listTitleInfoNode.set("text", t);
  467. },
  468. showFindResult: function(data,option, treeNode){
  469. this.addResultTitle();
  470. this.listInfoNode.hide();
  471. this.listContentNode.show();
  472. var regexp = this.getFilterOptionRegex(option);
  473. var moduleNode = (this.tree.modules) ? this.tree.modules[data.module] : null;
  474. if (!moduleNode){
  475. moduleNode = this.createResultCategroyItem(this.lp[data.module], this.lp[data.module], this.tree);
  476. moduleNode.patternCount = 0;
  477. if (!this.tree.modules) this.tree.modules = {};
  478. this.tree.modules[data.module] = moduleNode;
  479. }
  480. this.updatePatternCount(moduleNode);
  481. var appNode = (moduleNode.apps) ? moduleNode.apps[data.appId] : null;
  482. if (!appNode){
  483. appNode = this.createResultAppItem(data.appName, data.appName, moduleNode);
  484. appNode.patternCount = 0;
  485. if (!moduleNode.apps) moduleNode.apps = {};
  486. moduleNode.apps[data.appId] = appNode;
  487. }
  488. this.updatePatternCount(appNode);
  489. var typeNode = (appNode.types) ? appNode.types[data.designerType] : null;
  490. if (!typeNode){
  491. typeNode = this.createResultTypeItem(this.lp[data.designerType], this.lp[data.designerType], appNode);
  492. typeNode.patternCount = 0;
  493. if (!appNode.types) appNode.types = {};
  494. appNode.types[data.designerType] = typeNode;
  495. }
  496. this.updatePatternCount(typeNode);
  497. var designerNode = (typeNode.designers) ? typeNode.designers[data.designerId] : null;
  498. if (!designerNode){
  499. designerNode = this.createResultDesignerItem(data.designerName, data.designerName, typeNode);
  500. designerNode.patternCount = 0;
  501. if (!typeNode.designers) typeNode.designers = {};
  502. typeNode.designers[data.designerId] = designerNode;
  503. }
  504. this.updatePatternCount(designerNode);
  505. switch (data.designerType){
  506. case "script":
  507. this.createScriptPatternNode(data, designerNode, regexp, treeNode);
  508. break;
  509. case "form":
  510. case "page":
  511. case "widget":
  512. case "view":
  513. case "statement":
  514. this.createFormPatternNode(data, designerNode, regexp, treeNode);
  515. break;
  516. case "process":
  517. this.createProcessPatternNode(data, designerNode, regexp, treeNode);
  518. break;
  519. }
  520. },
  521. createProcessPatternNode: function(data, node, regexp){
  522. var text = this.lp.elementPattern.replace("{element}", "&lt;"+data.pattern.type+"&gt;"+data.pattern.name).
  523. replace("{property}", "{"+data.pattern.key+"}"+data.pattern.propertyName);
  524. text = "<span style='color: #666666'>"+text+"</span>&nbsp;&nbsp;"
  525. if (data.pattern.line){
  526. if (data.pattern.evkey){
  527. text += "<b>["+data.pattern.evkey+"]</b>&nbsp;"+((data.pattern.line) ? data.pattern.line+"&nbsp;&nbsp;" : "" )+this.getPatternValue(data.pattern.value, regexp);
  528. }else{
  529. text += ((data.pattern.line) ? data.pattern.line+"&nbsp;&nbsp;" : "" )+this.getPatternValue(data.pattern.value, regexp);
  530. }
  531. }else{
  532. text += this.getPatternValue(data.pattern.value, regexp);
  533. }
  534. if (data.pattern.mode){
  535. text = "<b>["+data.pattern.mode+"]</b>&nbsp;"+text;
  536. }
  537. patternNode = this.createResultPatternItem(text, "", node, "icon_"+data.pattern.propertyType+".png");
  538. },
  539. createFormPatternNode: function(data, node, regexp){
  540. var text = this.lp.elementPattern.replace("{element}", "&lt;"+data.pattern.type+"&gt;"+data.pattern.name).
  541. replace("{property}", "{"+data.pattern.key+"}"+data.pattern.propertyName);
  542. text = "<span style='color: #666666'>"+text+"</span>&nbsp;&nbsp;";
  543. var openScript = function(node){
  544. this.openPatternForm(node);
  545. }.bind(this);
  546. if (data.pattern.line){
  547. if (data.pattern.evkey){
  548. text += "<b>["+data.pattern.evkey+"]</b>&nbsp;"+((data.pattern.line) ? data.pattern.line+"&nbsp;&nbsp;" : "" )+this.getPatternValue(data.pattern.value, regexp, data.pattern);
  549. }else{
  550. text += ((data.pattern.line) ? data.pattern.line+"&nbsp;&nbsp;" : "" )+this.getPatternValue(data.pattern.value, regexp, data.pattern);
  551. }
  552. }else{
  553. text += this.getPatternValue(data.pattern.value, regexp, data.pattern);
  554. }
  555. if (data.pattern.mode){
  556. text = "<b>["+data.pattern.mode+"]</b>&nbsp;"+text;
  557. }
  558. patternNode = this.createResultPatternItem(text, "", node, "icon_"+data.pattern.propertyType+".png", openScript);
  559. patternNode.pattern = data;
  560. },
  561. getPatternValue: function(value, regexp, pattern){
  562. regexp.lastIndex = 0;
  563. var valueHtml = "";
  564. var idx = 0;
  565. while ((arr = regexp.exec(value)) !== null) {
  566. if (pattern){
  567. if (!pattern.cols) pattern.cols = [];
  568. pattern.cols.push({"start": arr.index+1, "end": regexp.lastIndex+1});
  569. }
  570. valueHtml += o2.common.encodeHtml(value.substring(idx, arr.index));
  571. valueHtml += "<span style='background-color: #ffef8f'>"+o2.common.encodeHtml(value.substring(arr.index, regexp.lastIndex))+"</span>";
  572. idx = regexp.lastIndex;
  573. }
  574. valueHtml += o2.common.encodeHtml(value.substring(idx, value.length));
  575. return valueHtml;
  576. },
  577. createScriptPatternNode: function(data, node, regexp){
  578. var patternNode;
  579. var text;
  580. var openScript = function(node){
  581. this.openPatternScript(node);
  582. }.bind(this);
  583. if (data.pattern.property=="text"){
  584. text = "<span style='color: #666666'>"+data.pattern.line+"</span>&nbsp;&nbsp;"+this.getPatternValue(data.pattern.value, regexp, data.pattern);
  585. patternNode = this.createResultPatternItem(text, "", node, "icon_script.png", openScript);
  586. }else{
  587. text = this.lp.property+":&nbsp;<b>"+data.pattern.property+"</b> "+this.lp.value+":&nbsp;"+this.getPatternValue(data.pattern.value, regexp);
  588. patternNode = this.createResultPatternItem(text, "", node, "icon_text.png", openScript);
  589. }
  590. patternNode.pattern = data;
  591. },
  592. openPatternForm: function(node){
  593. var pattern = node.pattern;
  594. if (this.editor && this.editor.pattern.designerId === node.pattern.designerId && this.editor.pattern.module === node.pattern.module){
  595. this.resetFormEditor(node.pattern);
  596. }else{
  597. if (this.editor){
  598. if (this.editor.pattern.designerType === "script"){
  599. if (this.scriptDesignerDataObject && this.scriptDesignerDataObject[this.editor.pattern.designerId]){
  600. this.scriptDesignerDataObject[this.editor.pattern.designerId].text = this.editor.getValue();
  601. }
  602. }else{
  603. if (this.designerDataObject && this.designerDataObject[this.editor.pattern.designerId]){
  604. var d = this.designerDataObject[this.editor.pattern.designerId];
  605. if (this.editor.pattern.pattern.path){
  606. var path = this.editor.pattern.pattern.path;
  607. for (var i=0; i<path.length-1; i++){
  608. d = d[path[i]];
  609. }
  610. }
  611. d[path[path.length-1]] = this.editor.getValue();
  612. }
  613. }
  614. this.editor.destroy();
  615. }
  616. this.editor = null;
  617. this.previewInforNode.hide().dispose();
  618. var m;
  619. switch (node.pattern.module){
  620. case "processPlatform":
  621. if (node.pattern.designerType==="form"){
  622. m = o2.Actions.load("x_processplatform_assemble_designer").FormAction.get;
  623. break;
  624. }
  625. if (node.pattern.designerType==="process"){
  626. m = o2.Actions.load("x_processplatform_assemble_designer").ProcessAction.get;
  627. break;
  628. }
  629. break;
  630. case "cms":
  631. //m = o2.Actions.load("x_cms_assemble_control").ScriptAction.get;
  632. break;
  633. case "portal":
  634. //m = o2.Actions.load("x_portal_assemble_designer").ScriptAction.get;
  635. break;
  636. case "service":
  637. //m = (node.pattern.appId==="invoke") ? o2.Actions.load("x_program_center").InvokeAction.get : o2.Actions.load("x_program_center").AgentAction.get;
  638. break;
  639. }
  640. if (m) this.openPatternFormWithData(m, node);
  641. }
  642. },
  643. resetFormEditor: function(pattern){
  644. switch (pattern.pattern.propertyType){
  645. case "html":
  646. case "script":
  647. case "css":
  648. case "sql":
  649. this.reLocationEditor(pattern);
  650. break;
  651. }
  652. },
  653. openPatternFormWithData: function(m, node){
  654. if (this.designerDataObject && this.designerDataObject[node.pattern.designerId]){
  655. this.openPatternFormEditor(this.designerDataObject[node.pattern.designerId], node);
  656. }else{
  657. if (m) m(node.pattern.designerId).then(function(json){
  658. if (json.data){
  659. var data = json.data;
  660. var pcData = JSON.decode(MWF.decodeJsonString(json.data.data));
  661. var mobileData = (json.data.mobileData) ? JSON.decode(MWF.decodeJsonString(json.data.mobileData)) : null;
  662. var d = {"data": pcData, "mobileData": mobileData};
  663. if (!this.designerDataObject) this.designerDataObject = {};
  664. this.designerDataObject[node.pattern.designerId] = d;
  665. this.openPatternFormEditor(d, node);
  666. }
  667. }.bind(this), function(){});
  668. }
  669. },
  670. openPatternFormEditor: function(data, node){
  671. switch (node.pattern.pattern.propertyType){
  672. case "html":
  673. case "script":
  674. case "css":
  675. case "sql":
  676. case "events":
  677. this.openPatternFormEditor_script(data, node);
  678. break;
  679. case "map":
  680. this.openPatternFormEditor_map(data, node);
  681. break;
  682. }
  683. },
  684. openPatternFormEditor_map: function(data, node){
  685. debugger;
  686. var path = node.pattern.pattern.path;
  687. var d = data;
  688. var i=0;
  689. while (i<path.length){
  690. if (path[i]=="styles"){
  691. d.styles = d.recoveryStyles;
  692. }else if (path[i]=="inputStyles"){
  693. d.inputStyles = d.recoveryInputStyles;
  694. }
  695. d = d[path[i]];
  696. i++;
  697. }
  698. if (d){
  699. o2.require("o2.widget.Maplist", function(){
  700. this.editor = new o2.widget.Maplist(this.previewContentNode, {
  701. "onChange": function(){
  702. //this.reFindInFormDesigner();
  703. }.bind(this),
  704. "onPostLoad": function(){
  705. if (this.previewToolbar){
  706. this.previewToolbar.childrenButton[0].enable();
  707. this.previewToolbar.childrenButton[1].enable();
  708. }
  709. }.bind(this),
  710. });
  711. this.editor.pattern = node.pattern;
  712. this.editor.designerNode = node;
  713. this.editor.designerData = data;
  714. this.editor.load(d);
  715. }.bind(this))
  716. }
  717. },
  718. openPatternFormEditor_script: function(data, node){
  719. var path = node.pattern.pattern.path;
  720. var d = data;
  721. var i=0;
  722. while (i<path.length){
  723. d = d[path[i]];
  724. i++;
  725. }
  726. if (d){
  727. o2.require("o2.widget.JavascriptEditor", function(){
  728. this.editor = new o2.widget.JavascriptEditor(this.previewContentNode, {
  729. "option": {
  730. "value": d,
  731. "mode": (!node.pattern.pattern.propertyType || node.pattern.pattern.propertyType==="script") ? "javascript" : node.pattern.pattern.propertyType
  732. }
  733. });
  734. this.editor.pattern = node.pattern;
  735. this.editor.designerNode = node;
  736. this.editor.designerData = data;
  737. this.editor.load(function(){
  738. if (this.previewToolbar){
  739. this.previewToolbar.childrenButton[0].enable();
  740. this.previewToolbar.childrenButton[1].enable();
  741. }
  742. this.editor.addEvent("change", function(){
  743. this.editor.isRefind = true;
  744. }.bind(this));
  745. this.editor.addEvent("blur", function(){
  746. if (this.editor.isRefind) this.reFindInFormDesigner();
  747. }.bind(this));
  748. this.editor.addEvent("destroy", function(){
  749. this.previewToolbar.childrenButton[0].disable();
  750. this.previewToolbar.childrenButton[1].disable();
  751. }.bind(this));
  752. this.editor.addEvent("save", function(){
  753. this.saveDesigner();
  754. }.bind(this));
  755. this.resetFormEditor(node.pattern);
  756. }.bind(this));
  757. }.bind(this));
  758. }
  759. },
  760. openPatternScript: function(node){
  761. var pattern = node.pattern;
  762. if (this.editor && this.editor.pattern.designerId === node.pattern.designerId && this.editor.pattern.module === node.pattern.module){
  763. this.reLocationEditor(node.pattern);
  764. }else{
  765. if (this.editor){
  766. if (this.editor.pattern.designerType === "script"){
  767. if (this.scriptDesignerDataObject && this.scriptDesignerDataObject[this.editor.pattern.designerId]){
  768. this.scriptDesignerDataObject[this.editor.pattern.designerId].text = this.editor.getValue();
  769. }
  770. }else{
  771. if (this.designerDataObject && this.designerDataObject[this.editor.pattern.designerId]){
  772. this.designerDataObject[this.editor.pattern.designerId] = this.editor.designerData;
  773. }
  774. }
  775. this.editor.destroy();
  776. }
  777. this.editor = null;
  778. this.previewInforNode.hide().dispose();
  779. var m;
  780. switch (node.pattern.module){
  781. case "processPlatform":
  782. m = o2.Actions.load("x_processplatform_assemble_designer").ScriptAction.get;
  783. break;
  784. case "cms":
  785. m = o2.Actions.load("x_cms_assemble_control").ScriptAction.get;
  786. break;
  787. case "portal":
  788. m = o2.Actions.load("x_portal_assemble_designer").ScriptAction.get;
  789. break;
  790. case "service":
  791. m = (node.pattern.appId==="invoke") ? o2.Actions.load("x_program_center").InvokeAction.get : o2.Actions.load("x_program_center").AgentAction.get;
  792. break;
  793. }
  794. this.openPatternScriptWithData(m, node);
  795. }
  796. },
  797. openPatternScriptWithData: function(m, node){
  798. if (this.scriptDesignerDataObject && this.scriptDesignerDataObject[node.pattern.designerId]){
  799. this.openPatternScriptEditor(this.scriptDesignerDataObject[node.pattern.designerId], node);
  800. }else{
  801. if (m) m(node.pattern.designerId).then(function(json){
  802. if (!this.scriptDesignerDataObject) this.scriptDesignerDataObject = {};
  803. this.scriptDesignerDataObject[node.pattern.designerId] = json.data;
  804. if (json.data) this.openPatternScriptEditor(json.data, node);
  805. }.bind(this), function(){});
  806. }
  807. },
  808. openPatternScriptEditor: function(data, node){
  809. o2.require("o2.widget.JavascriptEditor", function(){
  810. this.editor = new o2.widget.JavascriptEditor(this.previewContentNode, {
  811. "option": {"value": data.text}
  812. });
  813. this.editor.pattern = node.pattern;
  814. this.editor.designerNode = node.parentNode;
  815. this.editor.designerData = data;
  816. this.editor.load(function(){
  817. if (this.previewToolbar){
  818. this.previewToolbar.childrenButton[0].enable();
  819. this.previewToolbar.childrenButton[1].enable();
  820. }
  821. this.editor.addEvent("change", function(){
  822. this.editor.isRefind = true;
  823. }.bind(this));
  824. this.editor.addEvent("blur", function(){
  825. if (this.editor.isRefind) this.reFindInDesigner();
  826. }.bind(this));
  827. this.editor.addEvent("destroy", function(){
  828. this.previewToolbar.childrenButton[0].disable();
  829. this.previewToolbar.childrenButton[1].disable();
  830. }.bind(this));
  831. this.editor.addEvent("save", function(){
  832. this.saveDesigner();
  833. }.bind(this));
  834. //var idx = node.parentNode.children.indexOf(node);
  835. //this.reFindInDesigner();
  836. this.reLocationEditor(node.pattern);
  837. //if (node.parentNode.children[idx]) node.parentNode.children[idx].clickNode();
  838. }.bind(this));
  839. }.bind(this));
  840. },
  841. findScriptLineValue: function(result, code, preLine, preIndex, len, regex){
  842. var lineRegexp = /\r\n|\n|\r/g;
  843. var preText = code.substring(preIndex, result.index);
  844. var m = preText.match(lineRegexp);
  845. preLine += (m) ? m.length : 0;
  846. var value = result[0];
  847. var n = result.index-1;
  848. var char = code.charAt(n);
  849. while (!lineRegexp.test(char) && n>=0){
  850. value = char+value;
  851. n--;
  852. char = code.charAt(n);
  853. }
  854. n = regex.lastIndex;
  855. char = code.charAt(n);
  856. while (!lineRegexp.test(char) && n<len){
  857. value = value+char;
  858. n++;
  859. char = code.charAt(n);
  860. }
  861. preIndex = regex.lastIndex = n;
  862. return {"value": value, "preLine": preLine, "preIndex": preIndex};
  863. },
  864. reFindInFormDesigner: function(){
  865. debugger;
  866. if (this.editor && this.editor.designerNode){
  867. var pathStr = this.editor.pattern.pattern.path.join(".");
  868. var pNode = this.editor.designerNode.parentNode;
  869. var removeNodes = [];
  870. pNode.children.forEach(function(n){
  871. if (n.pattern.pattern.path && n.pattern.pattern.path.join(".")===pathStr) removeNodes.push(n);
  872. }.bind(this));
  873. for (var i=1; i<removeNodes.length; i++){
  874. removeNodes[i].destroy();
  875. }
  876. flagNode = removeNodes[0];
  877. var pattern = this.editor.pattern;
  878. var code = this.editor.getValue();
  879. if (code){
  880. var regex = this.getFilterOptionRegex(this.filterOption)
  881. regex.lastIndex = 0;
  882. var len = code.length;
  883. var preLine = 0;
  884. var preIndex = 0;
  885. var result;
  886. while ((result = regex.exec(code)) !== null){
  887. var obj = this.findScriptLineValue(result, code, preLine, preIndex, len, regex);
  888. preLine = obj.preLine;
  889. preIndex = obj.preIndex;
  890. this.showFindResult(this._createFindMessageReplyData( this.editor.pattern.module, this.editor.pattern, "", {
  891. "type": pattern.pattern.type,
  892. "propertyType": pattern.pattern.propertyType,
  893. "propertyName": pattern.pattern.propertyName,
  894. "name": pattern.pattern.name,
  895. "key": pattern.pattern.key,
  896. "evkey": pattern.pattern.evkey,
  897. "value": obj.value,
  898. "line": preLine+1,
  899. "mode": pattern.pattern.mode,
  900. "path": pattern.pattern.path
  901. }), this.filterOption, flagNode);
  902. }
  903. }
  904. if (flagNode) flagNode.destroy();
  905. }
  906. this.editor.isRefind = false;
  907. },
  908. reFindInDesigner: function(){
  909. if (this.editor && this.editor.designerNode){
  910. while (this.editor.designerNode.firstChild){
  911. this.editor.designerNode.firstChild.destroy();
  912. this.subResultTitle();
  913. var moduleNode = (this.tree.modules) ? this.tree.modules[this.editor.pattern.module] : null;
  914. if (moduleNode) this.subPatternCount(moduleNode);
  915. var appNode = (moduleNode.apps) ? moduleNode.apps[this.editor.pattern.appId] : null;
  916. if (appNode) this.subPatternCount(appNode);
  917. var typeNode = (appNode.types) ? appNode.types[this.editor.pattern.designerType] : null;
  918. if (typeNode) this.subPatternCount(typeNode);
  919. var designerNode = (typeNode.designers) ? typeNode.designers[this.editor.pattern.designerId] : null;
  920. if (designerNode) this.subPatternCount(designerNode);
  921. }
  922. var code = this.editor.getValue();
  923. if (code){
  924. var regex = this.getFilterOptionRegex(this.filterOption)
  925. regex.lastIndex = 0;
  926. var len = code.length;
  927. var preLine = 0;
  928. var preIndex = 0;
  929. var result;
  930. while ((result = regex.exec(code)) !== null){
  931. var obj = this.findScriptLineValue(result, code, preLine, preIndex, len, regex);
  932. preLine = obj.preLine;
  933. preIndex = obj.preIndex;
  934. this.showFindResult(this._createFindMessageReplyData( this.editor.pattern.module, this.editor.pattern, "", {
  935. "property": "text",
  936. "value": obj.value,
  937. "line": preLine+1
  938. }), this.filterOption);
  939. }
  940. }
  941. }
  942. this.editor.isRefind = false;
  943. },
  944. saveDesigner: function(){
  945. debugger;
  946. if (this.editor && this.editor.pattern){
  947. var pattern = this.editor.pattern;
  948. var data = this.editor.designerData;
  949. switch (pattern.designerType){
  950. case "script":
  951. var m;
  952. switch (pattern.module){
  953. case "processPlatform":
  954. m = o2.Actions.load("x_processplatform_assemble_designer").ScriptAction.put;
  955. break;
  956. case "cms":
  957. m = o2.Actions.load("x_cms_assemble_control").ScriptAction.put;
  958. break;
  959. case "portal":
  960. m = o2.Actions.load("x_portal_assemble_designer").ScriptAction.put;
  961. break;
  962. case "service":
  963. m = (node.pattern.appId==="invoke") ? o2.Actions.load("x_program_center").InvokeAction.update : o2.Actions.load("x_program_center").AgentAction.update;
  964. break;
  965. }
  966. data.text = this.editor.getValue();
  967. if (m) m(data.id, data).then(function(){
  968. this.notice(this.lp.notice.save_success, "success", this.previewContentNode, {"x": "left", "y": "bottom"});
  969. }.bind(this), function(){});
  970. break;
  971. case "form":
  972. switch (pattern.module){
  973. case "processPlatform":
  974. var action = MWF.Actions.get("x_processplatform_assemble_designer");
  975. m = action.saveForm.bind(action);
  976. break;
  977. case "cms":
  978. var action = MWF.Actions.get("x_cms_assemble_control");
  979. m = action.saveForm.bind(action);
  980. break;
  981. }
  982. if (this.designerDataObject && this.designerDataObject[this.editor.pattern.designerId]){
  983. var d = this.designerDataObject[this.editor.pattern.designerId];
  984. if (this.editor.pattern.pattern.path){
  985. var path = this.editor.pattern.pattern.path;
  986. for (var i=0; i<path.length-1; i++){
  987. d = d[path[i]];
  988. }
  989. }
  990. if (path[path.length-1]=="styles"){
  991. d["recoveryStyles"] = this.editor.getValue();
  992. }else if (path[path.length-1]=="inputStyles"){
  993. d["recoveryInputStyles"] = this.editor.getValue();
  994. }else{
  995. d[path[path.length-1]] = this.editor.getValue();
  996. }
  997. }
  998. if (m) m(data.data, data.mobileData, null, function(){
  999. this.notice(this.lp.notice.save_success, "success", this.previewContentNode, {"x": "left", "y": "bottom"});
  1000. }.bind(this), function(){});
  1001. break;
  1002. case "process":
  1003. break;
  1004. }
  1005. }
  1006. },
  1007. openDesinger: function(){
  1008. if (this.editor && this.editor.pattern){
  1009. var pattern = this.editor.pattern;
  1010. switch (pattern.designerType){
  1011. case "script":
  1012. var m;
  1013. switch (pattern.module){
  1014. case "processPlatform":
  1015. var options = {
  1016. "appId": "process.ScriptDesigner"+pattern.designerId,
  1017. "id": pattern.designerId,
  1018. "application": pattern.appId,
  1019. };
  1020. layout.openApplication(null, "process.ScriptDesigner", options);
  1021. break;
  1022. case "cms":
  1023. var options = {
  1024. "appId": "cms.ScriptDesigner"+pattern.designerId,
  1025. "id": pattern.designerId,
  1026. "application": pattern.appId,
  1027. };
  1028. layout.openApplication(null, "cms.ScriptDesigner", options);
  1029. break;
  1030. case "portal":
  1031. var options = {
  1032. "appId": "portal.ScriptDesigner"+pattern.designerId,
  1033. "id": pattern.designerId,
  1034. "application": pattern.appId,
  1035. };
  1036. layout.openApplication(null, "portal.ScriptDesigner", options);
  1037. break;
  1038. case "service":
  1039. if (pattern.appId==="invoke"){
  1040. var options = {
  1041. "appId": "service.InvokeDesigner"+pattern.designerId,
  1042. "id": pattern.designerId,
  1043. };
  1044. layout.openApplication(null, "service.InvokeDesigner", options);
  1045. }else{
  1046. var options = {
  1047. "appId": "service.AgentDesigner"+pattern.designerId,
  1048. "id": pattern.designerId,
  1049. };
  1050. layout.openApplication(null, "service.AgentDesigner", options);
  1051. }
  1052. break;
  1053. }
  1054. break;
  1055. case "form":
  1056. //this.createFormPatternNode(data, designerNode, regexp);
  1057. break;
  1058. case "process":
  1059. break;
  1060. }
  1061. window.setTimeout(function(){
  1062. if (this.scriptDesignerDataObject && this.scriptDesignerDataObject[this.editor.pattern.designerId]){
  1063. this.scriptDesignerDataObject[this.editor.pattern.designerId] = null;
  1064. delete this.scriptDesignerDataObject[this.editor.pattern.designerId];
  1065. }
  1066. if (this.editor) this.editor.destroy();
  1067. this.editor = null;
  1068. this.previewInforNode.show().inject(this.previewContentNode);
  1069. }.bind(this), 100);
  1070. }
  1071. },
  1072. _createFindMessageReplyData: function(module, designer, aliase, pattern){
  1073. return {
  1074. "module": module,
  1075. "appId": designer.appId,
  1076. "appName": designer.appName,
  1077. "designerId": designer.designerId,
  1078. "designerName": designer.designerName,
  1079. "designerType": designer.designerType,
  1080. "designerAliase": aliase,
  1081. "pattern": pattern
  1082. };
  1083. },
  1084. reLocationEditor: function(pattern){
  1085. this.editor.pattern = pattern;
  1086. this.editor.gotoLine(pattern.pattern.line, 1);
  1087. if (pattern.pattern.cols && pattern.pattern.cols.length){
  1088. var rs = [];
  1089. pattern.pattern.cols.forEach(function(col){
  1090. rs.push(this.editor.getRange(pattern.pattern.line,col.start, pattern.pattern.line, col.end));
  1091. }.bind(this));
  1092. this.editor.selectRange(rs);
  1093. }else{
  1094. this.editor.selectRange(this.editor.getRange(pattern.pattern.line,0));
  1095. }
  1096. },
  1097. getFilterOptionRegex: function(option){
  1098. var keyword = option.keyword;
  1099. keyword = keyword.replace("[", "\\[").replace("]", "\\]").replace("(", "\\(").replace(")", "\\)").replace("{", "\\{").replace("}", "\\}")
  1100. .replace("^", "\\^").replace("$", "\\$").replace(".", "\\.").replace("?", "\\?").replace("+", "\\+").replace("*", "\\*").replace("|", "\\|");
  1101. if (option.matchRegExp){
  1102. var flag = (option.caseSensitive) ? "gm" : "gmi";
  1103. return new RegExp(keyword, flag);
  1104. }else{
  1105. var flag = (option.caseSensitive) ? "gm" : "gmi";
  1106. keyword = (option.matchWholeWord) ? "\\b"+keyword+"\\b" : keyword;
  1107. return new RegExp(keyword, flag);
  1108. }
  1109. },
  1110. setReceiveMessage: function(){
  1111. this.listTitleInfoNode.set("text", this.lp.receiveToFind);
  1112. },
  1113. setReadyMessage: function(data){
  1114. this.findOptionModuleCount = data.count;
  1115. this.findOptionModuleProcessed = 0;
  1116. this.updateFindProgress();
  1117. this.listTitleInfoNode.set("text", this.lp.readyToFind.replace("{n}", data.count));
  1118. },
  1119. updateFindProgress: function(){
  1120. var percent = (this.findOptionModuleProcessed/this.findOptionModuleCount)*100;
  1121. this.listTitleProgressNode.setStyle("width", ""+percent+"%");
  1122. },
  1123. getActionsUrl:function(){
  1124. var processHost = o2.Actions.getHost("x_processplatform_assemble_designer");
  1125. var cmsHost = o2.Actions.getHost("x_cms_assemble_control");
  1126. var portalHost = o2.Actions.getHost("x_portal_assemble_designer");
  1127. var queryHost = o2.Actions.getHost("x_query_assemble_designer");
  1128. var serviceHost = o2.Actions.getHost("x_program_center");
  1129. var findHost = o2.Actions.getHost("x_query_service_processing");
  1130. var actions = {
  1131. "listProcess": o2.filterUrl(processHost+"/x_processplatform_assemble_designer/jaxrs/application/list"),
  1132. "listProcessProcess": o2.filterUrl(processHost+"/x_processplatform_assemble_designer/jaxrs/process/application/{applicationId}"),
  1133. "listProcessForm": o2.filterUrl(processHost+"/x_processplatform_assemble_designer/jaxrs/form/list/application/{applicationId}"),
  1134. "listProcessScript": o2.filterUrl(processHost+"/x_processplatform_assemble_designer/jaxrs/script/application/{applicationId}"),
  1135. "getProcessProcess": o2.filterUrl(processHost+"/x_processplatform_assemble_designer/jaxrs/process/{id}"),
  1136. "getProcessForm": o2.filterUrl(processHost+"/x_processplatform_assemble_designer/jaxrs/form/{id}"),
  1137. "getProcessScript": o2.filterUrl(processHost+"/x_processplatform_assemble_designer/jaxrs/script/{id}"),
  1138. "listCms": o2.filterUrl(cmsHost+"/x_cms_assemble_control/jaxrs/appinfo/list/manage"),
  1139. "listCmsForm": o2.filterUrl(cmsHost+"/x_cms_assemble_control/jaxrs/form/list/app/{appId}"),
  1140. "listCmsScript": o2.filterUrl(cmsHost+"/x_cms_assemble_control/jaxrs/script/list/app/{flag}"),
  1141. "getCmsForm": o2.filterUrl(cmsHost+"/x_cms_assemble_control/jaxrs/form/{id}"),
  1142. "getCmsScript": o2.filterUrl(cmsHost+"/x_cms_assemble_control/jaxrs/script/{id}"),
  1143. "listPortal": o2.filterUrl(portalHost+"/x_portal_assemble_designer/jaxrs/portal/list"),
  1144. "listPortalPage": o2.filterUrl(portalHost+"/x_portal_assemble_designer/jaxrs/page/list/portal/{portalId}"),
  1145. "listPortalScript": o2.filterUrl(portalHost+"/x_portal_assemble_designer/jaxrs/script/list/portal/{portalId}"),
  1146. "listPortalWidget": o2.filterUrl(portalHost+"/x_portal_assemble_designer/jaxrs/widget/list/portal/{portalId}"),
  1147. "getPortalPage": o2.filterUrl(portalHost+"/x_portal_assemble_designer/jaxrs/page/{id}"),
  1148. "getPortalScript": o2.filterUrl(portalHost+"/x_portal_assemble_designer/jaxrs/script/{id}"),
  1149. "getPortalWidget": o2.filterUrl(portalHost+"/x_portal_assemble_designer/jaxrs/widget/{id}"),
  1150. "listQuery": o2.filterUrl(queryHost+"/x_query_assemble_designer/jaxrs/query/list/summary"),
  1151. "listQueryView": o2.filterUrl(portalHost+"/x_query_assemble_designer/jaxrs/view/list/query/{flag}"),
  1152. "listQueryStat": o2.filterUrl(portalHost+"/x_query_assemble_designer/jaxrs/stat/list/query/{flag}"),
  1153. "listQueryStatement": o2.filterUrl(portalHost+"/x_query_assemble_designer/jaxrs/statement/list/query/{flag}"),
  1154. "getQueryView": o2.filterUrl(portalHost+"/x_query_assemble_designer/jaxrs/view/{id}"),
  1155. "getQueryStat": o2.filterUrl(portalHost+"/x_query_assemble_designer/jaxrs/stat/{id}"),
  1156. "getQueryStatement": o2.filterUrl(portalHost+"/x_query_assemble_designer/jaxrs/statement/{id}"),
  1157. "listInvoke": o2.filterUrl(serviceHost+"/x_program_center/jaxrs/invoke"),
  1158. "listAgent": o2.filterUrl(serviceHost+"/x_program_center/jaxrs/agent"),
  1159. "getInvoke": o2.filterUrl(serviceHost+"/x_program_center/jaxrs/invoke/{flag}"),
  1160. "getAgent": o2.filterUrl(serviceHost+"/x_program_center/jaxrs/agent/{flag}"),
  1161. "findAction": o2.filterUrl(findHost+"/x_query_service_processing/jaxrs/design/search")
  1162. };
  1163. return actions;
  1164. },
  1165. findDesigner: function(){
  1166. this.listContentNode.hide();
  1167. this.listContentNode.empty();
  1168. this.listInfoNode.show().getFirst().set("text", "");
  1169. this.listInfoNode.addClass("loadding");
  1170. this.patternCount = 0;
  1171. if (this.editor) this.editor.destroy();
  1172. this.editor = null;
  1173. this.previewInforNode.show().inject(this.previewContentNode);
  1174. this.scriptDesignerDataObject = null;
  1175. this.designerDataObject = null;
  1176. this.getFindWorker();
  1177. var actions = this.getActionsUrl();
  1178. this.tree = null;
  1179. this.getResultTree(function(){
  1180. var workerMessage = {
  1181. actions:actions,
  1182. filterOption: this.filterOption,
  1183. debug: (window.layout && layout["debugger"]),
  1184. token: (window.layout && layout.session && layout.session.user) ? layout.session.user.token : ""
  1185. };
  1186. this.findWorker.postMessage(workerMessage);
  1187. }.bind(this));
  1188. },
  1189. //------------------------------------------------------------
  1190. //------------------------------------------------------------
  1191. //------------------------------------------------------------
  1192. //------------------------------------------------------------
  1193. //------------------------------------------------------------
  1194. //------------------------------------------------------------
  1195. //------------------------------------------------------------
  1196. //------------------------------------------------------------
  1197. //------------------------------------------------------------
  1198. //------------------------------------------------------------
  1199. // ------------------------------------------------------------
  1200. // ------------------------------------------------------------
  1201. findDesigner_bak: function(){
  1202. this.listContentNode.hide();
  1203. this.listInfoNode.show().getFirst().set("text", "");
  1204. this.listInfoNode.addClass("loadding")
  1205. o2.Actions.load("x_query_service_processing").DesignAction.search(this.filterOption, function(json){
  1206. if ((json.data.processPlatformList && json.data.processPlatformList.length) ||
  1207. (json.data.cmsList && json.data.cmsList.length) ||
  1208. (json.data.portalList && json.data.portalList.length) ||
  1209. (json.data.queryList && json.data.queryList.length) ||
  1210. (json.data.serviceList && json.data.serviceList.length)){
  1211. this.listInfoNode.hide();
  1212. this.listFindResult(json.data);
  1213. }else{
  1214. this.listInfoNode.show().removeClass("loadding").getFirst().set("text", this.lp.nothingFind);
  1215. }
  1216. }.bind(this));
  1217. },
  1218. createResultAppItem: function(text, title, tree){
  1219. var obj = {
  1220. "title": title,
  1221. "text": "<span style='font-weight: bold; color: #4A90E2'>"+text+"</span>",
  1222. "icon": ""
  1223. }
  1224. return tree.appendChild(obj);
  1225. },
  1226. // createResultDesignerItem: function(designer, tree){
  1227. // var title = this.lp[designer.designerType]+ ": "+ designer.designerName + " ("+designer.designerId+")";
  1228. // var text = this.lp[designer.designerType]+ ": <b>"+ designer.designerName+"</b>";
  1229. // var obj = {
  1230. // "expand": false,
  1231. // "title": title,
  1232. // "text": text,
  1233. // "icon": ""
  1234. // }
  1235. // var item = tree.appendChild(obj);
  1236. // item.designer = designer;
  1237. // item.appendChild({ "expand": false, "text": "loading...", "icon": "" });
  1238. // return item;
  1239. // },
  1240. listFindResult: function(data){
  1241. this.listContentNode.empty();
  1242. this.listContentNode.show();
  1243. o2.require("o2.widget.Tree", function(){
  1244. var tree = new o2.widget.Tree(this.listContentNode, {
  1245. "onQueryExpand": function(item){
  1246. if (item.designer) this.loadDesignerPattern(item);
  1247. }.bind(this)
  1248. });
  1249. tree.load();
  1250. if (data.processPlatformList && data.processPlatformList.length){
  1251. var platformItem = this.createResultCategroyItem(this.lp.processPlatform, this.lp.processPlatform, tree);
  1252. this.listProcessResult(platformItem, data.processPlatformList, "processPlatform");
  1253. }
  1254. if (data.cmsList && data.cmsList.length){
  1255. var platformItem = this.createResultCategroyItem(this.lp.cms, this.lp.cms, tree);
  1256. //this.listProcessResult(categroyItem, data.cmsList);
  1257. }
  1258. if (data.portalList && data.portalList.length){
  1259. var platformItem = this.createResultCategroyItem(this.lp.portal, this.lp.portal, tree);
  1260. }
  1261. if (data.queryList && data.queryList.length){
  1262. var platformItem = this.createResultCategroyItem(this.lp.query, this.lp.query, tree);
  1263. }
  1264. if (data.serviceList && data.serviceList.length){
  1265. var platformItem = this.createResultCategroyItem(this.lp.service, this.lp.service, tree);
  1266. }
  1267. }.bind(this));
  1268. },
  1269. addPatternCount: function(item, count){
  1270. if (!item.count) item.count = 0;
  1271. item.count += count;
  1272. var t = this.lp.patternCount.replace("{n}", item.count);
  1273. var textDivNode = item.textNode.getElement("div");
  1274. if (textDivNode){
  1275. var html = item.options.text;
  1276. textDivNode.set("html", html+" <span style=''>( "+t+" )</span>");
  1277. }
  1278. },
  1279. listProcessResult: function(platformItem, list, platform){
  1280. var applicationItems = {};
  1281. list.each(function(designer){
  1282. if (designer.patternList && designer.patternList.length){
  1283. var appItem = applicationItems[designer.appId];
  1284. if (!appItem){
  1285. applicationItems[designer.appId] = appItem = this.createResultAppItem(designer.appName, designer.appName+" ("+designer.appId+")", platformItem);
  1286. }
  1287. designer.platform = platform;
  1288. var designerItem = this.createResultDesignerItem(designer, appItem);
  1289. var count=0;
  1290. designer.patternList.each(function(p){
  1291. if (p.lines && p.lines.length){
  1292. count += p.lines.length;
  1293. }else{
  1294. count++;
  1295. }
  1296. });
  1297. // var count = designer.patternList.length;
  1298. this.addPatternCount(designerItem, count);
  1299. this.addPatternCount(appItem, count);
  1300. this.addPatternCount(platformItem, count);
  1301. }
  1302. }.bind(this));
  1303. },
  1304. getDesignerObject: function(designer){
  1305. switch (designer.platform){
  1306. case "processPlatform":
  1307. var action = this.Actions.load("x_processplatform_assemble_designer");
  1308. switch (designer.designerType){
  1309. case "script":
  1310. return action.ScriptAction.get(designer.designerId, function(json){return json.data;});
  1311. case "form":
  1312. return action.FomrAction.get(designer.designerId, function(json){return json.data;});
  1313. case "process":
  1314. return action.ProcessAction.get(designer.designerId, function(json){return json.data;});
  1315. }
  1316. case "cms":
  1317. var action = this.Actions.load("x_cms_assemble_control");
  1318. switch (designer.designerType){
  1319. case "script":
  1320. return action.ScriptAction.get(designer.designerId, function(json){return json.data;});
  1321. case "form":
  1322. return action.FormAction.get(designer.designerId, function(json){return json.data;});
  1323. }
  1324. case "portal":
  1325. var action = this.Actions.load("x_portal_assemble_designer");
  1326. switch (designer.designerType){
  1327. case "script":
  1328. return action.ScriptAction.get(designer.designerId, function(json){return json.data;});
  1329. case "page":
  1330. return action.PageAction.get(designer.designerId, function(json){return json.data;});
  1331. case "widget":
  1332. return action.WidgetAction.get(designer.designerId, function(json){return json.data;});
  1333. }
  1334. case "query":
  1335. var action = this.Actions.load("x_query_assemble_designer");
  1336. switch (designer.designerType){
  1337. case "view":
  1338. return action.ViewAction.get(designer.designerId, function(json){return json.data;});
  1339. case "statement":
  1340. return action.StatementAction.get(designer.designerId, function(json){return json.data;});
  1341. case "stat":
  1342. return action.StatAction.get(designer.designerId, function(json){return json.data;});
  1343. }
  1344. case "service":
  1345. var action = this.Actions.load("x_program_center");
  1346. switch (designer.appId){
  1347. case "invoke":
  1348. return action.InvokeAction.get(designer.designerId, function(json){return json.data;});
  1349. case "agent":
  1350. return action.AgentAction.get(designer.designerId, function(json){return json.data;});
  1351. }
  1352. }
  1353. },
  1354. loadDesignerPattern: function(item){
  1355. if (item.firstChild && item.firstChild.options.text==="loading..."){
  1356. item.firstChild.destroy();
  1357. var root, actionName, fun;
  1358. switch (designer.platform) {
  1359. case "processPlatform":
  1360. root = "x_processplatform_assemble_designer";
  1361. switch (designer.designerType) {
  1362. case "script": actionName = "ScriptAction"; fun = "listProcessScriptPattern";
  1363. case "form": actionName = "FomrAction"; fun = "listProcessFormPattern";
  1364. case "process": actionName = "ProcessAction"; fun = "listProcessProcessPattern";
  1365. }
  1366. case "cms":
  1367. root = "x_cms_assemble_control";
  1368. switch (designer.designerType) {
  1369. case "script": actionName = "ScriptAction"; fun = "listCmsScriptPattern";
  1370. case "form": actionName = "FormAction"; fun = "listCmsFormPattern";
  1371. }
  1372. case "portal":
  1373. root = "x_portal_assemble_designer";
  1374. switch (designer.designerType) {
  1375. case "script": actionName = "ScriptAction"; fun = "listPortalScriptPattern";
  1376. case "page": actionName = "PageAction"; fun = "listPortalPagePattern";
  1377. case "widget": actionName = "WidgetAction"; fun = "listPortalWidgetPattern";
  1378. }
  1379. case "query":
  1380. root = "x_query_assemble_designer";
  1381. switch (designer.designerType) {
  1382. case "view": actionName = "ViewAction"; fun = "listQueryViewPattern";
  1383. case "statement": actionName = "StatementAction"; fun = "listQueryStatementPattern";
  1384. case "stat": actionName = "StatAction"; fun = "listQueryStatPattern";
  1385. }
  1386. case "service":
  1387. root = "x_program_center";
  1388. switch (designer.appId) {
  1389. case "invoke": actionName = "InvokeAction"; fun = "listServiceInvokePattern";
  1390. case "agent": actionName = "AgentAction"; fun = "listServiceAgentPattern";
  1391. }
  1392. }
  1393. this.Actions.load(root)[actionName].get(designer.designerId, function(json){
  1394. this[fun](json.data, designer.patternList, item);
  1395. }.bind(this))
  1396. }
  1397. },
  1398. getFindRegExp: function(){
  1399. var flag = "gm";
  1400. var keyword = this.filterOption.keyword;
  1401. if (!this.filterOption.caseSensitive) flag+="i";
  1402. if (this.filterOption.matchRegExp){
  1403. return new RegExp(keyword, flag)
  1404. }else{
  1405. if (this.filterOption.matchWholeWord) keyword = "\\b"+keyword+"\\b";
  1406. return new RegExp(keyword, flag)
  1407. }
  1408. },
  1409. //启动一个webworker处理
  1410. listProcessScriptPattern: function (data, patternList, item){
  1411. patternList.each(function(pattern){
  1412. if (pattern.property == "text"){
  1413. var textArr = data.split("\n");
  1414. var regex = this.getFindRegExp();
  1415. pattern.lines.each(function(line){
  1416. var text = textArr[line];
  1417. }.bind(this));
  1418. }else{
  1419. }
  1420. }.bind(this));
  1421. }
  1422. });