123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405 |
- <!DOCTYPE html>
- <html xmlns="http://www.w3.org/1999/xhtml" ng-app="app">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
- <title>oa变更单</title>
- <link href="../../../AFrontEnd/css/animate.css" rel="stylesheet" />
- <link href="../../../AFrontEnd/css/fontawesome/css/font-awesome.css" rel="stylesheet" />
- <link href="../../../AFrontEnd/css/bootstrap.css" rel="stylesheet" />
- <link href="../../../AFrontEnd/css/style.css" rel="stylesheet" />
- <script>document.write("<link href='../../../AFrontEnd/css/special.css?time=" + new Date().getTime() + "' rel='stylesheet'>");</script>
- <script>document.write("<link href='../../flowchart_app_imgcss/css/formedit.css?time=" + new Date().getTime() + "' rel='stylesheet'>");</script>
- <script>document.write("<link href='../../flowchart_app_imgcss/css/canvasQianzi.css?time=" + new Date().getTime() + "' rel='stylesheet'>");</script>
- <style>
- .formedit {
- border-collapse: collapse;
- width: 100%;
- border: 2px solid #000;
- color: #000;
- }
- .formedit tbody td {
- text-align: center;
- line-height: 20px;
- padding: 7px 8px;
- border-top: 1px solid #000;
- border-right: 1px solid #000;
- }
- .sp-page-center input,
- .sp-page-center select,
- .sp-page-center textarea {
- border: 1px solid #fff;
- color: #333;
- }
- .sp-error {
- color: #409EFF;
- }
- .sp-errorTip:hover,
- .sp-errorTip:focus {
- border: 1px solid #409EFF;
- }
- </style>
- </head>
- <body>
- <div ng-controller="formeditCtrl as ctl" id="app" ng-cloak>
- <div class="wrapper wrapper-content">
- <div class="row">
- <div class="col-md-12">
- <div class="ibox float-e-margins">
- <div class="ibox-content">
- <div class="row">
- <div class="col-md-12">
- <div class="sp-box sp-bg-white">
- <div class="sp-page-col">
- <div class="sp-page-title" style="margin:7px 0;">oa变更单</div>
- </div>
- <div class="sp-page-col sp-ml-15 topPart">
- <a ng-repeat="item in ctl.SwenList" ng-class="{'activeSwen':ctl.Title==item.VNAME}" class="SwenBtn" href="{{item.TEMPFORM}}" title="{{item.VNAME}}">
- {{item.VNAME}}
- <!--<i ng-if="ctl.Title==item.VNAME" class="fa fa-check sp-color-blue"></i>-->
- </a>
- </div>
- <div class="sp-page-col sp-pull-right btn-box">
- <a class="sp-md sp-radius" ng-class="{'sp-btn-gray':item.CODE.indexOf('SENDITEM')==-1,'sp-btn-blue':item.CODE.indexOf('SENDITEM')!=-1}"ng-repeat="item in ctl.buttonList" ng-click="ctl.btnEvent(item)" ng-if="ctl.dotype==1||(ctl.dotype!=1&&item.EXPLAIN=='1')">
- <img ng-if="item.CODE.indexOf('SAVEITEM')!=-1" src="../../flowchart_app_imgcss/img/bc.png" height="14" />
- <img ng-if="item.CODE.indexOf('PRINTITEM')!=-1" src="../../flowchart_app_imgcss/img/dy.png" height="14" />
- <img ng-if="item.CODE.indexOf('SENDITEM')!=-1" src="../../flowchart_app_imgcss/img/zfw.png" height="14" />
- <img ng-if="item.CODE.indexOf('SENDLOG')!=-1" src="../../flowchart_app_imgcss/img/lz.png" height="14" />
- {{item.CNAME}}
- </a>
- <a href="{{ctl.return}}" class="sp-btn-gray sp-radius">
- <img src="../../flowchart_app_imgcss/img/fh.png" height="14" />
- 返 回
- </a>
- </div>
- </div>
- <div class="sp-page-center" style="line-height: 30px; color: #000; overflow-y: auto;" ng-class="{'sp-width-900': '{{ctl.deviceType}}'=='pad','sp-width-1000': '{{ctl.deviceType}}'!='pad'}">
- <h3 class="sp-text-center">建委机关OA变更申请单</h3>
- <table class="formedit">
- <tr>
- <td width="200">申请部门</td>
- <td>
- <input type="text" class="sp-input" ng-model="ctl.data.SQBM" readonly ng-click="ctl.openDpList('SQBM')" />
- </td>
- <td width="200">申请日期</td>
- <td>
- <input type="text" class="sp-input laydate-logo" sp-laydate ng-model="ctl.data.SQRQ" ng-disabled="ctl.hide('readonly','SQRQ')" ng-change="ctl.changeFiled('SQRQ')" />
- </td>
- </tr>
- <tr>
- <td>申请人</td>
- <td>
- <input type="text" class="sp-input" ng-model="ctl.data.SQR" readonly ng-click="ctl.openUserList('SQR')" sp-required />
- </td>
- <td>联系电话</td>
- <td>
- <input type="text" class="sp-input" ng-model="ctl.data.LXDH" ng-disabled="ctl.hide('readonly','LXDH')" ng-change="ctl.changeFiled('LXDH')" />
- </td>
- </tr>
- <tr>
- <td>变更类型</td>
- <td colspan="3">
- <select class="sp-select" ng-model="ctl.data.BGLX" ng-disabled="ctl.hide('readonly','BGLX')" ng-change="ctl.changeFiled('BGLX')">
- <option ng-repeat="item in ctl.BGLX" value="{{item.CODE}}" ng-bind="item.CNAME"></option>
- </select>
- </td>
- </tr>
- <tr>
- <td>变更原因</td>
- <td colspan="3">
- <input type="text" class="sp-input" ng-model="ctl.data.BGYY" ng-disabled="ctl.hide('readonly','BGYY')" ng-change="ctl.changeFiled('BGYY')" />
- </td>
- </tr>
- <tr>
- <td>变更内容</td>
- <td colspan="3">
- <textarea class="sp-textarea" ng-model="ctl.data.BGNR" ng-disabled="ctl.hide('readonly','BGNR')" ng-change="ctl.changeFiled('BGNR')" rows="5"></textarea>
- </td>
- </tr>
- <tr>
- <td>部门负责人</td>
- <td colspan="3">
- <input type="text" class="sp-input" ng-model="ctl.data.BMFZR" readonly ng-click="ctl.openUserList('BMFZR')" />
- </td>
- </tr>
- <tr>
- <td>分管委领导</td>
- <td colspan="3">
- <input type="text" class="sp-input" ng-model="ctl.data.FGWLD" readonly ng-click="ctl.openUserList('FGWLD')" />
- </td>
- </tr>
- <tr>
- <td>委主要领导</td>
- <td colspan="3">
- <input type="text" class="sp-input" ng-model="ctl.data.WZYLD" readonly ng-click="ctl.openUserList('WZYLD')" />
- </td>
- </tr>
- <tr>
- <td>系统主管部门意见</td>
- <td colspan="3">
- <div ng-if="ctl.opinion.XTZGBMYJ==false">
- <div class="sp-page" style="height: 212px; margin-bottom: 30px; overflow-y: auto">
- <table class="sp-grid sp-mb-5">
- <tr ng-repeat="item in ctl.YJ.XTZGBMYJ" class="qianzi">
- <td>
- <div class="sp-page">
- <p ng-if="!item.OPINIONIMAGE" class="sp-page sp-text-left" ng-bind-html="item.OPINION | trustHtml"></p>
- <img class="sp-pull-left" ng-if="!item.OPINION" ng-src="{{item.OPINIONIMAGE}}" style="width:50%" />
- <div class="sp-page">
- <div class="sp-col-75">
- <div ng-repeat="item in item.FILEDATA" style="width: 135px; display: inline-block; cursor: pointer; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; position: relative; top: 5px; margin-left: 10px">
- <a ng-click="ctl.downLoadOption(item)" title="下载">
- <i class="fa fa-download sp-color-red"></i>
- </a>
- <a ng-click="ctl.deleteOptionFile(item,'XTZGBMYJ')" title="删除" ng-if="item.ROUTEID==ctl.routeid">
- <i class="fa fa-trash sp-color-red"></i>
- </a>
- <span ng-bind="item.FILENAME" title="{{item.FILENAME}}"></span>
- </div>
- <div style="display: inline-block; position: relative; margin-left: 10px; line-height: 40px;" ng-if="item.ROUTEID==ctl.routeid&&ctl.opinion.XTZGBMYJ==false&&ctl.dotype==1&&item.COLID=='XTZGBMYJ'">
- <span class="opbtn" style="position: relative; color: #1c84c6">
- <span class="upload-tip"></span>
- <input id="fileupload-XTZGBMYJ" class="upload-file-single" ng-click="ctl.upload2('XTZGBMYJ')" type="file" name="files[]" multiple>
- <i class="fa fa-upload"></i>
- <span class="upload-loading" ng-if="ctl.uploading1"><i class="fa fa-spinner fa-pulse sp-fs-20"></i></span>
- </span>
- </div>
- </div>
- <div class="sp-col-25 sp-text-right sp-pull-right" style="line-height:40px">
- <span ng-bind="item.CMANNAME"></span>
- <span ng-bind="item.CDATE"></span>
- </div>
- </div>
- </div>
- <div class="sp-page sp-text-right">
- <div class="opbtn" style="color: #FF6F6F; display: inline-block; " ng-if="item.ROUTEID==ctl.routeid&&ctl.dotype==1"
- ng-click="ctl.Dopinion('XTZGBMYJ')">
- <i class="fa fa-trash-o fa-lg"></i>
- </div>
- <div class="opbtn" ng-if="item.ROUTEID==ctl.routeid&&ctl.dotype==1" style="color: #66D151; display: inline-block; "
- ng-click="ctl.changeOpinionItem('XTZGBMYJ',item)">
- <i class="fa fa-pencil fa-lg"></i>
- </div>
- </div>
- </td>
- </tr>
- </table>
- </div>
- <span class="opbtn sp-pull-right" ng-if="ctl.YJ.XTZGBMYJSTATUS==false" style="color: #1EADFF"
- ng-hide="ctl.hide('readonly','XTZGBMYJ')" ng-click="ctl.openOpinion('XTZGBMYJ')">
- <i class="fa fa-pencil fa-lg"></i>
- </span>
- </div>
- <div ng-if="ctl.opinion.XTZGBMYJ==true||ctl.opinion.XTZGBMYJImg==true">
- <textarea id="XTZGBMYJ" class="op-textarea sp-mb-10" ng-model="ctl.data.XTZGBMYJ" ng-if="ctl.opinion.XTZGBMYJ==true&&ctl.opinion.XTZGBMYJImg==false"></textarea>
- <div ng-if="ctl.opinion.XTZGBMYJImg==true">
- <div id="XTZGBMYJQZ" class="canvas"></div>
- </div>
- <div class="sp-page">
- <div class="sp-pull-left" ng-class="{'sp-qz-blue':ctl.opinion.XTZGBMYJImg==false,'sp-qz-gray':ctl.opinion.XTZGBMYJImg==true}" ng-click="ctl.opinion.XTZGBMYJImg=false">文字</div>
- <div class="sp-pull-left" ng-class="{'sp-qz-blue':ctl.opinion.XTZGBMYJImg==true,'sp-qz-gray':ctl.opinion.XTZGBMYJImg==false}" ng-click="ctl.QianZi('XTZGBMYJ')">手签</div>
- <span class="sp-btn-gray sp-btn-sm sp-btn-radius sp-pull-right" ng-click="ctl.opinion.XTZGBMYJ=false;ctl.opinion.XTZGBMYJImg=false">取消</span>
- <span class="sp-btn-gray sp-btn-sm sp-btn-radius sp-pull-right" ng-click="ctl.Sopinion('XTZGBMYJ')">保存</span>
- <span class="sp-btn-gray sp-btn-sm sp-btn-radius sp-pull-right" ng-click="ctl.canvasClear('XTZGBMYJ')" ng-if="ctl.opinion.XTZGBMYJImg==true">清除</span>
- <span class="sp-btn-gray sp-btn-sm sp-btn-radius sp-pull-right" ng-click="ctl.phrase('XTZGBMYJ')" ng-if="ctl.opinion.XTZGBMYJ==true&&ctl.opinion.XTZGBMYJImg==false">常用语</span>
- </div>
- </div>
- </td>
- </tr>
- <tr>
- <td>系统管理员操作记录</td>
- <td colspan="3">
- <textarea class="sp-textarea" ng-model="ctl.data.XTGLYCZJL" ng-disabled="ctl.hide('readonly','XTGLYCZJL')" ng-change="ctl.changeFiled('XTGLYCZJL')" rows="5"></textarea>
- </td>
- </tr>
- </table>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- <div class="sp-layer" id="DpList" style="width: 900px;">
- <div class="sp-layer-head" style="background:#2176d6">
- <div class="sp-page sp-text-center sp-font16">
- 部门列表
- <div class="sp-layer-close" title="关闭" onclick="sp.closeCenter('.sp-layer')">
- ×
- </div>
- </div>
- </div>
- <div class="sp-layer-body" ng-class="{'sp-height-400': '{{ctl.deviceType}}' =='pad'}">
- <div class="sp-page" style="height:290px;overflow:auto">
- <label class="sp-col-20">
- <input type="checkbox" style="position:relative;top:2px" ng-checked="ctl.AllCheckedDp[ctl.filed]" ng-click="ctl.checkAllDp()" />
- 全选
- </label>
- <div class="sp-page">
- <label class="sp-col-25" title="{{item.SECTION}}" ng-repeat="item in ctl.DpList[ctl.filed]">
- <input type="checkbox" style="position:relative;top:2px" ng-checked="item.checked" ng-click="ctl.checkDpItem(item)" />
- {{item.SECTION}}
- </label>
- </div>
- </div>
- <div class="sp-page sp-text-center sp-pt-10">
- <a class="sp-btn-blue sp-radius" ng-click="ctl.submitDpList(0)"><i class="fa fa-check sp-mr-5"></i>确 定</a>
- <a class="sp-btn-blue sp-radius" onclick="sp.layerhide()"><i class="fa fa-close sp-mr-5"></i>取 消</a>
- </div>
- </div>
- </div>
- <div class="sp-layer" id="userList" style="width: 900px;">
- <div class="sp-layer-head" style="background:#2176d6">
- <div class="sp-page sp-text-center sp-font16">
- 人员列表
- <div class="sp-layer-close" title="关闭" onclick="sp.closeCenter('.sp-layer')">
- ×
- </div>
- </div>
- </div>
- <div class="sp-layer-body" ng-class="{'sp-height-400': '{{ctl.deviceType}}' =='pad'}">
- <div class="sp-page" style="height:290px;overflow:auto">
- <label class="sp-col-20">
- <input type="checkbox" style="position:relative;top:2px" ng-checked="ctl.AllChecked[ctl.filed]" ng-click="ctl.checkAllUser()" />
- 全选
- </label>
- <div class="sp-page" ng-repeat="item in ctl.UserList[ctl.filed]">
- <h4 style="background:#409EFF" class="sp-color-white sp-pl-10">
- <input type="checkbox" style="position:relative;top:2px" ng-checked="item.checked" ng-click="ctl.checkUserItem(item)" />
- {{item.DEP}}
- </h4>
- <label ng-repeat="item1 in item.USER" class="sp-col-20" title="{{item1.USHOWNAME}}">
- <input type="checkbox" style="position:relative;top:2px" ng-checked="item1.checked" ng-click="ctl.checkUser(item1)" />
- {{item1.USHOWNAME2}}
- </label>
- </div>
- </div>
- <div class="sp-page sp-text-center sp-pt-10">
- <a class="sp-btn-blue sp-radius" ng-click="ctl.submitUserList(0)"><i class="fa fa-check sp-mr-5"></i>确 定</a>
- <a class="sp-btn-blue sp-radius" onclick="sp.layerhide()"><i class="fa fa-close sp-mr-5"></i>取 消</a>
- </div>
- </div>
- </div>
- <div class="sp-layer" id="phrase" style="width:480px;">
- <div class="sp-layer-head" style="background:#2176d6">
- <div class="sp-page sp-text-center sp-font16">
- 常用语库
- <div class="sp-layer-close" title="关闭" onclick="sp.closeCenter('.sp-layer')">
- ×
- </div>
- </div>
- </div>
- <div class="sp-layer-body" ng-class="{'sp-height-400': '{{ctl.deviceType}}' =='pad'}">
- <div class="sp-box">
- <div class="sp-col-70">
- <input type="text" ng-model="ctl.phraseText" class="sp-input" />
- </div>
- <div class="sp-col-30">
- <span class="sp-btn-blue sp-pull-left sp-radius" ng-class="{'sp-disabled':ctl.phraseText==''}" ng-click="ctl.Aphrase()">添加常用语</span>
- </div>
- </div>
- <div class="sp-box">
- <div class="sp-col-20" style="line-height:30px;">
- 常用语:
- </div>
- <div class="sp-col-60">
- <select class="sp-select sp-bg-white" ng-model="ctl.phraseSelect">
- <option ng-repeat="item in ctl.phraseList" value="{{item.CONTENTS}}" ng-bind="item.CONTENTS"></option>
- </select>
- </div>
- <div class="sp-col-20">
- <span class="sp-btn-blue sp-pull-left sp-radius" ng-click="ctl.Dphrase()">删除</span>
- </div>
- </div>
- <div class="sp-page sp-text-center sp-pt-10">
- <a class="sp-btn-blue sp-radius" ng-click="ctl.btnPhrase()"><i class="fa fa-check sp-mr-5"> </i>确 认</a>
- <a class="sp-btn-blue sp-radius" onclick="sp.closeCenter('.sp-layer')"><i class="fa fa-reply-all sp-mr-5"> </i>关 闭</a>
- </div>
- </div>
- </div>
- <div class="sp-layer" id="forward" style="width: 1000px;">
- <div class="sp-layer-head" style="background:#2176d6">
- <div class="sp-page sp-text-center sp-font16">
- 转 发
- <div class="sp-layer-close" title="关闭" onclick="sp.closeCenter('.sp-layer')">
- ×
- </div>
- </div>
- </div>
- <div class="sp-layer-body" ng-class="{'sp-height-400': '{{ctl.deviceType}}' =='pad'}">
- <iframe id="forwardWin" style="width:100%;border:0"></iframe>
- </div>
- </div>
- <div class="sp-layer" id="RouteList" style="width:900px;">
- <div class="sp-layer-head" style="background:#2176d6">
- <div class="sp-page sp-text-center sp-font16">
- 流转记录
- <div class="sp-layer-close" title="关闭" onclick="sp.closeCenter('.sp-layer')">
- ×
- </div>
- </div>
- </div>
- <div class="sp-layer-body" ng-class="{'sp-height-400': '{{ctl.deviceType}}' =='pad'}">
- <table class="sp-table">
- <thead>
- <tr>
- <th style="width:100px"><strong>流程名称</strong></th>
- <th style="width:200px"><strong>标题</strong></th>
- <th style="width:100px"><strong>工作节点</strong></th>
- <th style="width:100px"><strong>转发人</strong></th>
- <th style="width:100px"><strong>主送</strong></th>
- <th style="width:150px"><strong>抄送</strong></th>
- <th style="width:200px"><strong>发送日期</strong></th>
- </tr>
- </thead>
- </table>
- <div style="overflow-y:scroll;max-height:400px">
- <table class="sp-table" style="margin-top: -38px">
- <thead>
- <tr>
- <th style="width:100px"><strong>流程名称</strong></th>
- <th style="width:200px"><strong>标题</strong></th>
- <th style="width:100px"><strong>工作节点</strong></th>
- <th style="width:100px"><strong>转发人</strong></th>
- <th style="width:100px"><strong>主送</strong></th>
- <th style="width:150px"><strong>抄送</strong></th>
- <th style="width:200px"><strong>发送日期</strong></th>
- </tr>
- </thead>
- <tbody>
- <tr ng-repeat="item in ctl.routeList">
- <td ng-bind="item.FLOWNAME"></td>
- <td ng-bind="item.TITLE"></td>
- <td ng-bind="item.ENDNODENAME"></td>
- <td ng-bind="item.USERNAMEFROM"></td>
- <td ng-bind="item.mainUser"></td>
- <td ng-bind="item.copyUsers"></td>
- <td ng-bind="item.RECEIVEDATE"></td>
- </tr>
- </tbody>
- </table>
- </div>
- <div class="sp-page sp-text-center sp-pt-10">
- <a class="sp-btn-blue sp-radius" onclick="sp.closeCenter('.sp-layer')"><i class="fa fa-reply-all sp-mr-5"> </i>关 闭</a>
- </div>
- </div>
- </div>
- </div>
- <script src="../../../AFrontEnd/js/jquery/jquery-2.1.4.min.js"></script>
- <script src="../../../AFrontEnd/js/laydate/laydate.js"></script>
- <script src="../../../AFrontEnd/js/angularjs/angular.js"></script>
- <script src="../../../AFrontEnd/js/angularjs/dirPagination.js"></script>
- <script src="../../../apiurljs.js"></script>
- <!--<script src="../../js/watermark.js"></script>-->
- <script src="../../../js/sm4.js"></script>
- <script>document.write('<scri' + 'pt src="../../../AFrontEnd/js/special/special.js?time=' + new Date().getTime() + '" type="text/javascript"></s' + 'cript>')</script>
- <script>document.write('<scri' + 'pt src="js/formedit.js?time=' + new Date().getTime() + '" type="text/javascript"></s' + 'cript>')</script>
- <script src="../../../AFrontEnd/js/special/spng.js"></script>
- <script src="../../../AFrontEnd/js/special/spngvld.js"></script>
- </body>
- </html>
|