create_and_edit.blade.php 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. @extends('layouts.app')
  2. @section('content')
  3. <div class="container d-none" id="create">
  4. <div class="col-md-10 offset-md-1">
  5. <div class="card ">
  6. <div class="card-body">
  7. @if($owner_sundry_fee_detail->id)
  8. <form action="{{ route('ownerSundryFeeDetails.update', $owner_sundry_fee_detail->id) }}" method="POST" accept-charset="UTF-8">
  9. <input type="hidden" name="_method" value="PUT">
  10. @else
  11. <form action="{{ route('ownerSundryFeeDetails.store') }}" method="POST" accept-charset="UTF-8">
  12. @endif
  13. @include('shared._error')
  14. <input type="hidden" name="_token" value="{{ csrf_token() }}">
  15. <div class="form-group">
  16. <label for="fee_explain-field">作业类型</label>
  17. <select class="form-control" name="type" required>
  18. <option value="" hidden disabled {{ $owner_sundry_fee_detail->id ? '' : 'selected' }}>请选择作业类型</option>
  19. @foreach ($types as $value)
  20. <option value="{{ $value }}" {{ $owner_sundry_fee_detail->type == $value ? 'selected' : '' }}>
  21. {{ $value }}
  22. </option>
  23. @endforeach
  24. </select>
  25. </div>
  26. <div class="form-group">
  27. <label for="fee_explain-field">货主</label>
  28. <div class="col-sm-10 form-inline">
  29. <select class="form-control" name="owner_id" required>
  30. <option v-for="owner in filterOwners" :value="owner.id" :selected="owner.id===sundryFee.owner_id">
  31. @{{ owner.name }}
  32. </option>
  33. </select>
  34. <input type="text" placeholder="输入货主进行筛选" class="form-control col-sm-4 offset-1" id="filterOwnerName" @input="filterOwner($event,1)">
  35. </div>
  36. </div>
  37. <div class="form-group">
  38. <label for="fee_explain-field">费用描述</label>
  39. <input class="form-control" type="text" name="fee_explain" id="fee_explain-field" value="{{ old('fee_explain', $owner_sundry_fee_detail->fee_explain ) }}" />
  40. </div>
  41. <div class="form-group">
  42. <label for="remark-field">快递单号</label>
  43. <input class="form-control" type="text" name="logistic_number" id="logistic_number-field" v-model="sundryFee.logistic_number" @input="logistic_number_returnChange($event)"/>
  44. </div>
  45. <div class="form-group">
  46. <label for="fee_explain-field">承运商</label>
  47. <div class="col-sm-10 form-inline">
  48. <select class="form-control" name="logistic_id" required>
  49. <option v-for="logistic in filterLogistics" :value="logistic.id" :selected="logistic.id===sundryFee.logistic_id">
  50. @{{ logistic.name }}
  51. </option>
  52. </select>
  53. <input type="text" placeholder="输入承运商进行筛选" class="form-control col-sm-4 offset-1" id="filterLogisticName" @input="filterLogistic($event,1)">
  54. </div>
  55. </div>
  56. <div class="form-group">
  57. <label for="remark-field">数量</label>
  58. <input class="form-control" type="number" name="amount" id="amount-field" v-model="sundryFee.amount" />
  59. </div>
  60. <div class="form-group">
  61. <label for="remark-field">单价</label>
  62. <input class="form-control" type="number" name="price" id="price-field" v-model="sundryFee.price" />
  63. </div>
  64. <div class="form-group">
  65. <label for="fee-field">收费金额</label>
  66. <input disabled class="form-control" type="number" name="fee" id="fee-field" v-model="getFee" />
  67. </div>
  68. <div class="form-group">
  69. <label for="remark-field">备注</label>
  70. <input class="form-control" type="text" name="remark" id="remark-field" value="{{ old('remark', $owner_sundry_fee_detail->remark ) }}" />
  71. </div>
  72. <div class="well well-sm">
  73. <button type="submit" class="btn btn-primary">保存</button>
  74. <a class="btn btn-link float-xs-right" href="{{ route('ownerSundryFeeDetails.index') }}"> <- 返回</a>
  75. </div>
  76. </form>
  77. </div>
  78. </div>
  79. </div>
  80. </div>
  81. @endsection
  82. @section('lastScript')
  83. <script>
  84. let vue = new Vue({
  85. el: "#create",
  86. data: {
  87. sundryFee: {!! $owner_sundry_fee_detail !!},
  88. logistics:[@foreach($logistics as $logistic){!! $logistic !!},@endforeach],
  89. owners:[@foreach($owners as $owner){!! $owner !!},@endforeach],
  90. createSundayFee: {},
  91. filterOwners: [],
  92. filterLogistics: []
  93. },
  94. created() {
  95. },
  96. mounted() {
  97. $('#create').removeClass('d-none');
  98. this.filterOwners = this.owners;
  99. this.filterLogistics = this.logistics;
  100. this.sundryFee ? this.sundryFee : {};
  101. },
  102. computed: {
  103. getFee() {
  104. return this.sundryFee.amount*this.sundryFee.price;
  105. }
  106. },
  107. methods: {
  108. filterOwner(e,type){
  109. let value = $(e.target).val();
  110. let owners = this.owners;
  111. if(value==='' || value===null)this.filterOwners = owners;
  112. else {
  113. this.filterOwners = owners.filter(function(item){
  114. return item.name.indexOf(value) !== -1;
  115. });
  116. if(this.filterOwners.length>0){
  117. if(type===1)this.sundryFee.owner_id = this.filterOwners[0]['id'];
  118. if(type===2)this.sundryFee.owner_id = this.filterOwners[0]['id'];
  119. }
  120. }
  121. },
  122. filterLogistic(e,type){
  123. let value = $(e.target).val();
  124. let logistics = this.logistics;
  125. if(value==='' || value===null)this.filterOwners = logistics;
  126. else {
  127. this.filterLogistics = logistics.filter(function(item){
  128. return item.name.indexOf(value) !== -1;
  129. });
  130. if(this.filterLogistics.length>0){
  131. if(type===1)this.sundryFee.logistic_id = this.filterLogistics[0]['id'];
  132. if(type===2)this.sundryFee.logistic_id = this.filterLogistics[0]['id'];
  133. }
  134. }
  135. },
  136. logistic_number_returnChange(e){
  137. let number=$(e.target).val();
  138. if(!number)return;
  139. let url='{{"/apiLocal/logistic/numberFeatures/computeLogisticByNumber"}}';
  140. axios.post(url,{logistic_number_return:number}).then(response=> {
  141. if(response.data.success==='true'){
  142. if(response.data.logistic){
  143. this.$set(this.sundryFee,'logistic_id',response.data.logistic.id);
  144. }
  145. }
  146. }).catch(function (response) {
  147. console.log(response);
  148. });
  149. },
  150. },
  151. filters: {},
  152. });
  153. </script>
  154. @endsection