tender_list.js 4.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. const tenderListSpec = (function(){
  2. function getTenderTreeHeaderHtml() {
  3. const html = [];
  4. const left = $('#sub-menu').css('display') === 'none' ? 56 : 176;
  5. html.push('<table class="table table-hover table-bordered">');
  6. html.push('<thead style="position: fixed;left:'+ left +'px;top: 34px;">', '<tr>');
  7. html.push('<th class="text-center" style="width: 40%">', '标段名称', tenderListOrder.getOrderButton('name'), '</th>');
  8. html.push('<th class="text-center" style="width: 9%">', '计量模式', '</th>');
  9. html.push('<th class="text-center" style="width: 9%">', '创建人', '</th>');
  10. html.push('<th class="text-center" style="width: 9%">', '游客', '</th>');
  11. html.push('<th class="text-center" style="width: 9%">', '创建时间', tenderListOrder.getOrderButton('create_time'), '</th>');
  12. html.push('<th class="text-center" style="width: 9%">', '计量期数', '</th>');
  13. html.push('<th class="text-center" style="width: 15%">', '审批状态', '</th>');
  14. html.push('</tr>', '</thead>');
  15. return html.join('');
  16. }
  17. function getTenderNodeHtml(node, arr, pid) {
  18. const html = [];
  19. html.push('<tr pid="' + pid + '">');
  20. // 名称
  21. html.push('<td style="width: 40%" class="in-' + node.level + '">');
  22. if (node.cid) {
  23. html.push('<span onselectstart="return false" style="{-moz-user-select:none}" class="fold-switch mr-1" title="收起" cid="'+ node.sort_id +'"><i class="fa fa-minus-square-o"></i></span> <i class="fa fa-folder-o"></i> ');
  24. html.push((node.level === 1 ? '<b>' : ''), node.name, (node.level === 1 ? '</b>' : ''));
  25. } else {
  26. html.push('<span class="text-muted mr-2">');
  27. html.push(arr.indexOf(node) === arr.length - 1 ? '└' : '├');
  28. html.push('</span>');
  29. //html.push('<a href="/tender/' + node.id + '">', node[c.field], '</a>');
  30. html.push('<a href="javascript: void(0)" id="' + node.id + '" name="name">', node.name, '</a>');
  31. }
  32. html.push('</td>');
  33. // 计量模式
  34. html.push('<td style="width: 9%" class="text-center">');
  35. if (node.measure_type) {
  36. html.push(node.measure_type === measureType.tz.value ? '0号台账' : '工程量清单');
  37. }
  38. html.push('</td>');
  39. // 创建人
  40. html.push('<td style="width: 9%" class="text-center">', node.user_name ? node.user_name : '', '</td>');
  41. // 游客
  42. const visitor = node.visitor && node.visitor.length > 0
  43. ? `<a href="javascirpt: void(0)" data-toggle="tooltip" data-placement="top" data-original-title="${node.visitor.join(',')}">${node.visitor.length}</a>`
  44. : '';
  45. html.push('<td style="width: 9%" class="text-center">', visitor, '</td>');
  46. // 创建时间
  47. html.push('<td style="width: 9%">', node.create_time ? moment(node.create_time).format('YYYY-MM-DD HH:mm:ss') : '', '</td>');
  48. // 计量模式
  49. // html.push('<td>');
  50. // if (node.measure_type) {
  51. // html.push(node.measure_type === measureType.tz.value ? '0号台账' : '工程量清单');
  52. // }
  53. // html.push('</td>');
  54. // 计量期数
  55. html.push('<td style="width: 9%" class="text-center">');
  56. if (!node.cid) {
  57. if (node.progress) {
  58. html.push(node.progress.title === '台账' ? '' : node.progress.title);
  59. } else {
  60. html.push(node.lastStage ? '第' + node.lastStage.order + '期' : '台账');
  61. }
  62. }
  63. html.push('</td>');
  64. // 审批状态
  65. html.push('<td style="width: 15%">');
  66. if (!node.cid && node.cur_flow) {
  67. if (node.stage_status !== undefined) {
  68. if (node.cur_flow instanceof Array && node.cur_flow[0].audit_type && node.cur_flow[0].audit_type !== auditType.key.common) {
  69. html.push(`<span class="${node.progress.status_class}">${node.progress.status}</span>(${transFormToChinese(node.cur_flow[0].audit_order)}审)`);
  70. } else {
  71. html.push(`<span class="${node.progress.status_class}">${node.progress.status}</span>(${node.cur_flow instanceof Array ? node.cur_flow[0].name : node.cur_flow.name })`);
  72. }
  73. } else {
  74. html.push(`<span class="${node.lastStage ? auditConst.stage.tiStatusStringClass[node.lastStage.status] : auditConst.ledger.tiStatusStringClass[node.ledger_status]}">`);
  75. html.push(node.lastStage ? auditConst.stage.statusString[node.lastStage.status] : auditConst.ledger.statusString[node.ledger_status]);
  76. html.push('</span>');
  77. html.push(node.status_users ? '(' + node.status_users + ')' : '');
  78. }
  79. }
  80. html.push('</td>');
  81. html.push('</tr>');
  82. return html.join('');
  83. }
  84. return { getTenderNodeHtml, getTenderTreeHeaderHtml }
  85. })();