index.blade.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. @extends('layouts.app')
  2. @section('title')项目列表-项目管理@endsection
  3. @section('content')
  4. <div class="container-fluid d-none" id="container">
  5. <div id="form_div"></div>
  6. <div class="modal fade" tabindex="-1" role="dialog" id="modal">
  7. <div class="modal-dialog modal-dialog-scrollable modal-dialog-centered">
  8. <div class="modal-content">
  9. <div class="modal-body">
  10. <div class="container-fluid" v-if="priceModel[thisClickIndex]">
  11. <div class="row" v-for="(model,i) in priceModel[thisClickIndex]['ownerStoragePriceModels']">
  12. <label class="text-dark font-weight-bold col-3"><span v-if="i==0">仓储:</span></label>
  13. <a target="_blank" @can("计费模型-仓储-录入"):href="'{{url('customer/project')}}/'+thisClickIndex+'/edit?type=storage'" @endcan class="text-decoration-none">@{{ model.counting_type }}-@{{ model.using_type }}</a>
  14. </div>
  15. <hr class="m-1" v-if="priceModel[thisClickIndex]['ownerPriceOperations'].length>0">
  16. <div class="row" v-for="(model,i) in priceModel[thisClickIndex]['ownerPriceOperations']">
  17. <label class="text-dark font-weight-bold col-3"><span v-if="i==0">作业:</span></label>
  18. <a target="_blank" @can("计费模型-作业-录入"):href="'{{url('customer/project')}}/'+thisClickIndex+'/edit?type=operation'" @endcan class="text-decoration-none">@{{ model.name }}</a>
  19. </div>
  20. <hr class="m-1" v-if="priceModel[thisClickIndex]['ownerPriceExpresses'].length>0">
  21. <div class="row" v-for="(model,i) in priceModel[thisClickIndex]['ownerPriceExpresses']">
  22. <label class="text-dark font-weight-bold col-3"><span v-if="i==0">快递:</span></label>
  23. <a target="_blank" @can("计费模型-快递-录入"):href="'{{url('customer/project')}}/'+thisClickIndex+'/edit?type=express'" @endcan class="text-decoration-none">@{{ model.name }}</a>
  24. </div>
  25. <hr class="m-1" v-if="priceModel[thisClickIndex]['ownerPriceLogistics'].length>0">
  26. <div class="row" v-for="(model,i) in priceModel[thisClickIndex]['ownerPriceLogistics']">
  27. <label class="text-dark font-weight-bold col-3"><span v-if="i==0">物流:</span></label>
  28. <a target="_blank" @can("计费模型-物流-录入"):href="'{{url('customer/project')}}/'+thisClickIndex+'/edit?type=logistic'" @endcan class="text-decoration-none">@{{ model.name }}</a>
  29. </div>
  30. <hr class="m-1" v-if="priceModel[thisClickIndex]['ownerPriceDirectLogistics'].length>0">
  31. <div class="row" v-for="(model,i) in priceModel[thisClickIndex]['ownerPriceDirectLogistics']">
  32. <label class="text-dark font-weight-bold col-3"><span v-if="i==0">直发车:</span></label>
  33. <a target="_blank" @can("计费模型-直发-录入"):href="'{{url('customer/project')}}/'+thisClickIndex+'/edit?type=directLogistic'" @endcan class="text-decoration-none">@{{ model.name }}</a>
  34. </div>
  35. </div>
  36. </div>
  37. <div class="modal-footer">
  38. <button type="button" class="btn btn-secondary" data-dismiss="modal">关闭</button>
  39. </div>
  40. </div>
  41. </div>
  42. </div>
  43. <div class="mt-1">
  44. <button type="button" class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget"
  45. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的筛选结果,将其全部记录(每一页)导出">
  46. 导出Excel
  47. </button>
  48. <div class="dropdown-menu">
  49. <a class="dropdown-item" @click="executeExport(false)" href="javascript:">导出勾选内容</a>
  50. <a class="dropdown-item" @click="executeExport(true)" href="javascript:">导出所有页</a>
  51. </div>
  52. </div>
  53. @if(Session::has('successTip'))
  54. <div class="alert alert-success h1">{{Session::get('successTip')}}</div>
  55. @endif
  56. <div>
  57. <table class="table table-sm text-nowrap table-striped table-hover td-min-width-80" id="table">
  58. <tr v-for="(owner,i) in owners" :class="owner.id===id ? 'focusing' : ''" @click="selectTableRow(owner.id)">
  59. <td>
  60. <label><input type="checkbox" :value="owner.id"></label>
  61. </td>
  62. <td><span>@{{ i+1 }}</span></td>
  63. <td><span>@{{ owner.name }}</span></td>
  64. <td><span>@{{ owner.customer_name }}</span></td>
  65. <td><span>@{{ owner.user_owner_group_name }}</span></td>
  66. {{-- <td><span>@{{ owner.user_work_group_name }}</span></td>--}}
  67. <td><span>@{{ owner.kcGroup }}</span></td>
  68. <td><span>@{{ owner.jgGroup }}</span></td>
  69. <td><span>@{{ owner.thGroup }}</span></td>
  70. <td><span>@{{ owner.shGroup }}</span></td>
  71. <td><span>@{{ owner.fhGroup }}</span></td>
  72. <td><span><b>@{{owner.relevance ? owner.relevance.length : 0}}</b>/6&nbsp;<span class="badge badge-success" v-if="owner.audit_count>0">@{{ owner.audit_count }}项待审</span></span></td>
  73. <td><span>@{{ owner.created_at }}</span></td>
  74. <td><span>@{{ owner.customer_company_name }}</span></td>
  75. <td><span>@{{ ownerSubjection[owner.subjection] }}</span></td>
  76. <td><span>@{{ owner.is_activation }}</span></td>
  77. <td>
  78. <button class="btn btn-sm btn-info text-white" @click="showModal(owner)">各项计价</button>
  79. </td>
  80. <td>
  81. @can("项目管理-项目-编辑")<a :href="'{{url('customer/project')}}/'+owner.id+'/edit'"><button class="btn btn-sm btn0sm btn-outline-info">编辑</button></a>@endcan
  82. @can('客户管理-项目-停用')
  83. <button class="btn btn-sm btn-outline-danger" @click="destroy(owner)">停用</button>
  84. @endcan
  85. </td>
  86. </tr>
  87. </table>
  88. {{$owners->appends($params)->links()}}
  89. </div>
  90. </div>
  91. @endsection
  92. @section('lastScript')
  93. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版2--}}
  94. <script type="text/javascript" src="{{mix('js/queryForm/export.js')}}"></script>
  95. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  96. <script>
  97. let vue = new Vue({
  98. el:"#container",
  99. data:{
  100. owners : [
  101. @foreach($owners as $owner)
  102. { id : "{{$owner->id}}",
  103. relevance:@json($owner->relevance),
  104. customer_name:"{{$owner->customer ? $owner->customer->name : ''}}",
  105. name : "{{$owner->name}}",
  106. created_at : "{{$owner->created_at}}",
  107. subjection : "{{$owner->subjection}}",
  108. customer_company_name:"{{$owner->customer ? $owner->customer->company_name : ''}}",
  109. user_owner_group_name:"{{$owner->userOwnerGroup ? $owner->userOwnerGroup->name : ''}}",
  110. user_work_group_name:"{{$owner->userWorkGroup ? $owner->userWorkGroup->name : ''}}",
  111. is_activation : "{{$owner->deleted_at ? '否' : '是'}}",
  112. ownerStoragePriceModels : {!! $owner->ownerStoragePriceModels !!},
  113. audit_count:"{{count($owner->storageAudit)+count($owner->operationAudit)+count($owner->expressAudit)+count($owner->logisticAudit)+count($owner->directLogisticAudit)+($owner->systemAudit ? 1 : 0)}}",
  114. a:"{{$owner}}",
  115. kc:"{{$owner->kc}}", kcGroup:"{{$owner->kcGroup}}",
  116. jg:"{{$owner->jg}}", jgGroup:"{{$owner->jgGroup}}",
  117. th:"{{$owner->th}}", thGroup:"{{$owner->thGroup}}",
  118. sh:"{{$owner->sh}}", shGroup:"{{$owner->shGroup}}",
  119. fh:"{{$owner->fh}}", fhGroup:"{{$owner->fhGroup}}",
  120. },
  121. @endforeach
  122. ],
  123. sum : Number("{{ $owners->total() }}"),
  124. priceModel : {},
  125. thisClickIndex : "",
  126. models:[
  127. @foreach($models as $model)
  128. {name:"{{$model->id}}",value:"{{$model->name}}"},
  129. @endforeach
  130. ],
  131. customers:[
  132. @foreach($customers as $customer)
  133. {name:"{{$customer->id}}",value:"{{$customer->name}}"},
  134. @endforeach
  135. ],
  136. ownerGroups:[
  137. @foreach($ownerGroups as $ownerGroup)
  138. {name:"{{$ownerGroup->id}}",value:"{{$ownerGroup->name}}"},
  139. @endforeach
  140. ],
  141. ownerSubjection:{!! json_encode(\App\Owner::subjection,JSON_UNESCAPED_UNICODE) !!},
  142. selectTr:'',
  143. id:"",
  144. user_work_groups: [@foreach($userWorkGroups as $userWorkGroup){name:"{{$userWorkGroup->id}}",value:"{{$userWorkGroup->name}}"},@endforeach]
  145. },
  146. mounted(){
  147. $('#container').removeClass('d-none');
  148. let data=[
  149. [
  150. {name:'user_owner_group_id',type:'select',tip:'项目小组',placeholder: '项目小组',data:this.ownerGroups},
  151. // {name:'user_work_group',type:'select',tip: '仓库小组搜索',placeholder: '仓库小组',data:this.user_work_groups},
  152. {name:'kcGroup',type:'select',tip: '库存组搜索',placeholder: '库存组',data:this.user_work_groups},
  153. {name:'jgGroup',type:'select',tip: '加工组搜索',placeholder: '加工组',data:this.user_work_groups},
  154. {name:'shGroup',type:'select',tip: '收货组搜索',placeholder: '收货组',data:this.user_work_groups},
  155. {name:'created_at_start',type:'time',tip:['选择显示创建日期的起始时间','']},
  156. {name:'ids',type:'select_multiple_select',tip:['输入关键词快速定位下拉列表,回车确定','选择要显示的项目'],
  157. placeholder:['项目','定位或多选项目'],data:this.models},
  158. {name:'contract_number',type:'input',tip: '合同号:可在左侧增加百分号(%)进行模糊搜索',placeholder: '合同号'},
  159. ],[
  160. {name:'customers',type:'select_multiple_select',tip:['客户','定位或多选项目'],placeholder: ['客户','定位或多选项目'],data:this.customers},
  161. {name:'using_type',type:'select',placeholder: '用仓类型',data:[{name:"常温",value:"常温"},{name:"恒温",value:"恒温"}]},
  162. {name:'thGroup',type:'select',tip: '退货组搜索',placeholder: '退货组',data:this.user_work_groups},
  163. {name:'fhGroup',type:'select',tip: '发货组搜索',placeholder: '发货组',data:this.user_work_groups},
  164. {name:'created_at_end',type:'time',tip:['选择显示创建日期的结束时间','']},
  165. ],
  166. ];
  167. this.form = new query({
  168. el:"#form_div",
  169. condition:data,
  170. });
  171. this.form.init();
  172. let column = [
  173. {name:'index',value: '序号', neglect: true},
  174. {name:'name',value: '项目'},
  175. {name:'customer',value: '客户'},
  176. {name:'user_owner_group_name',value: '项目小组'},
  177. // {name:'user_work_group_name',value: '仓库小组'},
  178. {name:'kc',value: '库存组'},
  179. {name:'jg',value: '加工组'},
  180. {name:'th',value: '退货组'},
  181. {name:'sh',value: '收货组'},
  182. {name:'fh',value: '发货组'},
  183. {name:'relevance', neglect: true,value: '计费模型填写情况'},
  184. {name:'created_at',value: '创建日期'},
  185. {name:'customer_full_name',value: '公司全称'},
  186. {name:'subjection',value: '主体公司'},
  187. {name:'is_activating',value: '是否激活', neglect: true},
  188. {name:'relating_price',value: '关联报价', neglect: true},
  189. {name:'operating',value: '操作', neglect: true},
  190. ];
  191. new Header({
  192. el: "table",
  193. name: "customer",
  194. column: column,
  195. data: this.owners,
  196. fixedTop:($('#form_div').height())+2,
  197. }).init();
  198. },
  199. methods:{
  200. selectTableRow(id){
  201. this.id = id;
  202. },
  203. executeExport(isAll){
  204. let url = '{{url('customer/project/index/export')}}';
  205. let token='{{ csrf_token() }}';
  206. excelExport(isAll,checkData,url,this.sum,token);
  207. },
  208. showModal(owner){
  209. if (this.priceModel[owner.id]){
  210. this.thisClickIndex = owner.id;
  211. $("#modal").modal('show');
  212. return;
  213. }
  214. window.axios.post('{{url('customer/project/getOwnerPriceModel')}}',{id:owner.id})
  215. .then(res=>{
  216. if (res.data.success){
  217. let model = res.data.data;
  218. model["ownerStoragePriceModels"] = owner.ownerStoragePriceModels;
  219. delete owner.ownerStoragePriceModels;
  220. this.priceModel[owner.id] = model;
  221. this.thisClickIndex = owner.id;
  222. $("#modal").modal('show');
  223. return;
  224. }
  225. window.tempTip.setDuration(3000);
  226. window.tempTip.showSuccess(res.data.data);
  227. }).catch(err=>{
  228. window.tempTip.setDuration(3000);
  229. window.tempTip.show("网络错误:"+err);
  230. });
  231. },
  232. destroy:function(owner){
  233. confirm('确定要停用项目“' + owner.name + '”吗?');
  234. let data=this;
  235. let url = "{{url('maintenance/owner')}}/"+owner.id;
  236. axios.delete(url,{id:owner.id})
  237. .then(function (response) {
  238. if(response.data.success){
  239. for (let i = 0; i < data.owners.length; i++) {
  240. if (data.owners[i].id===owner.id){
  241. data.owners.splice(i,1);
  242. break;
  243. }
  244. }
  245. tempTip.setDuration(1000);
  246. tempTip.showSuccess('停用项目"'+owner.name+'"成功!')
  247. }else{
  248. tempTip.setDuration(1000);
  249. tempTip.show('停用项目"'+owner.name+'"失败!')
  250. }
  251. })
  252. .catch(function (err) {
  253. tempTip.setDuration(3000);
  254. tempTip.show('停用项目失败!'+'网络错误:' + err);
  255. });
  256. },
  257. },
  258. });
  259. </script>
  260. @endsection