Newer.js 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915
  1. MWF.xDesktop.requireApp("Template", "MPopupForm", null, false);
  2. MWF.xApplication.cms = MWF.xApplication.cms || {};
  3. MWF.xApplication.cms.Index = MWF.xApplication.cms.Index || {};
  4. //MWF.xDesktop.requireApp("cms.Index", "Actions.RestActions", null, false);
  5. MWF.require("MWF.xAction.org.express.RestActions", null, false);
  6. MWF.require("MWF.widget.Mask", null, false);
  7. MWF.xApplication.cms.Index.Newer = new Class({
  8. Extends: MPopupForm,
  9. Implements: [Options, Events],
  10. options: {
  11. "style": "default",
  12. "popupStyle" : "o2platform",
  13. "width": "850",
  14. "height": "510",
  15. "hasTop": true,
  16. "hasIcon": false,
  17. "hasTopContent" : true,
  18. "hasBottom": false,
  19. //"title": MWF.xApplication.cms.Index.LP.createDocument,
  20. "draggable": true,
  21. "closeAction": true,
  22. "latest" : true,
  23. "ignoreTitle" : false,
  24. "ignoreDrafted" : false,
  25. "selectColumnEnable" : true,
  26. "restrictToColumn" : false,
  27. "documentData" : null,
  28. "identity" : null,
  29. //autoSave : "",
  30. //saveOnClose : "",
  31. "categoryFlag" : "", //category id or name
  32. "columnFlag" : "",//column id or name
  33. "appFlag" : "" //column id or name
  34. },
  35. initialize: function (columnData, categoryData, app, view, options) {
  36. this.path = "../x_component_cms_Index/$Newer/";
  37. this.cssPath = "../x_component_cms_Index/$Newer/"+this.options.style+"/css.wcss";
  38. this._loadCss();
  39. MWF.xDesktop.requireApp("cms.Index", "$Newer.lp."+MWF.language, null, false);
  40. this.lp = MWF.xApplication.cms.Index.Newer.lp;
  41. this.options.title = this.lp.createDocument;
  42. this.setOptions(options);
  43. this.columnData = columnData;
  44. this.categoryData = categoryData;
  45. this.app = app;
  46. this.view = view;
  47. this.container = this.app.content;
  48. if( !this.columnData ){
  49. this.initData();
  50. }
  51. if( this.columnData ) {
  52. this.columnData.config = this.columnData.config || {};
  53. if (typeOf(this.columnData.config) === "string") {
  54. this.columnData.config = JSON.parse(this.columnData.config || {});
  55. } else {
  56. this.columnData.config = Object.clone(this.columnData.config || {});
  57. }
  58. if (typeOf(options.ignoreTitle) !== "boolean" && typeOf(this.columnData.config.ignoreTitle) === "boolean") {
  59. this.options.ignoreTitle = this.columnData.config.ignoreTitle;
  60. }
  61. if (typeOf(options.latest) !== "boolean" && typeOf(this.columnData.config.latest) === "boolean") {
  62. this.options.latest = this.columnData.config.latest;
  63. }
  64. }
  65. this.documentAction = MWF.Actions.get("x_cms_assemble_control"); //new MWF.xApplication.cms.Index.Actions.RestActions();
  66. //this.orgAction = new MWF.xAction.org.express.RestActions();
  67. },
  68. initData : function(){
  69. var appId = this.options.appFlag || this.options.columnFlag;
  70. if( !this.columnData && appId){
  71. MWF.Actions.get("x_cms_assemble_control").getColumn( appId, function( json ){
  72. this.columnData = json.data
  73. }.bind(this), null, false)
  74. }
  75. var categoryId = this.options.categoryFlag;
  76. if( !this.categoryData && categoryId ){
  77. MWF.Actions.get("x_cms_assemble_control").getCategory( categoryId, function(js){
  78. this.categoryData = js.data;
  79. if( !this.columnData ){
  80. MWF.Actions.get("x_cms_assemble_control").getColumn( this.categoryData.appId, function( json ){
  81. this.columnData = json.data;
  82. }.bind(this), null, false)
  83. }
  84. }.bind(this), null, false)
  85. }
  86. },
  87. load : function(){
  88. this.initData();
  89. this.identityList = this.getIdentities();
  90. if( !this.categoryData ) { //如果未限定分类
  91. this._load();
  92. this.fireEvent("postLoad");
  93. }else if(this.categoryData.workflowAppId && this.categoryData.workflowFlag ){ //发起审批流程
  94. this._load();
  95. this.fireEvent( "postLoad" );
  96. }else if( this.options.ignoreDrafted ){
  97. this._load();
  98. this.fireEvent( "postLoad" );
  99. }else{
  100. var fielter = {
  101. "categoryIdList": [this.categoryData.id ],
  102. "creatorList": [layout.desktop.session.user.distinguishedName]
  103. };
  104. debugger
  105. this.documentAction.listDraftNext("(0)", 1, fielter, function(json){
  106. if( json.data.length > 0 ){
  107. this._openDocument(json.data[0].id);
  108. this.fireEvent( "postLoad" );
  109. }else{
  110. this._load();
  111. this.fireEvent( "postLoad" );
  112. }
  113. }.bind(this));
  114. }
  115. },
  116. _load : function(){
  117. if( this.categoryData && this.isIgnoreTitle() && this.identityList.length == 1 ) { //信息需要输入标题,数据不需要输入标题
  118. this.okStart();
  119. }else{
  120. this.isNew = true;
  121. this.isEdited = true;
  122. this._open();
  123. this.checkSubject();
  124. if( this.options.selectColumnEnable ){
  125. this.openSel();
  126. }
  127. }
  128. },
  129. openSel : function(){
  130. this.formTopTextNode.set("text", this.lp.selCategory);
  131. if( this.sel ){
  132. this.sel.load();
  133. }else{
  134. this.sel = new MWF.xApplication.cms.Index.Newer.CategorySel(this.app, this.formContentNode, this, this.columnData, this.categoryData, {
  135. restrictToColumn : this.options.restrictToColumn
  136. });
  137. this.sel.load();
  138. }
  139. },
  140. _loadCss: function(){
  141. var key = encodeURIComponent(this.cssPath);
  142. if (MWF.widget.css[key]){
  143. this.css = MWF.widget.css[key];
  144. }else{
  145. this.cssPath = (this.cssPath.indexOf("?")!=-1) ? this.cssPath+"&v="+COMMON.version : this.cssPath+"?v="+COMMON.version;
  146. var r = new Request.JSON({
  147. url: this.cssPath,
  148. secure: false,
  149. async: false,
  150. method: "get",
  151. noCache: false,
  152. onSuccess: function(responseJSON, responseText){
  153. this.css = responseJSON;
  154. MWF.widget.css[key] = responseJSON;
  155. }.bind(this),
  156. onError: function(text, error){
  157. alert(error + text);
  158. }
  159. });
  160. r.send();
  161. }
  162. },
  163. _createTableContent: function () {
  164. var categoryName = this.categoryData ? ( this.categoryData.name || this.categoryData.categoryName ) : this.lp.selectCategory;
  165. var html = "";
  166. if( this.options.selectColumnEnable ){
  167. this.selectArea = new Element("div",{styles:this.css.selectArea}).inject( this.formTableArea );
  168. this.selectContainer = new Element("div",{styles:this.css.selectContainer}).inject( this.selectArea );
  169. //html = "<table width='100%' height='90%' border='0' cellPadding='0' cellSpacing='0'>" +
  170. //"<tr>" +
  171. //"<td style='height: 40px; line-height: 40px; text-align: left; width: 40%' id='form_startColumn'></td>" +
  172. //"<td style='text-align: left;' id='form_startCategory'></td>" +
  173. //"</tr>" +
  174. //"</table>"
  175. html = "<div id='form_startColumn' style='float:left'></div><div id='form_startCategory' style='float:left'></div>";
  176. this.selectContainer.set("html", html);
  177. this.setSelectContent();
  178. }
  179. this.inputContainer = new Element("div",{styles:this.css.inputContainer}).inject( this.formTableArea );
  180. html = "<table width='100%' height='90%' border='0' cellPadding='0' cellSpacing='0'; >" +
  181. "<tr><td colSpan='2' style='height: 60px; line-height: 60px; text-align: center; font-size: 24px; ' id='form_startTitle'>" +
  182. this.lp.start+" - "+categoryName+"</td></tr>" +
  183. "<tr><td style='height: 38px; line-height: 38px; text-align: left; font-size:16px;color:#333;min-width: 100px;'>"+this.lp.department+":</td>" +
  184. "<td style='; text-align: left;' id='form_startDepartment'></td></tr>" +
  185. "<tr><td style='height: 38px; line-height: 38px; text-align: left; font-size:16px;color:#333'>"+this.lp.identity+":</td>" +
  186. "<td style='; text-align: left;'><div id='form_startIdentity'></div></td></tr>" +
  187. "<tr><td style='height: 38px; line-height: 38px; text-align: left; font-size:16px;color:#333'>"+this.lp.date+":</td>" +
  188. "<td style='; text-align: left;'><div id='form_startDate'></div></td></tr>" +
  189. "<tr><td style='height: 38px; line-height: 38px; text-align: left; font-size:16px;color:#333'>"+this.lp.subject+":</td>" +
  190. "<td style='; text-align: left;'><input type='text' id='form_startSubject' " +
  191. "style='width: 99%; border:1px solid #999; background-color:#FFF; border-radius: 3px; box-shadow: 0px 0px 6px #CCC;height: 26px;'/></td></tr>" +
  192. "<tr><td style='height: 38px; line-height: 38px; text-align: left; font-size:16px;color:#333'></td>" +
  193. "<td style='text-align: left;' id='form_startAction'></td></tr>" +
  194. "</table>";
  195. this.inputContainer.set("html", html);
  196. this.setStartFormContent();
  197. this.startActionContainer = this.inputContainer.getElementById("form_startAction");
  198. this.startTitleNode = this.inputContainer.getElementById("form_startTitle");
  199. this.startOkActionNode = new Element("div", {
  200. "styles": this.css.startOkActionNode,
  201. "text": this.lp.ok
  202. }).inject(this.startActionContainer);
  203. this.cancelActionNode = new Element("div", {
  204. "styles": this.css.cancelActionNode,
  205. "text": this.lp.cancel
  206. }).inject(this.startActionContainer);
  207. this.cancelActionNode.addEvent("click", function(e){
  208. this.cancelStart(e);
  209. }.bind(this));
  210. this.startOkActionNode.addEvent("click", function(e){
  211. this.okStart(e);
  212. }.bind(this));
  213. },
  214. isIgnoreTitle : function(){
  215. if( this.options.ignoreTitle )return true;
  216. return this.categoryData && this.categoryData.documentType != "信息"
  217. },
  218. checkSubject: function(){
  219. if( this.categoryData ){
  220. if( this.isIgnoreTitle() ){
  221. if(this.subjectInput)this.subjectInput.getParent("tr").setStyle("display","none");
  222. }else{
  223. if(this.subjectInput)this.subjectInput.getParent("tr").setStyle("display","");
  224. }
  225. }
  226. },
  227. setSelectContent: function(){
  228. this.columnContainer = this.selectContainer.getElementById("form_startColumn");
  229. this.columnContainer.setStyles( this.css.columnContainer );
  230. this.selectContainer.addEvents({
  231. mouseover : function(){
  232. this.columnSelectNode.setStyles( this.css.columnSelectNode_over );
  233. }.bind(this),
  234. mouseout : function(){
  235. this.columnSelectNode.setStyles( this.css.columnSelectNode );
  236. }.bind(this),
  237. click : function(){
  238. this.openSel();
  239. }.bind(this)
  240. });
  241. this.columnIconNode = new Element("img", {styles : this.css.columnIconNode }).inject( this.columnContainer );
  242. if( this.columnData ){
  243. if (this.columnData.appIcon){
  244. this.columnIconNode.set("src", "data:image/png;base64,"+this.columnData.appIcon+"");
  245. }else{
  246. this.columnIconNode.set("src", "../x_component_cms_Index/$Main/default/icon/column.png");
  247. }
  248. }else{
  249. this.columnIconNode.set("src","../x_component_cms_Index/$Main/default/icon/all_40.png");
  250. }
  251. this.columnTextNode = new Element("div", {
  252. styles : this.css.columnTextNode,
  253. text : this.lp.all
  254. } ).inject( this.columnContainer );
  255. this.columnSelectNode = new Element("div", {styles : this.css.columnSelectNode }).inject( this.columnContainer );
  256. this.categoryContainer = this.selectContainer.getElementById("form_startCategory");
  257. this.categoryContainer.setStyles( this.css.categoryContainer );
  258. this.categoryTextNode = new Element("div", {
  259. styles : this.css.categoryTextNode,
  260. text : this.lp.clickForSelect
  261. }).inject( this.categoryContainer );
  262. },
  263. setCurrentColumn: function( column ){
  264. if( this.currentColumn && this.currentColumn != column ){
  265. this.currentColumn.node.setStyles( this.css.columnItemNode );
  266. this.currentColumn.options.isCurrent = false;
  267. }
  268. this.currentColumn = column;
  269. },
  270. setCurrentCategory: function( category ){
  271. if( this.currentCategory && this.currentCategory != category ){
  272. this.currentCategory.node.setStyles( this.css.categoryItemNode );
  273. this.currentCategory.options.isCurrent = false;
  274. }
  275. this.currentCategory = category;
  276. var fielter = {
  277. "categoryIdList": [ category.data.id ],
  278. "creatorList": [layout.desktop.session.user.distinguishedName]
  279. };
  280. this.documentAction.listDraftNext("(0)", 1, fielter, function(j){
  281. if( j.data && j.data.length > 0 && this.options.latest){
  282. this._openDocument(j.data[0].id);
  283. this.close();
  284. }else{
  285. this.documentAction.getColumn( category.data.appId , function( json ){
  286. this.columnData = json.data;
  287. if (this.columnData.appIcon){
  288. this.columnIconNode.set("src", "data:image/png;base64,"+this.columnData.appIcon+"");
  289. }else{
  290. this.columnIconNode.set("src", "../x_component_cms_Index/$Main/default/icon/column.png");
  291. }
  292. this.columnTextNode.set("text", this.columnData.appName);
  293. this.formTopTextNode.set("text", this.lp.createDocument);
  294. this.categoryData = category.data;
  295. this.checkSubject();
  296. this.categoryTextNode.set("text", this.categoryData.categoryName);
  297. this.startTitleNode.set("text",this.lp.start+" - "+this.categoryData.categoryName);
  298. this.sel.closeArea();
  299. if( this.isIgnoreTitle() && this.identityList.length == 1 ){
  300. this.okStart();
  301. }
  302. }.bind(this));
  303. }
  304. }.bind(this));
  305. },
  306. setStartFormContent: function(){
  307. this.dateArea = this.formTableArea.getElementById("form_startDate");
  308. var d = new Date();
  309. this.dateArea.set("text", d.format("%Y-%m-%d %H:%M"));
  310. this.departmentSelArea = this.formTableArea.getElementById("form_startDepartment");
  311. this.identityArea = this.formTableArea.getElementById("form_startIdentity");
  312. this.subjectInput = this.formTableArea.getElementById("form_startSubject");
  313. this.loadDepartments();
  314. },
  315. getIdentities: function(){
  316. var identities = [];
  317. MWF.Actions.get("x_organization_assemble_personal").getPerson(function(json){
  318. var identities1 = (json.data && json.data.woIdentityList) ? json.data.woIdentityList : [];
  319. identities1.each( function(i){
  320. if( this.options.identity ){
  321. if( this.options.identity == i.distinguishedName ){
  322. if( i.distinguishedName )identities.push(i);
  323. }
  324. }else{
  325. if( i.distinguishedName )identities.push(i);
  326. }
  327. }.bind(this));
  328. }.bind(this), null, false );
  329. return identities;
  330. },
  331. loadDepartments: function(){
  332. //MWF.Actions.get("x_organization_assemble_personal").getPerson(function(json){
  333. // var identities1 = (json.data && json.data.woIdentityList) ? json.data.woIdentityList : [];
  334. // var identities = [];
  335. // identities1.each( function(i){
  336. // if( i.distinguishedName )identities.push(i);
  337. // }.bind(this));
  338. // var selected = (identities.length==1) ? true : false;
  339. // identities.each(function(id){
  340. // var departSel = new MWF.xApplication.cms.Index.Newer.DepartmentSel(id, this, this.departmentSelArea, this.identityArea);
  341. // if (selected) departSel.selected();
  342. // }.bind(this));
  343. //}.bind(this), null )
  344. var identities = this.identityList || this.getIdentities() || [];
  345. var selected = (identities.length==1) ? true : false;
  346. identities.each(function(id){
  347. var departSel = new MWF.xApplication.cms.Index.Newer.DepartmentSel(id, this, this.departmentSelArea, this.identityArea);
  348. if (selected) departSel.selected();
  349. }.bind(this));
  350. },
  351. cancelStart: function(e){
  352. var _self = this;
  353. if ( this.subjectInput && this.subjectInput.get("value")){
  354. this.app.confirm("warn", e, this.lp.start_cancel_title, this.lp.start_cancel, "320", "120", function(){
  355. _self.close();
  356. this.close();
  357. },function(){
  358. this.close();
  359. });
  360. }else{
  361. this.close();
  362. }
  363. },
  364. okStart: function(){
  365. if( !this.categoryData ){
  366. this.app.notice(this.lp.selectCategory, "error");
  367. }else{
  368. if( this.categoryData.workflowAppId && this.categoryData.workflowFlag ){
  369. this._createProcessDocument();
  370. }else{
  371. this._createDocument();
  372. }
  373. }
  374. },
  375. _createDocument: function(e){
  376. var title = this.subjectInput ? this.subjectInput.get("value") : "";
  377. if( !title && this.options.documentData ){
  378. title = this.options.documentData.title || this.options.documentData.subject || "";
  379. }
  380. var identity = "";
  381. if( this.options.identity ){
  382. identity = this.options.identity;
  383. }else if( this.identityArea ){
  384. identity = this.identityArea.get("value");
  385. }else if( this.identityList.length > 0 ){
  386. identity = this.identityList[0].distinguishedName;
  387. }
  388. var data = {
  389. "id" : this.documentAction.getUUID(),
  390. "isNewDocument" : true,
  391. "title": title,
  392. "creatorIdentity": identity,
  393. "identity" : identity,
  394. "appId" :this.categoryData.appId,
  395. "categoryId" : this.categoryData.id,
  396. "form" : this.categoryData.formId,
  397. "formName" :this.categoryData.formName,
  398. "docStatus" : "draft",
  399. "categoryName" : this.categoryData.name || this.categoryData.categoryName,
  400. "categoryAlias" : this.categoryData.alias || this.categoryData.categoryAlias,
  401. "attachmentList" : []
  402. };
  403. if( this.options.documentData ){
  404. data.docData = this.options.documentData;
  405. }
  406. if (!data.title && !this.isIgnoreTitle()){
  407. if(this.subjectInput)this.subjectInput.setStyle("border-color", "red");
  408. if(this.subjectInput)this.subjectInput.focus();
  409. this.app.notice(this.lp.inputSubject, "error");
  410. }else if (!data.creatorIdentity){
  411. this.departmentSelArea.setStyle("border-color", "red");
  412. this.app.notice(this.lp.selectStartId, "error");
  413. }else{
  414. if( this.isIgnoreTitle() && !data.title )data.title = "无标题";
  415. if( this.formAreaNode ){
  416. this.mask = new MWF.widget.Mask({"style": "desktop"});
  417. this.mask.loadNode(this.formAreaNode);
  418. }
  419. this.documentAction.addDocument( data, function(json){
  420. if( this.mask )this.mask.hide();
  421. //this.markNode.destroy();
  422. this.close();
  423. this.fireEvent("started", [json.data.id, data]);
  424. this._openDocument( json.data.id );
  425. //this.fireEvent("started", [json.data, title, this.categoryData.name]);
  426. //this.app.refreshAll();
  427. this.app.notice(this.lp.Started, "success");
  428. // this.app.processConfig();
  429. }.bind(this), function(xhr, text, error){
  430. if( xhr && xhr.response && typeOf(xhr.response)==="string" ){
  431. try{
  432. var eObj = JSON.parse(xhr.response);
  433. this.app.notice( eObj.message, "error");
  434. }catch (e) {}
  435. }
  436. if( this.mask )this.mask.hide();
  437. }.bind(this));
  438. }
  439. },
  440. _openDocument: function(id,el){
  441. var _self = this;
  442. var appId = "cms.Document"+id;
  443. if (_self.app.desktop.apps[appId]){
  444. _self.app.desktop.apps[appId].setCurrent();
  445. }else {
  446. var options = {
  447. "readonly" :false,
  448. "documentId": id,
  449. "appId": appId,
  450. "onPostPublish" : function( args ){
  451. this.fireEvent( "postPublish", args );
  452. }.bind(this),
  453. "onAfterPublish" : function ( args ) {
  454. debugger;
  455. if(_self.view && _self.view.reload )_self.view.reload();
  456. _self.fireEvent( "afterPublish", args );
  457. }
  458. };
  459. if( typeOf(this.options.autoSave) == "boolean" )options.autoSave = this.options.autoSave;
  460. if( typeOf(this.options.saveOnClose) == "boolean" )options.saveOnClose = this.options.saveOnClose;
  461. this.app.desktop.openApplication(el, "cms.Document", options);
  462. }
  463. },
  464. _createProcessDocument:function(e){
  465. var title = this.subjectInput ? this.subjectInput.get("value") : "";
  466. if( !title && this.options.documentData ){
  467. title = this.options.documentData.title || this.options.documentData.subject || "";
  468. }
  469. var identity = "";
  470. if( this.options.identity ){
  471. identity = this.options.identity;
  472. }else if( this.identityArea ){
  473. identity = this.identityArea.get("value");
  474. }else if( this.identityList.length > 0 ){
  475. identity = this.identityList[0].distinguishedName;
  476. }
  477. var processId = this.categoryData.workflowFlag;
  478. var data = {
  479. "title":title,
  480. "identity": identity
  481. };
  482. if (!data.title && !this.isIgnoreTitle() ){
  483. this.subjectInput.setStyle("border-color", "red");
  484. this.subjectInput.focus();
  485. this.app.notice(this.lp.inputSubject, "error");
  486. }else if (!data.identity){
  487. this.departmentSelArea.setStyle("border-color", "red");
  488. this.app.notice(this.lp.selectStartId, "error");
  489. }else{
  490. if( this.isIgnoreTitle() && !title )title = "无标题";
  491. var workData;
  492. if( this.options.documentData ){
  493. workData = Object.clone(this.options.documentData);
  494. }else{
  495. workData = {};
  496. }
  497. workData.cmsDocument = {
  498. "isNewDocument" : true,
  499. "title": title,
  500. "creatorIdentity": data.identity,
  501. "identity": data.identity,
  502. "appId" :this.categoryData.appId,
  503. "categoryId" : this.categoryData.id,
  504. //"form" : this.categoryData.formId,
  505. //"formName" :this.categoryData.formName,
  506. "docStatus" : "draft",
  507. "categoryName" : this.categoryData.name,
  508. "categoryAlias" : this.categoryData.alias,
  509. "createTime": new Date().format("db"),
  510. "attachmentList" : []
  511. };
  512. if( this.formAreaNode ){
  513. this.mask = new MWF.widget.Mask({"style": "desktop"});
  514. this.mask.loadNode(this.formAreaNode);
  515. }
  516. MWF.Actions.get("x_processplatform_assemble_surface").startWork( function( json ){
  517. if(this.mask)this.mask.hide();
  518. //this.markNode.destroy();
  519. this.close();
  520. this.afterStartProcess( json.data, data.title, this.categoryData.workflowName, workData );
  521. //this.fireEvent("started", [json.data, title, this.categoryData.name]);
  522. //this.app.refreshAll();
  523. this.app.notice(this.lp.Started, "success");
  524. }.bind(this), null, processId, data)
  525. }
  526. },
  527. afterStartProcess: function(data, title, processName, workData){
  528. var workInfors = [];
  529. var currentTask = [];
  530. data.each(function(work){
  531. if (work.currentTaskIndex != -1) currentTask.push(work.taskList[work.currentTaskIndex].work);
  532. workInfors.push(this.getStartWorkInforObj(work));
  533. }.bind(this));
  534. var workId = currentTask[0];
  535. MWF.Actions.get("x_processplatform_assemble_surface").saveData(function(){
  536. this.fireEvent("started", [workId, workData]);
  537. if (currentTask.length==1){
  538. var options = {"workId": workId};
  539. this.app.desktop.openApplication(null, "process.Work", options);
  540. this.createStartWorkResault(workInfors, title, processName, false);
  541. }else{
  542. this.createStartWorkResault(workInfors, title, processName, true);
  543. }
  544. }.bind(this), null, workId, workData)
  545. },
  546. getStartWorkInforObj: function(work){
  547. var users = [];
  548. var currentTask = "";
  549. work.taskList.each(function(task, idx){
  550. users.push(task.identity.split("@")[0]+"("+task.unit.split("@")[0] + ")");
  551. if (work.currentTaskIndex==idx) currentTask = task.id;
  552. }.bind(this));
  553. return {"activity": work.fromActivityName, "users": users, "currentTask": currentTask};
  554. },
  555. createStartWorkResault: function(workInfors, title, processName, isopen){
  556. var content = "";
  557. workInfors.each(function(infor){
  558. content += "<div><b>"+this.lp.nextActivity+"<font style='color: #ea621f'>"+infor.activity+"</font>, "+this.lp.nextUser+"<font style='color: #ea621f'>"+infor.users.join(", ")+"</font></b>";
  559. if (infor.currentTask && isopen){
  560. content += "&nbsp;&nbsp;&nbsp;&nbsp;<span value='"+infor.currentTask+"'>"+this.lp.deal+"</span></div>";
  561. }else{
  562. content += "</div>";
  563. }
  564. }.bind(this));
  565. var msg = {
  566. "subject": this.lp.processStarted,
  567. "content": "<div>"+this.lp.processStartedMessage+"“["+processName+"]"+title+"”</div>"+content
  568. };
  569. var tooltip = layout.desktop.message.addTooltip(msg);
  570. var item = layout.desktop.message.addMessage(msg);
  571. this.setStartWorkResaultAction(tooltip);
  572. this.setStartWorkResaultAction(item);
  573. },
  574. setStartWorkResaultAction: function(item){
  575. var node = item.node.getElements("span");
  576. node.setStyles(this.css.dealStartedWorkAction);
  577. var _self = this;
  578. node.addEvent("click", function(e){
  579. var options = {"taskId": this.get("value")};
  580. _self.app.desktop.openApplication(e, "process.Work", options);
  581. });
  582. }
  583. });
  584. MWF.xApplication.cms.Index.Newer.DepartmentSel = new Class({
  585. initialize: function(data, starter, container, idArea){
  586. this.data = data;
  587. this.starter = starter;
  588. this.container = container;
  589. this.idArea = idArea;
  590. this.css = this.starter.css;
  591. this.isSelected = false;
  592. this.load();
  593. },
  594. load: function(){
  595. this.node = new Element("div", {"styles": this.css.departSelNode}).inject(this.container);
  596. //this.starter.documentAction.listDepartmentWithIdentity(function(department){
  597. // var unitList = department.data && department.data.unitList ? department.data.unitList : [""];
  598. // this.node.set("text", unitList[0]);
  599. //}.bind(this), null, { "identityList" : [ this.data.distinguishedName ] } );
  600. var unit = this.data.woUnit ? this.data.woUnit.name : this.lp.unnamedUnit;
  601. this.node.set("text",this.data.woUnit.name);
  602. this.node.addEvents({
  603. "mouseover": function(){if (!this.isSelected) this.node.setStyles(this.css.departSelNode_over);}.bind(this),
  604. "mouseout": function(){if (!this.isSelected) this.node.setStyles(this.css.departSelNode_out);}.bind(this),
  605. "click": function(){
  606. this.selected();
  607. }.bind(this)
  608. });
  609. },
  610. selected: function(){
  611. if (!this.isSelected){
  612. if (this.starter.currentDepartment) this.starter.currentDepartment.unSelected();
  613. this.node.setStyles(this.css.departSelNode_selected);
  614. this.isSelected = true;
  615. this.starter.currentDepartment = this;
  616. this.idArea.set({
  617. "text": this.data.name,
  618. "value": this.data.distinguishedName
  619. });
  620. }
  621. },
  622. unSelected: function(){
  623. if (this.isSelected){
  624. if (this.starter.currentDepartment) this.starter.currentDepartment = null;
  625. this.node.setStyles(this.css.departSelNode);
  626. this.isSelected = false;
  627. }
  628. }
  629. });
  630. MWF.xApplication.cms.Index.Newer.CategorySel = new Class({
  631. Extends: MWF.widget.Common,
  632. Implements: [Options, Events],
  633. options: {
  634. "style": "default",
  635. "restrictToColumn" : false
  636. },
  637. initialize: function(app, node, newer, columnData, categoryData, options){
  638. this.setOptions(options);
  639. this.node = node;
  640. this.newer = newer;
  641. this.lp = newer.lp;
  642. this.css = newer.css;
  643. this.action = newer.documentAction;
  644. this.columnData = columnData;
  645. this.categoryData = categoryData;
  646. },
  647. load: function(){
  648. if (!this.areaNode){
  649. this.createArea();
  650. }
  651. this.areaNode.fade("1");
  652. },
  653. closeArea: function(){
  654. if (this.areaNode) this.areaNode.fade("out");
  655. },
  656. createArea: function(){
  657. this.areaNode = new Element("div.categorySelAreaNode", {"styles": this.css.categorySelAreaNode}).inject(this.node );
  658. this.areaNode.addEvent("click", function(e){
  659. //this.closeArea();
  660. }.bind(this));
  661. this.columnContainer = new Element("div", {"styles": this.css.selColumnAreaNode}).inject( this.areaNode );
  662. this.columnScrollNode = new Element("div.columnScrollNode", {"styles": this.css.selColumnScrollNode}).inject(this.columnContainer);
  663. this.setScrollBar( this.columnScrollNode );
  664. this.columnContentNode = new Element("div.selColumnContentNode", {"styles": this.css.selColumnContentNode}).inject(this.columnScrollNode);
  665. this.categoryContainer = new Element("div", {"styles": this.css.selCategoryAreaNode}).inject( this.areaNode );
  666. this.categoryScrollNode = new Element("div", {"styles": this.css.selCategoryScrollNode}).inject(this.categoryContainer);
  667. this.setScrollBar( this.categoryScrollNode );
  668. this.categoryContentNode = new Element("div", {"styles": this.css.selCategoryContentNode}).inject(this.categoryScrollNode);
  669. if( this.options.restrictToColumn && this.columnData ){
  670. new MWF.xApplication.cms.Index.Newer.CategorySel.Column(this.columnData, this.app, this.newer, this.columnContentNode, this.categoryContentNode, {
  671. "needGetCategorys": true,
  672. "isCurrent": true,
  673. "currentCategory" : this.categoryData ? this.categoryData.id : "",
  674. "restrictToColumn" : this.options.restrictToColumn
  675. });
  676. }else{
  677. this.listColumns();
  678. }
  679. },
  680. listColumns: function(){
  681. var c = { wrapOutCategoryList : [] };
  682. this.action.listColumnByPublish(function(json){
  683. json.data.each(function(column){
  684. if(!column.name)column.name = column.appName;
  685. if( column.wrapOutCategoryList && column.wrapOutCategoryList.length ){
  686. column.wrapOutCategoryList.each(function(category){
  687. c.wrapOutCategoryList.push(category);
  688. }.bind(this));
  689. }
  690. }.bind(this));
  691. new MWF.xApplication.cms.Index.Newer.CategorySel.Column(c, this.app, this.newer, this.columnContentNode, this.categoryContentNode, {
  692. "needGetCategorys": false,
  693. "isAll" : true,
  694. "isCurrent" : this.columnData ? false : true,
  695. "currentCategory" : this.categoryData ? this.categoryData.id : "",
  696. "restrictToColumn" : this.options.restrictToColumn
  697. });
  698. json.data.each( function(column) {
  699. if(!column.name)column.name = column.appName;
  700. new MWF.xApplication.cms.Index.Newer.CategorySel.Column(column, this.app, this.newer, this.columnContentNode, this.categoryContentNode, {
  701. "needGetCategorys": false,
  702. "isCurrent": ( this.columnData && this.columnData.id == column.id) ? true : false,
  703. "currentCategory" : this.categoryData ? this.categoryData.id : "",
  704. "restrictToColumn" : this.options.restrictToColumn
  705. });
  706. }.bind(this) )
  707. }.bind(this));
  708. }
  709. });
  710. MWF.xApplication.cms.Index.Newer.CategorySel.Column = new Class({
  711. Implements: [Options],
  712. options: {
  713. "needGetCategorys": false,
  714. "isAll" : false,
  715. "isCurrent" : false,
  716. "currentCategory" : "",
  717. "restrictToColumn" : false
  718. },
  719. initialize: function(data, app, newer, container, categoryContainer, options ){
  720. this.setOptions( options );
  721. this.data = data;
  722. this.app = app;
  723. this.newer = newer;
  724. this.lp = newer.lp;
  725. this.css = newer.css;
  726. this.action = newer.documentAction;
  727. this.container = container;
  728. this.categoryContainer = categoryContainer;
  729. this.load();
  730. },
  731. load: function(){
  732. this.node = new Element("div", {"styles": this.css.columnItemNode}).inject(this.container);
  733. var iconNode = this.iconNode = new Element("img",{
  734. "styles" : this.css.columnItemIconNode
  735. }).inject(this.node);
  736. if( this.options.isAll ){
  737. this.iconNode.set("src", "../x_component_cms_Index/$Main/default/icon/all_40.png")
  738. }else if (this.data.appIcon){
  739. this.iconNode.set("src", "data:image/png;base64,"+this.data.appIcon+"");
  740. }else{
  741. this.iconNode.set("src", "../x_component_cms_Index/$Main/default/icon/column.png")
  742. }
  743. this.textNode = new Element("div", {"styles": this.css.columnItemTextNode}).inject(this.node);
  744. if( this.options.isAll ){
  745. this.textNode.set("text", this.lp.all);
  746. }else{
  747. this.textNode.set("text", (this.data.name || this.data.appName) );
  748. }
  749. if( this.options.isAll ){
  750. //new Element("div", {"styles": this.css.columnSelectNode}).inject(this.node);
  751. }
  752. this.node.addEvents({
  753. "mouseover" : function(){ if( !this.options.isCurrent )this.node.setStyles( this.css.columnItemNode_over ) }.bind(this),
  754. "mouseout" : function(){ if( !this.options.isCurrent )this.node.setStyles( this.css.columnItemNode ) }.bind(this),
  755. "click" : function(){ this.setCurrent(); }.bind(this)
  756. });
  757. if( this.options.isCurrent )this.setCurrent();
  758. },
  759. setCurrent: function(){
  760. this.options.isCurrent = true;
  761. this.node.setStyles( this.css.columnItemNode_current );
  762. this.newer.setCurrentColumn( this );
  763. this.loadCategory();
  764. },
  765. loadCategory: function(){
  766. this.categoryContainer.empty();
  767. if( this.options.needGetCategorys ){
  768. this.action.listCategoryByPublisher(this.data.id,function(json){
  769. if (json.data.length){
  770. var isSetCurrentImmediately = ( json.data.length == 1 && ( this.options.restrictToColumn || this.options.isAll ) );
  771. json.data.each(function(category){
  772. new MWF.xApplication.cms.Index.Newer.CategorySel.Category(category, this, this.categoryContainer, {
  773. isCurrent : ( this.options.currentCategory == category.id ) || isSetCurrentImmediately
  774. });
  775. }.bind(this));
  776. }else{
  777. this.node.setStyle("display", "none");
  778. }
  779. }.bind(this), null, this.data.id);
  780. }else{
  781. if( this.data.wrapOutCategoryList && this.data.wrapOutCategoryList.length ){
  782. var isSetCurrentImmediately = ( this.data.wrapOutCategoryList.length == 1 && ( this.options.restrictToColumn || this.options.isAll ) );
  783. this.data.wrapOutCategoryList.each(function(category){
  784. new MWF.xApplication.cms.Index.Newer.CategorySel.Category(category, this, this.categoryContainer,{
  785. isCurrent : ( this.options.currentCategory == category.id ) || isSetCurrentImmediately
  786. });
  787. }.bind(this));
  788. }else{
  789. this.node.setStyle("display", "none");
  790. }
  791. }
  792. }
  793. });
  794. MWF.xApplication.cms.Index.Newer.CategorySel.Category = new Class({
  795. Implements: [Options],
  796. options: {
  797. "isCurrent" : false
  798. },
  799. initialize: function(data, column, container, options){
  800. this.setOptions( options );
  801. this.data = data;
  802. this.column = column;
  803. this.app = this.column.app;
  804. this.newer = this.column.newer;
  805. this.container = container;
  806. this.css = this.newer.css;
  807. this.load();
  808. },
  809. load: function(){
  810. if( !this.data.name )this.data.name = this.data.categoryName;
  811. this.node = new Element("div.categoryItem", {"styles": this.css.categoryItemNode}).inject(this.container);
  812. if( this.options.isCurrent )this.node.setStyles( this.css.categoryItemNode_over );
  813. this.textNode = new Element("div", {"styles": this.css.categoryItemTextNode}).inject(this.node);
  814. this.textNode.set({
  815. "text": this.data.categoryName
  816. });
  817. var _self = this;
  818. this.node.addEvents({
  819. "mouseover": function(e){if( !this.options.isCurrent )this.node.setStyles(this.css.categoryItemNode_over); }.bind(this),
  820. "mouseout": function(e){if( !this.options.isCurrent )this.node.setStyles(this.css.categoryItemNode);}.bind(this),
  821. "click": function(e){
  822. this.setCurrent();
  823. }.bind(this)
  824. });
  825. if( this.options.isCurrent )this.setCurrent();
  826. },
  827. setCurrent: function(){
  828. this.options.isCurrent = true;
  829. this.node.setStyles( this.css.categoryItemNode_current );
  830. this.newer.setCurrentCategory( this );
  831. }
  832. });