rpt_signature.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387
  1. /**
  2. * Created by Tony on 2019/9/25.
  3. */
  4. 'use strict'
  5. let rptSignatureHelper = {
  6. currentSelectedESignAccDom: null,
  7. currentSelectedESignAccName: null,
  8. originalRoleRelList: [],
  9. buildSelectableAccount: function () {
  10. //PRJ_ACCOUNT_LIST
  11. //1. 清理所有选择项
  12. // $("#project_account_select_div").empty();
  13. let accDiv = $('#project_account_select_div');
  14. let accSelect = $('#project_account_select_dom'); //绑定成员
  15. accDiv.empty();
  16. accSelect.empty();
  17. //2. 一个个加可选用户项
  18. const prj_accounts = [];
  19. const prj_sel_option_accounts = [];
  20. const acc_role_keys = [];
  21. for (let accIdx = 0; accIdx < PRJ_ACCOUNT_LIST.length; accIdx++) {
  22. const prjAccount = PRJ_ACCOUNT_LIST[accIdx];
  23. let companyKey = prjAccount.company;
  24. let roleKey = prjAccount.role;
  25. if (companyKey === '') {
  26. companyKey = '其他单位';
  27. }
  28. if (roleKey === '') {
  29. roleKey = '工程师';
  30. }
  31. let keyIdx = acc_role_keys.indexOf(companyKey);
  32. if (keyIdx < 0) {
  33. acc_role_keys.push(companyKey);
  34. prj_accounts.push([]);
  35. prj_sel_option_accounts.push([]);
  36. keyIdx = prj_accounts.length - 1;
  37. //这里先push一些 html prefix,在后面统一在push html suffix
  38. prj_accounts[keyIdx].push('<ul class="list-group">');
  39. prj_accounts[keyIdx].push('<li class="px-2 text-muted"><i class="fa fa-caret-down"></i> ' + companyKey + '</li>');
  40. prj_sel_option_accounts[keyIdx].push('<optgroup label=" ' + companyKey + '">');
  41. }
  42. //push item
  43. prj_accounts[keyIdx].push('<li class="add-sign-list-item"><a href="javascript:void(0)" onclick="rptSignatureHelper.createEsignatureByAccIdx(' + accIdx + ')" class="btn-link pull-right" title="添加" data-dismiss="modal"><i class="fa fa-plus"></i></a>' +
  44. prjAccount.name + '-<small class="text-muted">' + roleKey + '</small></li>');
  45. prj_sel_option_accounts[keyIdx].push('<option value="' + accIdx + '">' + prjAccount.name + '-' + roleKey + '</option>');
  46. }
  47. for (const prjAccList of prj_accounts) {
  48. prjAccList.push('</ul>');
  49. }
  50. for (const prjAccList of prj_sel_option_accounts) {
  51. prjAccList.push('</optgroup>');
  52. }
  53. for (let idx = 0; idx < prj_accounts.length; idx++) {
  54. prj_accounts[idx] = prj_accounts[idx].join('');
  55. prj_sel_option_accounts[idx] = prj_sel_option_accounts[idx].join('');
  56. }
  57. accDiv.append(prj_accounts.join(''));
  58. accSelect.append(prj_sel_option_accounts.join(''));
  59. },
  60. createEsignatureByAccIdx: function (accIdx) {
  61. rptSignatureHelper.createPreSelectedSignature(PRJ_ACCOUNT_LIST[accIdx], null);
  62. },
  63. createEsignatureByRoleIdx: function (roleIdx) {
  64. rptSignatureHelper.createPreSelectedSignature(null, ROLE_LIST[roleIdx]);
  65. },
  66. createPreSelectedSignature: function (directAcc, roleAcc) {
  67. let dftSignSrc = '/public/images/user-sign.PNG';
  68. let userAcc = directAcc;
  69. if (roleAcc) {
  70. userAcc = rptSignatureHelper.getUserAccount(roleAcc.bind_acc_id);
  71. }
  72. if (userAcc.sign_path !== '') {
  73. dftSignSrc = '/public/images/' + userAcc.sign_path;
  74. }
  75. if (rptSignatureHelper.currentSelectedESignAccName !== null) {
  76. for (const page of zTreeOprObj.currentRptPageRst.items) {
  77. if (page.signature_cells) {
  78. for (const sCell of page.signature_cells) {
  79. if (sCell.signature_name === rptSignatureHelper.currentSelectedESignAccName) {
  80. sCell.pre_path = dftSignSrc;
  81. }
  82. }
  83. }
  84. }
  85. // 1. 删除不需要的child dom
  86. $(rptSignatureHelper.currentSelectedESignAccDom).empty();
  87. // 2. 创建已选择签名相关 dom
  88. rptSignatureHelper.cleanOldSignature(rptSignatureHelper.currentSelectedESignAccName);
  89. // 2.1 dom element
  90. const elementsStrArr = [];
  91. if (directAcc) {
  92. rptSignatureHelper.pushDomElementByUser(elementsStrArr, userAcc.name, userAcc.role);
  93. // 还有ROLE_REL_LIST
  94. let roleRelObj = {};
  95. roleRelObj.signature_name = rptSignatureHelper.currentSelectedESignAccName;
  96. roleRelObj.sign_path = dftSignSrc;
  97. roleRelObj.sign_date = '';
  98. roleRelObj.sign_date_format = 'yyyy年M月d日';
  99. roleRelObj.user_name = userAcc.name;
  100. roleRelObj.acc_id = userAcc.id;
  101. roleRelObj.type = '用户';
  102. roleRelObj.role = (userAcc.role === '')?"工程师":userAcc.role;
  103. ROLE_REL_LIST.push(roleRelObj);
  104. } else if (roleAcc) {
  105. // 创建相关dom元素
  106. rptSignatureHelper.pushDomElementByRole(elementsStrArr, roleAcc.name, userAcc.name);
  107. // 还有ROLE_REL_LIST
  108. let roleRelObj = {};
  109. roleRelObj.signature_name = rptSignatureHelper.currentSelectedESignAccName;
  110. roleRelObj.sign_path = dftSignSrc;
  111. roleRelObj.sign_date = '';
  112. roleRelObj.sign_date_format = 'yyyy年M月d日';
  113. roleRelObj.user_name = userAcc.name;
  114. roleRelObj.acc_id = userAcc.id;
  115. roleRelObj.type = '角色';
  116. roleRelObj.role = (userAcc.role === '')?"工程师":userAcc.role;
  117. roleRelObj.role_name = roleAcc.name;
  118. ROLE_REL_LIST.push(roleRelObj);
  119. }
  120. // elementsStrArr.push('');
  121. $(rptSignatureHelper.currentSelectedESignAccDom).append(elementsStrArr.join(' '));
  122. //.appendChild(pNode);
  123. //*/
  124. // 2.2 date-picker
  125. }
  126. },
  127. cleanOldSignature: function (signature_name) {
  128. // 清掉ROLE_REL_LIST原有的签名
  129. for (let idx = ROLE_REL_LIST.length - 1; idx >= 0 ; idx--) {
  130. if (ROLE_REL_LIST[idx].signature_name === signature_name) {
  131. ROLE_REL_LIST.splice(idx, 1);
  132. }
  133. }
  134. },
  135. resetESignature: function (pageRst) {
  136. let body = $('#eSignatureBodyDiv');
  137. body.empty();
  138. const signature_cells = [];
  139. const singatureNameArr = [];
  140. for (const page of pageRst.items) {
  141. if (page.signature_cells) {
  142. for (const sCell of page.signature_cells) {
  143. if (singatureNameArr.indexOf(sCell.signature_name) < 0) {
  144. signature_cells.push(sCell);
  145. singatureNameArr.push(sCell.signature_name);
  146. }
  147. }
  148. }
  149. }
  150. if (signature_cells.length > 0) {
  151. const elementsStrArr = [];
  152. const elementsDateStrArr = [];
  153. for (let scIdx = 0; scIdx < signature_cells.length; scIdx++) {
  154. const sCell = signature_cells[scIdx];
  155. elementsStrArr.push('<div class="form-group row">');
  156. elementsStrArr.push('<label for="staticEmail" class="col-sm-3 col-form-label pr-0">' + sCell.signature_name + '</label>');
  157. elementsStrArr.push('<div class="col-sm-9">');
  158. elementsStrArr.push('<ul class="list-group">');
  159. elementsStrArr.push('<li class="list-group-item">');
  160. if (sCell.path || sCell.pic) {
  161. let hasPic = false;
  162. for (const role_rel of ROLE_REL_LIST) {
  163. if (role_rel.signature_name === sCell.signature_name) {
  164. if (role_rel.type === '用户') {
  165. rptSignatureHelper.pushDomElementByUser(elementsStrArr, role_rel.user_name, role_rel.role);
  166. } else {
  167. //角色
  168. rptSignatureHelper.pushDomElementByRole(elementsStrArr, role_rel.role_name, role_rel.user_name);
  169. }
  170. elementsStrArr.push('<div class="dropdown">');
  171. if (role_rel.sign_date !== '') {
  172. //elementsStrArr.push('<a href="" data-toggle="dropdown">' + (new Date(role_rel.sign_date)).Format('yyyy-M-d') + '</a>');
  173. elementsStrArr.push('<a href="" data-toggle="dropdown"><i class="fa fa-calendar" title="添加签名日期"></i></a>');
  174. } else {
  175. elementsStrArr.push('<a href="" data-toggle="dropdown"><i class="fa fa-calendar" title="添加签名日期"></i></a>');
  176. }
  177. elementsStrArr.push('<form class="dropdown-menu p-2">');
  178. elementsStrArr.push('<div class="form-group">');
  179. elementsStrArr.push('<label for="exampleDropdownFormEmail2">签名日期</label>');
  180. if (role_rel.sign_date !== '') {
  181. //elementsStrArr.push('<input class="datepicker-here form-control form-control-sm mt-0" placeholder="选择签名日期" data-language="zh" type="text" value="' + (new Date(role_rel.sign_date)).Format('yyyy-M-d') + '">');
  182. elementsStrArr.push('<input class="datepicker-here form-control form-control-sm mt-0" placeholder="选择签名日期" data-language="zh" type="text">');
  183. } else {
  184. elementsStrArr.push('<input class="datepicker-here form-control form-control-sm mt-0" placeholder="选择签名日期" data-language="zh" type="text">');
  185. }
  186. elementsStrArr.push('</div>');
  187. if (role_rel.sign_date !== '') {
  188. //elementsStrArr.push('<button type="submit" class="btn btn-sm btn-outline-danger">移除日期</button> <button type="submit" class="btn btn-sm btn-primary">确认</button>');
  189. elementsStrArr.push('<button type="submit" class="btn btn-sm btn-primary">确认</button>');
  190. } else {
  191. elementsStrArr.push('<button type="submit" class="btn btn-sm btn-primary">确认</button>');
  192. }
  193. elementsStrArr.push('</form>');
  194. elementsStrArr.push('</div>');
  195. hasPic = true;
  196. break;
  197. }
  198. if (!hasPic) {
  199. // 在交互操作中,有可能实际上是没有
  200. // elementsStrArr.push('<a href="#add-sign" onclick="rptSignatureHelper.currentSelectedESignAccDom = this.parentNode; rptSignatureHelper.currentSelectedESignAccName = \'' + sCell.signature_name + '\'" data-toggle="modal" data-target="#add-sign"><i class="fa fa-plus"></i> 添加签名</a>');
  201. }
  202. }
  203. } else {
  204. elementsStrArr.push('<a href="#add-sign" onclick="rptSignatureHelper.currentSelectedESignAccDom = this.parentNode; rptSignatureHelper.currentSelectedESignAccName = \'' + sCell.signature_name + '\'" data-toggle="modal" data-target="#add-sign"><i class="fa fa-plus"></i> 添加签名</a>');
  205. }
  206. elementsStrArr.push('</li>');
  207. elementsStrArr.push('</ul>');
  208. elementsStrArr.push('</div>');
  209. elementsStrArr.push('</div>');
  210. //还有签名日期(用不用得上不管,先放上去再说)
  211. }
  212. body.append(elementsStrArr.join(' '));
  213. }
  214. },
  215. pushDomElementByUser: function (elementsStrArr, userName, userRole) {
  216. elementsStrArr.push('<p class=" d-flex justify-content-between m-0"><span>' + userName +
  217. '-<small class="text-muted">' + ((userRole === '')?"工程师":userRole) +
  218. '</small></span><a onclick="rptSignatureHelper.removeSignature(this)" class="text-danger"><i class="fa fa-remove" title="移除签名"></i></a></p>')
  219. },
  220. pushDomElementByRole: function (elementsStrArr, roleName, userName) {
  221. elementsStrArr.push('<p class=" d-flex justify-content-between m-0"><span><i class="fa fa-user" title="角色"> ' + roleName +
  222. '</i>-<small class="text-muted">' + userName +
  223. '</small></span><a onclick="rptSignatureHelper.removeSignature(this)" class="text-danger"><i class="fa fa-remove" title="移除签名"></i></a></p>')
  224. },
  225. removeSignature: function (dom) {
  226. let accTxtName = $(dom.parentNode.parentNode.parentNode.parentNode.parentNode).find('label')[0].innerText;
  227. let jDom = $(dom.parentNode.parentNode);
  228. jDom.empty();
  229. jDom.append('<a href="#add-sign" onclick="rptSignatureHelper.currentSelectedESignAccDom = this.parentNode; rptSignatureHelper.currentSelectedESignAccName = \'' +
  230. accTxtName + '\'" data-toggle="modal" data-target="#add-sign"><i class="fa fa-plus"></i> 添加签名</a>');
  231. // 要记得清空相关pre_path属性
  232. for (const page of zTreeOprObj.currentRptPageRst.items) {
  233. if (page.signature_cells) {
  234. for (const sCell of page.signature_cells) {
  235. if (sCell.signature_name === accTxtName) {
  236. sCell.pre_path = '';
  237. }
  238. }
  239. }
  240. }
  241. // 还有ROLE_REL_LIST
  242. rptSignatureHelper.cleanOldSignature(accTxtName);
  243. },
  244. removeSelectSignature: function () {
  245. for (const page of zTreeOprObj.currentRptPageRst.items) {
  246. if (page.signature_cells) {
  247. for (const sCell of page.signature_cells) {
  248. if (sCell.hasOwnProperty('pre_path')) {
  249. delete sCell.pre_path;
  250. }
  251. }
  252. }
  253. }
  254. ROLE_REL_LIST = [];
  255. ROLE_REL_LIST = ROLE_REL_LIST.concat(rptSignatureHelper.originalRoleRelList);
  256. zTreeOprObj.showPage(zTreeOprObj.currentPage, zTreeOprObj.canvas);
  257. },
  258. setupAfterSelectSignature: function () {
  259. //1. 重刷page
  260. for (const page of zTreeOprObj.currentRptPageRst.items) {
  261. if (page.signature_cells) {
  262. for (const sCell of page.signature_cells) {
  263. if (sCell.hasOwnProperty('pre_path')) {
  264. sCell.path = sCell.pre_path;
  265. delete sCell.pre_path;
  266. }
  267. }
  268. }
  269. }
  270. zTreeOprObj.showPage(zTreeOprObj.currentPage, zTreeOprObj.canvas);
  271. //2. 更新数据
  272. const params = {};
  273. params.id = CURRENT_ROLE_REL_ID;
  274. params.tender_id = TENDER_ID;
  275. params.rpt_id = zTreeOprObj.currentNode.refId;
  276. params.rel_content = ROLE_REL_LIST;
  277. rptSignatureHelper.originalRoleRelList = [];
  278. rptSignatureHelper.originalRoleRelList = rptSignatureHelper.originalRoleRelList.concat(ROLE_REL_LIST);
  279. CommonAjax.postXsrfEx("/tender/report_api/updateRoleRelationship", params, 10000, true, getCookie('csrfToken'),
  280. function(result){
  281. console.log(result);
  282. if (result.data && result.data.insertId >= 0) {
  283. CURRENT_ROLE_REL_ID = result.data.insertId;
  284. }
  285. }, function(err){
  286. // hintBox.unWaitBox();
  287. }, function(ex){
  288. // hintBox.unWaitBox();
  289. }
  290. );
  291. },
  292. switchAddRoleDiv: function (dom) {
  293. if (dom.nextElementSibling.children[0].style.display === 'none') {
  294. dom.nextElementSibling.children[0].style.display = '';
  295. } else {
  296. dom.nextElementSibling.children[0].style.display = 'none';
  297. }
  298. },
  299. createNewRole: function (dom) {
  300. if ($('#acc_role_name')[0].value !== '') {
  301. const params = {};
  302. params.name = $('#acc_role_name')[0].value;
  303. const selectedAcc = PRJ_ACCOUNT_LIST[$('#project_account_select_dom')[0].selectedOptions[0].value];
  304. const roleName = (selectedAcc.role === '')?'工程师':selectedAcc.role;
  305. params.bind_acc_id = selectedAcc.id;
  306. params.prj_id = PROJECT_ID;
  307. params.tender_id = TENDER_ID;
  308. CommonAjax.postXsrfEx("/tender/report_api/createSignatureRole", params, 10000, true, getCookie('csrfToken'),
  309. function(result){
  310. console.log(result);
  311. const newRole = {};
  312. newRole.name = params.name;
  313. newRole.bind_acc_id = selectedAcc.id;
  314. newRole.prj_id = PROJECT_ID;
  315. newRole.tender_id = TENDER_ID;
  316. ROLE_LIST.push(newRole);
  317. const domArr = [];
  318. domArr.push('<li class="add-sign-list-item">');
  319. //1. apply签名
  320. domArr.push('<a href="javascript:void(0)" onclick="rptSignatureHelper.createEsignatureByRoleIdx(' + (ROLE_LIST.length - 1) +')" class="btn-link pull-right" title="添加" data-dismiss="modal">');
  321. domArr.push('<i class="fa fa-plus"></i>');
  322. domArr.push('</a>');
  323. //2. 编辑角色(暂缓处理click事件)
  324. domArr.push('<a href="javascript:void(0)" onclick="" class="btn-link pull-right mr-1" title="编辑">');
  325. domArr.push('<i class="fa fa-pencil-square-o"></i>');
  326. domArr.push('</a>');
  327. //3. 显示名称
  328. domArr.push('<i class="fa fa-user"></i> ' + $('#acc_role_name')[0].value + '<p>' + selectedAcc.name + '-<small class="text-muted">' + roleName + '</small></p>');
  329. $('#existed_roles_ul').append(domArr.join(' '));
  330. }, function(err){
  331. // hintBox.unWaitBox();
  332. }, function(ex){
  333. // hintBox.unWaitBox();
  334. }
  335. );
  336. } else {
  337. alert('请输入合适的名称!');
  338. }
  339. },
  340. buildRoleDom: function (roleList) {
  341. const ulDom = $('#existed_roles_ul');
  342. ulDom.empty();
  343. for (let domIdx = 0; domIdx < roleList.length; domIdx++) {
  344. const role = roleList[domIdx];
  345. const domArr = [];
  346. domArr.push('<li class="add-sign-list-item">');
  347. //1. apply签名
  348. domArr.push('<a href="javascript:void(0)" onclick="rptSignatureHelper.createEsignatureByRoleIdx(' + domIdx + ')" class="btn-link pull-right" title="添加" data-dismiss="modal">');
  349. domArr.push('<i class="fa fa-plus"></i>');
  350. domArr.push('</a>');
  351. //2. 编辑角色(暂缓)
  352. domArr.push('<a href="javascript:void(0)" onclick="" class="btn-link pull-right mr-1" title="编辑">');
  353. domArr.push('<i class="fa fa-pencil-square-o"></i>');
  354. domArr.push('</a>');
  355. //3. 显示名称
  356. let acc = rptSignatureHelper.getUserAccount(role.bind_acc_id);
  357. domArr.push('<i class="fa fa-user"></i> ' + role.name + '<p>' + acc.name + '-<small class="text-muted">' + ((acc.role === '')?"工程师":acc.role) + '</small></p>');
  358. ulDom.append(domArr.join(' '));
  359. }
  360. },
  361. getUserAccount: function (accId) {
  362. let rst = null;
  363. for (const acc of PRJ_ACCOUNT_LIST) {
  364. if (acc.id === accId) {
  365. rst = acc;
  366. break;
  367. }
  368. }
  369. return rst;
  370. },
  371. mergeSignDate: function () {
  372. if (ROLE_REL_LIST && ROLE_REL_LIST.length > 0 && STAGE_AUDIT && STAGE_AUDIT.length > 0) {
  373. for (const role_rel of ROLE_REL_LIST) {
  374. if (role_rel.sign_date === undefined || role_rel.sign_date === null || role_rel.sign_date === '') {
  375. for (const stg_audit of STAGE_AUDIT) {
  376. if (role_rel.acc_id === stg_audit.aid) {
  377. role_rel.sign_date = stg_audit.end_time;
  378. break;
  379. }
  380. }
  381. }
  382. }
  383. }
  384. }
  385. }