rpt_signature.js 17 KB

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