procurementBill.blade.php 11 KB

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