add.html 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. {extend name="../../base/view/common/base" /}
  2. <!-- 主体 -->
  3. {block name="body"}
  4. <form class="layui-form p-page">
  5. <h3 class="pb-3">新建项目</h3>
  6. <table class="layui-table layui-table-form">
  7. <tr>
  8. <td class="layui-td-gray">项目名称<font>*</font></td>
  9. <td colspan="3"><input type="text" name="name" lay-verify="required" lay-reqText="请输入项目名称" placeholder="请输入项目名称" class="layui-input" value=""></td>
  10. <td class="layui-td-gray">项目类别<font>*</font></td>
  11. <td>
  12. <select name="cate_id" lay-filter="cate" lay-verify="required" lay-reqText="请选择项目类别">
  13. <option value="">请选择</option>
  14. {volist name = ":get_base_data('ProjectCate')" id="vo"}
  15. <option value="{$vo.id}">{$vo.title}</option>
  16. {/volist}
  17. </select>
  18. </td>
  19. </tr>
  20. <tr>
  21. <td class="layui-td-gray">项目经理<font>*</font></td>
  22. <td>
  23. <input type="text" name="director_name" placeholder="请选择项目经理(负责人)" readonly class="layui-input" value="" lay-verify="required" readonly lay-reqText="请选择项目经理(负责人)">
  24. <input type="hidden" name="director_uid" value="0">
  25. <input type="hidden" name="did" value="0">
  26. </td>
  27. <td class="layui-td-gray">归属部门<font>*</font></td>
  28. <td><input type="text" name="department" value="" autocomplete="off" readonly class="layui-input"></td>
  29. <td class="layui-td-gray">始止日期<span style="color: red">*</span></td>
  30. <td><input type="text" name="range_time" class="layui-input tool-time" data-range="到" readonly placeholder="开始 到 结束" lay-verify="required" lay-reqText="请选择计划完成周期"></td>
  31. </tr>
  32. <tr>
  33. <td class="layui-td-gray">项目成员<span style="color: red">*</span></td>
  34. <td colspan="5">
  35. <input type="text" name="team_admin_names" placeholder="请选择项目成员" readonly class="layui-input picker-admin" data-type="2" value="" lay-verify="required" lay-reqText="请完善项目成员">
  36. <input type="hidden" name="team_admin_ids" class="layui-input" value="">
  37. </td>
  38. </tr>
  39. <tr>
  40. <td class="layui-td-gray">关联合同</td>
  41. <td colspan="5">
  42. <input type="text" class="layui-input picker-oa" data-types="contract" name="contract_name" placeholder="请选择需要关联的合同" readonly value="">
  43. <input type="hidden" class="layui-input" name="contract_id" value="0">
  44. </td>
  45. </tr>
  46. <tr>
  47. <td class="layui-td-gray">项目简介</td>
  48. <td colspan="5">
  49. <textarea name="content" class="layui-textarea"></textarea>
  50. </td>
  51. </tr>
  52. <tr>
  53. <td colspan="6" style="background-color:#FAFAFA;">
  54. <strong>项目阶段</strong><span style="color: red">*</span>
  55. <span class="layui-btn layui-btn-sm" id="stepAdd">+ 添加阶段</span>
  56. </td>
  57. </tr>
  58. <tr>
  59. <td colspan="6">
  60. <table id="stepTable" class="layui-table layui-table-min" style="margin:0">
  61. <tr>
  62. <th width="60">序号</th>
  63. <th width="200">阶段名称</th>
  64. <th width="80">阶段负责人</th>
  65. <th width="180">阶段成员</th>
  66. <th width="162">阶段周期</th>
  67. <th>阶段说明</th>
  68. <th width="120">操作</th>
  69. </tr>
  70. {volist name = ":get_base_data('step')" id="vo" key="k"}
  71. <tr class="step-tr">
  72. <td class="step-key">第 <strong>{$k}</strong> 阶段</td>
  73. <td>
  74. <div class="layui-input-group">
  75. <input type="text" name="step_title[]" value="{$vo.title}" class="layui-input" lay-verify="required" lay-reqText="请输入阶段名称">
  76. <div class="layui-input-split layui-input-suffix picker-diy" style="cursor: pointer;"><i class="layui-icon layui-icon-search"></i></div>
  77. </div>
  78. </td>
  79. <td>
  80. <input type="text" value="" class="layui-input layui-input-readonly picker-admin" lay-verify="required" lay-reqText="请选择阶段负责人" readonly>
  81. <input type="hidden" name="step_director_uid[]" value="0" readonly>
  82. </td>
  83. <td>
  84. <input type="text" value="" class="layui-input layui-input-readonly picker-admin" data-type="2">
  85. <input type="hidden" name="step_uids[]" value="">
  86. </td>
  87. <td><input type="text" name="step_cycle_time[]" value="" class="layui-input layui-input-readonly tool-time" data-range="到" lay-verify="required" lay-reqText="请选择阶段周期" readonly></td>
  88. <td><input type="text" name="step_remark[]" value="" class="layui-input"></td>
  89. <td>
  90. <input type="hidden" name="step_id[]" value="0" class="layui-input">
  91. <div class="layui-btn-group">
  92. <span class="layui-btn layui-btn-xs step-up">上移</span>
  93. <span class="layui-btn layui-btn-normal layui-btn-xs step-down">下移</span>
  94. <span class="layui-btn layui-btn-danger layui-btn-xs step-del" data-id="0">删除</span>
  95. </div>
  96. </td>
  97. </tr>
  98. {/volist}
  99. </table>
  100. </td>
  101. </tr>
  102. </table>
  103. <div class="pt-3">
  104. <button class="layui-btn layui-btn-normal" lay-submit="" lay-filter="webform">立即提交</button>
  105. <button type="reset" class="layui-btn layui-btn-primary">重置</button>
  106. </div>
  107. </form>
  108. {/block}
  109. <!-- /主体 -->
  110. <!-- 脚本 -->
  111. {block name="script"}
  112. <script>
  113. var moduleInit = ['tool','oaPicker'];
  114. function gouguInit() {
  115. var form = layui.form, tool = layui.tool,oaPicker = layui.oaPicker;
  116. //选择项目经理
  117. $('body').on('click','[name="director_name"]',function () {
  118. var ids=$('[name="director_uid"]').val(),names=$('[name="director_name"]').val();
  119. oaPicker.employeeInit({
  120. ids:ids,
  121. names:names,
  122. type:1,
  123. callback:function(data){
  124. let select_id=[],select_name=[],select_did=[],select_dname=[];
  125. for(var a=0; a<data.length;a++){
  126. select_id.push(data[a].id);
  127. select_name.push(data[a].name);
  128. select_did.push(data[a].did);
  129. select_dname.push(data[a].department);
  130. }
  131. $('[name="director_uid"]').val(select_id.join(','));
  132. $('[name="director_name"]').val(select_name.join(','));
  133. $('[name="did"]').val(select_did.join(','));
  134. $('[name="department"]').val(select_dname.join(','));
  135. }
  136. });
  137. });
  138. //添加阶段信息表格
  139. $('#stepAdd').on('click',function(){
  140. var html = '';
  141. html += '<tr class="step-tr">\
  142. <td class="step-key">第 <strong>0</strong> 阶段</td>\
  143. <td>\
  144. <div class="layui-input-group">\
  145. <input type="text" name="step_title[]" value="" class="layui-input" lay-verify="required" lay-reqText="请输入阶段名称">\
  146. <div class="layui-input-split layui-input-suffix picker-diy" style="cursor: pointer;"><i class="layui-icon layui-icon-search"></i></div>\
  147. </div>\
  148. </td>\
  149. <td>\
  150. <input type="text" value="" class="layui-input layui-input-readonly picker-admin" lay-verify="required" lay-reqText="请选择阶段负责人" readonly>\
  151. <input type="hidden" name="step_director_uid[]" value="0" readonly>\
  152. </td>\
  153. <td>\
  154. <input type="text" value="" class="layui-input layui-input-readonly picker-admin" data-type="2">\
  155. <input type="hidden" name="step_uids[]" value="">\
  156. </td>\
  157. <td><input type="text" name="step_cycle_time[]" value="" class="layui-input layui-input-readonly tool-time" data-range="到" lay-verify="required" lay-reqText="请选择服务周期" readonly></td>\
  158. <td><input type="text" name="step_remark[]" value="" class="layui-input"></td>\
  159. <td>\
  160. <input type="hidden" name="step_id[]" value="0" class="layui-input">\
  161. <div class="layui-btn-group">\
  162. <span class="layui-btn layui-btn-xs step-up">上移</span>\
  163. <span class="layui-btn layui-btn-normal layui-btn-xs step-down">下移</span>\
  164. <span class="layui-btn layui-btn-danger layui-btn-xs step-del" data-id="0">删除</span>\
  165. </div>\
  166. </td>\
  167. </tr>';
  168. $('#stepTable').append(html).find('.tr-none').remove();
  169. $('#stepTable').find('.step-key').each(function(index,item){
  170. $(this).html('第 <strong>'+(index+1)+'</strong> 阶段');
  171. })
  172. form.render();
  173. });
  174. $('#stepTable').on('click','.step-del',function(){
  175. if($('.step-tr').length<2){
  176. layer.msg('至少保留一个项目阶段');
  177. return false;
  178. }
  179. $(this).parents('.step-tr').remove();
  180. $('#stepTable').find('.step-key').each(function(index,item){
  181. $(this).html('第 <strong>'+(index+1)+'</strong> 阶段');
  182. })
  183. });
  184. $('#stepTable').on('click','.step-up',function(e){
  185. let obj = $(e.target).closest('tr');
  186. tr_pre($(obj[0]));
  187. })
  188. $('#stepTable').on('click','.step-down',function(e){
  189. var obj = $(e.target).closest('tr');
  190. tr_next($(obj[0]));
  191. })
  192. function tr_pre(o) {
  193. var pres = o.prevAll('tr.step-tr');
  194. if (pres.length > 0) {
  195. var tmp = o.clone(true);
  196. var oo = pres[0];
  197. o.remove();
  198. $(oo).before(tmp);
  199. $('#stepTable').find('.step-key').each(function(index,item){
  200. $(this).html('第 <strong>'+(index+1)+'</strong> 阶段');
  201. })
  202. }
  203. else{
  204. layer.msg('已经第一个了');
  205. }
  206. }
  207. function tr_next(o) {
  208. var nexts = o.nextAll('tr.step-tr');
  209. if (nexts.length > 0) {
  210. var tmp = o.clone(true);
  211. var oo = nexts[0];
  212. o.remove();
  213. $(oo).after(tmp);
  214. $('#stepTable').find('.step-key').each(function(index,item){
  215. $(this).html('第 <strong>'+(index+1)+'</strong> 阶段');
  216. })
  217. }else{
  218. layer.msg('已经最后一个了');
  219. }
  220. }
  221. $('body').on('click','.picker-diy',function () {
  222. let that = $(this),ids = [],titles=[],map = {};
  223. let callback = function(data){
  224. for ( var i = 0; i <data.length; i++){
  225. ids.push(data[i].id);
  226. titles.push(data[i].title);
  227. }
  228. that.prev().val(titles.join(','));
  229. }
  230. let opts={
  231. "title":"选择项目阶段",
  232. "url": "/project/api/get_project_step",
  233. "ids":"",
  234. "titles":"",
  235. "area": ['600px', '580px'],
  236. "cols":[{field: 'id',width: 80,title:'序号',align:'center'},{field:'title',title:'项目阶段'}]
  237. }
  238. oaPicker.picker(opts,1,callback,map);//单选
  239. });
  240. //监听提交
  241. form.on('submit(webform)', function (data) {
  242. let callback = function (e) {
  243. layer.msg(e.msg);
  244. if (e.code == 0) {
  245. tool.sideClose(1000);
  246. }
  247. }
  248. let clickbtn = $(this);
  249. tool.post("/project/index/add", data.field, callback,clickbtn);
  250. return false;
  251. });
  252. }
  253. </script>
  254. {/block}
  255. <!-- /脚本 -->