tender_list.js 4.8 KB

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