procurementBill.blade.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. @extends('layouts.app')
  2. @section('title')采购管理-财务-采购账单@endsection
  3. @section('content')
  4. @component('procurement.finance.menu')@endcomponent
  5. <div class="container-fluid" id="list">
  6. <div id="form_div" class="mt-1"></div>
  7. <div class="row mt-2">
  8. <span class="dropdown ml-3">
  9. <button class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget"
  10. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的筛选结果,将其全部记录(每一页)导出">
  11. 导出Excel
  12. </button>
  13. <div class="dropdown-menu">
  14. <a class="dropdown-item" @click="procurementBillExport(false)" href="javascript:">导出勾选内容</a>
  15. <a class="dropdown-item" @click="procurementBillExport(true)" href="javascript:">导出所有页</a>
  16. </div>
  17. </span>
  18. </div>
  19. <table class="table table-sm table-striped table-bordered table-hover text-nowrap card-body mt-2" id="table">
  20. <tr v-for="(procurement,i) in procurements">
  21. <td>
  22. <input class="checkItem" type="checkbox" :value="procurement.id">
  23. </td>
  24. <td class="">@{{ procurement.code }}</td>
  25. <td class="">@{{ procurement.created_at }}</td>
  26. <td class=""><span v-if="procurement.supplier_id">@{{ procurement.deadline }}</span></td>
  27. <td class=""><span v-if="procurement.signed_at">@{{ procurement.signed_at }}</span></td>
  28. <td v-if="procurement.owner_material.owner">@{{ procurement.owner_material.owner.name }}</td>
  29. <td v-if="procurement.owner_material.owner.customer">@{{ procurement.owner_material.owner.customer.company_name }}</td>
  30. <td ><span v-if="procurement.supplier">@{{ procurement.supplier.name }}</span></td>
  31. <td class="tooltipTarget" style="max-width: 200px;overflow:hidden" v-if="procurement.owner_material.material">@{{ procurement.owner_material.material.code }}</td>
  32. <td class="text-muted" v-if="procurement.owner_material.material">@{{ procurement.owner_material.material.name }}</td>
  33. <td class="text-muted" v-if="procurement.owner_material">@{{ procurement.owner_material.size }}</td>
  34. <td class="text-muted" v-if="procurement.owner_material">@{{ procurement.owner_material.special }}</td>
  35. <td class="text-muted" v-if="procurement.owner_material">@{{ procurement.owner_material.specification }}</td>
  36. <td>@{{ procurement.quantity }}</td>{{--采购数量--}}
  37. <td>@{{ procurement.amount }}</td> {{--销售数量--}}
  38. <td><span v-if="procurement.receive_amount">@{{ procurement.receive_amount }}</span></td>
  39. <td>@{{ procurement.cost_price }}</td> {{--采购单价--}}
  40. <td>@{{ procurement.unit_price }}</td> {{--销售单价--}}
  41. <td>@{{ procurement.amount*procurement.cost_price }}</td> {{--应收--}}
  42. <td>@{{ procurement.quantity*procurement.unit_price }}</td> {{--应付--}}
  43. <td><span>@{{ procurement_status[procurement.status] }}</span></td>
  44. <td>
  45. <span v-if="procurement.status<9">
  46. <span class="btn btn-sm btn-outline-danger">锁定</span>
  47. <span class="btn btn-sm btn-outline-success" @click="changeCostPrice(procurement.id,procurement.cost_price)">修改采购单价</span>
  48. </span>
  49. </td>
  50. </tr>
  51. </table>
  52. @can('采购管理-财务-采购账单')
  53. @include('procurement.finance._changeCostPrice')
  54. @endcan
  55. <div class="text-info h5 btn btn">{{$procurements->count()}}/@{{ sum }}</div>
  56. <div>{{$procurements->appends($paginateParams)->links()}}</div>
  57. </div>
  58. @endsection
  59. @section('lastScript')
  60. <script type="text/javascript" src="{{mix('js/queryForm/export.js')}}"></script>
  61. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  62. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版--}}
  63. <script>
  64. let vue = new Vue({
  65. el: '#list',
  66. data: {
  67. procurements: {!! $procurements->toJson() !!}['data'],
  68. owners:[
  69. @foreach($owners as $owner)
  70. {name:'{{$owner->id}}',value:'{{$owner->name}}'},
  71. @endforeach
  72. ],
  73. materials: [
  74. @foreach($materials as $material)
  75. {name:'{{$material->id}}',value:'{{$material->name}}'},
  76. @endforeach
  77. ],
  78. suppliers:[
  79. @foreach($suppliers as $supplier)
  80. {name:'{{$supplier->id}}',value:'{{$supplier->name}}'},
  81. @endforeach
  82. ],
  83. sum:{!! $procurements->total() !!},
  84. procurement_status:{!! json_encode(\App\Procurement::status,JSON_UNESCAPED_UNICODE) !!},
  85. procurement_id:'',cost_price:'',
  86. },
  87. mounted: function () {
  88. $(".tooltipTarget").tooltip({'trigger': 'hover'});
  89. $('#list').removeClass('d-none');
  90. let data = [
  91. [
  92. {name: 'created_at_start', type: 'dateTime', tip: '选择显示指定日期的起始时间'},
  93. {name: 'created_at_end', type: 'dateTime', tip: '选择显示指定日期的结束时间'},
  94. {
  95. name: 'owner_id', type: 'select_multiple_select', tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的项目'],
  96. placeholder: ['项目', '定位或多选项目'], data: this.owners
  97. },
  98. {
  99. name: 'material_id', type: 'select_multiple_select', tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的耗材'],
  100. placeholder: ['耗材', '定位或多选耗材'], data: this.materials
  101. },
  102. {
  103. name: 'supplier_id', type: 'select_multiple_select', tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的供应商'],
  104. placeholder: ['供应商', '定位或多选供应商'], data: this.suppliers
  105. },
  106. {name: 'company_name', type: 'input', tip: '采购公司:可在两侧增加百分号(%)进行模糊搜索', placeholder: '采购公司'},
  107. ],
  108. ];
  109. this.form = new query({
  110. el: "#form_div",
  111. condition: data,
  112. });
  113. this.form.init();
  114. let column = [
  115. {name: 'code', value: '采购编号', neglect: true,class: 'text-center'},
  116. {name: 'code', value: '采购日期', neglect: true,class: 'text-center'},
  117. {name: 'code', value: '接单日期', neglect: true,class: 'text-center'},
  118. {name: 'code', value: '签收日期', neglect: true,class: 'text-center'},
  119. {name: 'owner_id', value: '项目名称',class: 'text-center'},
  120. {name: 'company_name', value: '采购公司',class: 'text-center'},
  121. {name: 'supplier_name', value: '供应商',class: 'text-center'},
  122. {name: 'material_code', value: '耗材编号',class: 'text-center'},
  123. {name: 'material_name', value: '耗材',class: 'text-center'},
  124. {name: 'size', value: '尺寸大小',class: 'text-center'},
  125. {name: 'special', value: '特殊要求',class: 'text-center'},
  126. {name: 'specification', value: '材质规格',class: 'text-center'},
  127. {name: 'quantity', value: '采购数量', neglect: true,class: 'text-center'},
  128. {name: '', value: '销售数量', neglect: true,class: 'text-center'},
  129. {name: 'deliver_amount', value: '收货数量', neglect: true,class: 'text-center'},
  130. {name: '', value: '采购单价(元)', neglect: true,class: 'text-center'},
  131. {name: 'unit_price', value: '销售单价(元)', neglect: true,class: 'text-center'},
  132. {name: '', value: '应收金额(元)', neglect: true,class: 'text-center'},
  133. {name: '', value: '应付金额(元)', neglect: true,class: 'text-center'},
  134. {name: '', value: '状态', neglect: true,class: 'text-center'},
  135. {name: '', value: '操作', neglect: true,class: 'text-center'},
  136. ];
  137. new Header({
  138. el: "table",
  139. column: column,
  140. data: this.procurements,
  141. fixedTop: ($('#form_div').height()) + 2,
  142. }).init();
  143. },
  144. methods: {
  145. changeCostPrice(id,cost_price){
  146. this.procurement_id=id;
  147. this.cost_price=cost_price;
  148. $("#change-costPrice").modal('show');
  149. },
  150. costPrice(){
  151. let _this=this;
  152. let url='{{url('procurement/finance/costPrice')}}';
  153. let param={id:_this.procurement_id,cost_price:_this.cost_price};
  154. window.axios.post(url,param).then(function (res) {
  155. if (res.data.success){
  156. _this.procurements.forEach(function (procurement) {
  157. if (procurement.id===res.data.data.id){
  158. procurement.cost_price=res.data.data.cost_price;
  159. $("#change-costPrice").modal('hide');
  160. }
  161. })
  162. }else {
  163. tempTip.setDuration(3000);
  164. tempTip.show(res.data.message);
  165. }
  166. }).catch(function (err) {
  167. window.tempTip.setDuration(3000);
  168. window.tempTip.show("网络错误:" + err);
  169. })
  170. },
  171. procurementBillExport(selectAll){
  172. let url = '{{url('procurement/finance/procurementBillExport')}}';
  173. let token='{{ csrf_token() }}';
  174. excelExport(selectAll,checkData,url,this.sum,token);
  175. },
  176. }
  177. });
  178. </script>
  179. @endsection