| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 | <!--审批流程/结果--><div class="modal fade" id="sp-list" data-backdrop="static">    <div class="modal-dialog modal-lg" role="document">        <div class="modal-content">            <div class="modal-header">                <h5 class="modal-title">审批流程</h5>            </div>            <div class="modal-body">                <div class="row">                    <div class="col-4">                        <div class="card mt-3">                            <ul class="list-group list-group-flush"  id="auditors-list">                                <% revise.userGroups.forEach((item, idx) => { %>                                <% if (idx === 0) { %>                                <li class="list-group-item d-flex justify-content-between align-items-center">                                    <span class="mr-1"><i class="fa fa fa-play-circle fa-rotate-90"></i></span>                                    <span class="text-muted">                                        <% for (const u of item) { %>                                        <small class="d-inline-block text-dark mx-1" title="<%- u.role %>" data-auditorId="<%- u.audit_id %>"><%- u.name %></small>                                        <% } %>                                    </span>                                    <span class="badge badge-light badge-pill ml-auto"><small>原报</small></span>                                </li>                                <% } else if(idx === revise.userGroups.length -1 && idx !== 0) { %>                                <li class="list-group-item d-flex justify-content-between align-items-center">                                    <span class="mr-1"><i class="fa fa fa-stop-circle"></i></span>                                    <span class="text-muted">                                        <% for (const u of item) { %>                                        <small class="d-inline-block text-dark mx-1" title="<%- u.role %>" data-auditorId="<%- u.audit_id %>"><%- u.name %></small>                                        <% } %>                                    </span>                                    <div class="d-flex ml-auto">                                        <% if (item[0].audit_type !== auditType.key.common) { %>                                        <span class="badge badge-pill badge-<%-  auditType.info[item[0].audit_type].class %> p-1"><small><%- auditType.info[item[0].audit_type].short %></small></span>                                        <% } %>                                        <span class="badge badge-light badge-pill"><small>终审</small></span>                                    </div>                                </li>                                <% } else {%>                                <li class="list-group-item d-flex justify-content-between align-items-center">                                    <span class="mr-1"><i class="fa fa-chevron-circle-down"></i></span>                                    <span class="text-muted">                                        <% for (const u of item) { %>                                        <small class="d-inline-block text-dark mx-1" title="<%- u.role %>" data-auditorId="<%- u.audit_id %>"><%- u.name %></small>                                        <% } %>                                    </span>                                    <div class="d-flex ml-auto">                                        <% if (item[0].audit_type !== auditType.key.common) { %>                                        <span class="badge badge-pill badge-<%- auditType.info[item[0].audit_type].class %> p-1"><small><%- auditType.info[item[0].audit_type].short %></small></span>                                        <% } %>                                        <span class="badge badge-light badge-pill"><small><%= ctx.helper.transFormToChinese(idx) %>审</small></span>                                    </div>                                </li>                                <% } %>                                <% }) %>                            </ul>                        </div>                    </div>                    <div class="col-8 modal-height-500 scroll-y">                        <% revise.auditHistory.forEach((his, idx) => { %>                        <!-- 展开/收起历史流程 -->                        <% if(idx === revise.auditHistory.length - 1 && revise.auditHistory.length !== 1) { %>                        <div class="text-right">                            <a href="javascript: void(0);" id="fold-btn" data-target="show">展开历史审批流程</a>                        </div>                        <% } %>                        <div class="<%- idx < revise.auditHistory.length - 1 ? 'fold-card' : '' %>">                            <div class="text-center text-muted"><%- idx+1 %>#</div>                            <ul class="timeline-list list-unstyled mt-2 <% if (idx === revise.auditHistory.length - 1) { %>last-auditor-list<% } %>">                                <% his.forEach((group, index) => { %>                                <% if (index === 0) { %>                                <li class="timeline-list-item pb-2">                                    <div class="timeline-item-date">                                        <%- group.beginYear %>                                        <span><%- group.beginDate %></span>                                        <span><%- group.beginTime %></span>                                    </div>                                    <div class="timeline-item-tail"></div>                                    <div class="timeline-item-icon bg-success text-light"><i class="fa fa-caret-down"></i></div>                                    <div class="timeline-item-content">                                        <div class="py-1">                                            <span class="text-black-50">原报</span>                                            <span class="pull-right text-success"><%- idx !== 0 ? '重新' : '' %>上报审批</span>                                        </div>                                        <div class="card">                                            <div class="card-body px-3 py-0">                                                <div class="card-text p-2 py-3 row">                                                    <div class="col">                                                        <span class="h6"><%- revise.user.name %></span>                                                        <span class="text-muted ml-1"><%- revise.user.role %></span>                                                    </div>                                                    <div class="col">                                                        <span class="pull-right text-success"><i class="fa fa-check-circle"></i></span>                                                    </div>                                                </div>                                            </div>                                        </div>                                    </div>                                </li>                                <% } %>                                <li class="timeline-list-item pb-2 <% if (group.status === auditConst.status.uncheck && idx === revise.auditHistory.length - 1 && revise.auditHistory.length !== 1) { %>is_uncheck<% } %>">                                    <% if (group.endYear) { %>                                    <div class="timeline-item-date">                                        <%- group.endYear %>                                        <span><%- group.endDate %></span>                                        <span><%- group.endTime %></span>                                    </div>                                    <% } %>                                    <% if (index < his.length - 1) { %>                                    <div class="timeline-item-tail"></div>                                    <% } %>                                    <% if (group.status === auditConst.status.checked) { %>                                    <div class="timeline-item-icon bg-success text-light"><i class="fa fa-check"></i></div>                                    <% } else if (group.status === auditConst.status.checkNo || group.status === auditConst.status.checkNoPre || group.status === auditConst.status.checkCancel) { %>                                    <div class="timeline-item-icon bg-warning text-light"><i class="fa fa-level-up"></i></div>                                    <% } else if (group.status === auditConst.status.checking) { %>                                    <div class="timeline-item-icon bg-warning text-light"><i class="fa fa-ellipsis-h"></i></div>                                    <% } else { %>                                    <div class="timeline-item-icon bg-secondary text-light"></div>                                    <% } %>                                    <div class="timeline-item-content">                                        <div class="py-1">                                            <span class="text-black-50">                                                <%- (!group.is_final ? group.audit_order : '终') %>审                                                <% if (group.audit_type !== auditType.key.common) { %><span class="text-<%- auditType.info[group.audit_type].class %> "><%- auditType.info[group.audit_type].long %></span><% } %>                                            </span>                                            <% if (group.status !== auditConst.status.uncheck) { %>                                            <span class="pull-right <%- auditConst.statusClass[group.status] %>"><%- auditConst.statusString[group.status] %></span>                                            <% } %>                                        </div>                                        <div class="card">                                            <div class="card-body px-3 py-0">                                                <% for (const [i, auditor] of group.auditors.entries()) { %>                                                <div class="card-text p-2 py-3 row <%- ( i > 0 ? 'border-top' : '') %>">                                                    <div class="col">                                                        <span class="h6"><%- auditor.name %></span>                                                        <span class="text-muted ml-1"><%- auditor.role %></span>                                                    </div>                                                    <div class="col">                                                        <% if (auditor.status === auditConst.status.checked) { %>                                                        <span class="pull-right text-success"><i class="fa fa-check-circle"></i></span>                                                        <% } else if (auditor.status === auditConst.status.checkNo || auditor.status === auditConst.status.checkNoPre || auditor.status === auditConst.status.checkCancel) { %>                                                        <span class="pull-right text-warning"><i class="fa fa-share-square fa-rotate-270"></i></span>                                                        <% } %>                                                    </div>                                                    <% if (auditor.opinion) { %>                                                    <div class="col-12 py-1 bg-light"><i class="fa fa-commenting-o mr-1"></i><%- auditor.opinion%></div>                                                    <% } %>                                                </div>                                                <% } %>                                            </div>                                        </div>                                    </div>                                </li>                                <% }) %>                            </ul>                        </div>                        <% }) %>                    </div>                </div>            </div>            <div class="modal-footer">                <button type="button" class="btn btn-secondary btn-sm" data-dismiss="modal">关闭</button>            </div>        </div>    </div></div><script>    // 展开历史审核记录    $('.modal-body #fold-btn').click(function () {        const type = $(this).data('target')        const auditCard = $(this).parent().parent()        if (type === 'show') {            $(this).data('target', 'hide')            auditCard.find('.fold-card').slideDown('swing', () => {                auditCard.find('#fold-btn').text('收起历史审核记录')            })        } else {            $(this).data('target', 'show')            auditCard.find('.fold-card').slideUp('swing', () => {                auditCard.find('#fold-btn').text('展开历史审核记录')            })        }    });</script>
 |