_operation.blade.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. <div class="row mt-3">
  2. <label for="operation_type" class="col-2">操作类型</label>
  3. <select id="operation_type" :class="errors.operation_type ? 'is-invalid' : ''" v-model="model.operation.operation_type" class="col-3 form-control">
  4. <option value="入库">入库</option>
  5. <option value="出库">出库</option>
  6. </select>
  7. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors.operation_type">
  8. <strong>@{{ errors.operation_type[0] }}</strong>
  9. </span>
  10. </div>
  11. <div class="row mt-3">
  12. <label for="strategy" class="col-2">计费策略</label>
  13. <select id="strategy" :class="errors.strategy ? 'is-invalid' : ''" class="col-3 form-control" v-model="model.operation.strategy">
  14. <option value="默认">默认</option>
  15. <option value="特征">特征</option>
  16. </select>
  17. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors.strategy">
  18. <strong>@{{ errors.strategy[0] }}</strong>
  19. </span>
  20. </div>
  21. <div class="row mt-3">
  22. <label class="col-2">名称</label>
  23. <input type="text" :class="errors.name ? 'is-invalid' : ''" class="col-6 form-control" v-model="model.operation.name">
  24. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors.name">
  25. <strong>@{{ errors.name[0] }}</strong>
  26. </span>
  27. </div>
  28. <div class="row mt-3" v-if="model.operation.operation_type == '入库'">
  29. <label class="col-2" for="isRejected">是退货</label>
  30. <input content="col-3" id="isRejected" type="checkbox" class="switch" v-model="model.operation.isRejected">
  31. </div>
  32. <div class="row mt-3" v-if="model.operation.strategy == '特征'">
  33. <label class="col-2">特征</label>
  34. <label class="col-8">
  35. <label v-if="model.operation.feature">@{{ model.operation.featureFormat }}</label><br>
  36. <label v-if="errors.feature" class="text-danger small font-weight-bold">@{{ errors.feature[0] }}</label><br>
  37. <button type="button" class="btn btn-dark w-75 ml-2" @click="showAddFeatureModal(-1,model.operation.feature)">调整特征</button>
  38. </label>
  39. </div>
  40. <div class="row mt-3">
  41. <label class="col-2" for="isDiscount">是否满减</label>
  42. <div class="col-2">
  43. <input type="checkbox" id="isDiscount" class="rounded mt-1" v-model="model.operation.isDiscount" @change="onDiscount(model.operation.isDiscount)">
  44. </div>
  45. <div class="col-8 row" v-if="model.operation.isDiscount">
  46. <div class="col-1 cursor-pointer"><span class="fa fa-plus" @click="addDiscount(model.operation.discount_count)"></span></div>
  47. <label class="col-2" for="discount">满减阈值</label>
  48. <input disabled id="discount" :value="model.operation.discount_count[0]" :class="errors['discount_count_0'] ? 'is-invalid' : ''"
  49. class="form-control form-control-sm col-6" step="1" type="number" min="0">
  50. </div>
  51. </div>
  52. <div class="row mt-1" v-for="(value,i) in model.operation.discount_count" v-if="model.operation.isDiscount && i!=0">
  53. <label class="col-2"></label><div class="col-2"></div>
  54. <div class="col-8 row">
  55. <label class="offset-1 col-2">满减阈值@{{ i+1 }}</label>
  56. <input v-model="model.operation.discount_count[i]" :placeholder="Number(model.operation.discount_count[i-1])+1"
  57. :class="errors['discount_count_'+i] ? 'is-invalid' : ''"
  58. class="form-control form-control-sm col-6" step="1" type="number" :min="Number(model.operation.discount_count[i-1])+1">
  59. <div class="col-1 cursor-pointer text-danger font-weight-bold h4" @click="delDiscount(i)">&times;</div>
  60. </div>
  61. </div>
  62. <div class="row mt-3">
  63. <label class="col-2" for="isSingle">按单计价</label>
  64. <div class="col-2">
  65. <input type="checkbox" id="isSingle" class="pull-left rounded mt-1" v-model="model.operation.isSingle">
  66. </div>
  67. <div class="col-6 row" v-if="model.operation.isSingle">
  68. <label class="col-3" for="total_price">普通价</label>
  69. <input id="total_price" v-model="model.operation.total_price"
  70. class="form-control form-control-sm col-6" :class="errors.total_price ? 'is-invalid' : ''" step="0.01" type="number" min="0">
  71. </div>
  72. </div>
  73. <div class="row mt-1" v-if="model.operation.isSingle && model.operation.isDiscount" v-for="(value,i) in model.operation.discount_count">
  74. <label class="col-2"></label><div class="col-2"></div>
  75. <div class="col-6 row">
  76. <label class="col-3" for="total_discount_price">满减价</label>
  77. <input id="total_discount_price" v-model="model.operation.total_discount_price[i]"
  78. class="form-control form-control-sm col-5" :class="errors.total_discount_price ? 'is-invalid' : ''" step="0.01" type="number" min="0">
  79. <label class="col-4 text-secondary">@{{ value ? (model.operation.discount_count[i+1] ? value+'-'+(model.operation.discount_count[i+1]-1)+' '+(model.operation.operation_type=='入库' ? '件' : '单')+'/月' : value+'+ '+(model.operation.operation_type=='入库' ? '件' : '单')+'/月') : '' }}</label>
  80. </div>
  81. </div>
  82. <div class="row mt-3" v-if="!model.operation.isSingle">
  83. <label class="col-2" for="max_fee">封顶费</label>
  84. <input type="number" id="max_fee" step="0.01" min="0" class="form-control col-6" v-model="model.operation.max_fee">
  85. </div>
  86. <div class="row mt-3" v-if="!model.operation.isSingle">
  87. <div class="btn-group offset-1 col-9 mb-1">
  88. <button type="button" class="btn btn-outline-dark" @click="addOperationItem('起步')">新增起步</button>
  89. <button type="button" class="btn btn-outline-info" @click="addOperationItem('默认')">新增默认</button>
  90. <button type="button" class="btn btn-outline-secondary" @click="addOperationItem('特征')">新增特征</button>
  91. </div>
  92. <div v-for="(item,i) in model.operation.items" class="card row text-white offset-1 col-9" :class="item.strategy=='特征' ? 'bg-secondary' : (item.strategy=='默认' ? 'bg-info' : 'bg-dark')">
  93. <div class="card-header" style="max-height: 50px">
  94. <div class="row">
  95. <div class="col-6 offset-3 text-center">
  96. @{{ item.strategy }}
  97. </div>
  98. <div class="col-3">
  99. <div class="pull-right cursor-pointer text-white" @click="delOperationItem(i)"><small>删除</small>&nbsp;<span class="fa fa-window-close-o"></span></div>
  100. </div>
  101. </div>
  102. </div>
  103. <div class="card-body">
  104. <div class="row mt-2" v-if="item.strategy!='起步'">
  105. <label class="col-3">数量</label>
  106. <label class="col-6 mb-0"><input type="number" step="1" min="0" :class="errors['items.'+i+'.amount'] ? 'is-invalid' : ''" v-model="item.amount" class="form-control"></label>
  107. </div>
  108. <div class="row" v-if="item.strategy=='起步'">
  109. <label class="col-3">
  110. <select class="form-control mt-1" v-model="model.operation.items[0].type">
  111. <option value="0">起步数</option>
  112. <option value="1">起步费</option>
  113. </select>
  114. </label>
  115. <label class="col-6 mb-0">
  116. <input id="amount" type="number" :class="errors['items.0.amount'] ? 'is-invalid' : ''" v-if="model.operation.items[0].type == 0"
  117. v-model="model.operation.items[0].amount" class="form-control" step="1">
  118. <input v-else type="number" min="0" step="0.01" class="form-control" v-model="model.operation.items[0].unit_price"
  119. :class="errors['items.0.unit_price'] ? 'is-invalid' : ''">
  120. </label>
  121. </div>
  122. <div class="row mt-0" v-if="errors['items.'+i+'.amount']">
  123. <div class="offset-3"><small class="text-danger font-weight-bold ml-3"><span v-if="item.strategy=='起步'">起步数</span><span v-else>数量</span>为必填项</small></div>
  124. </div>
  125. <div class="row mt-2" v-if="item.strategy!='起步' || (item.strategy=='起步' && item.type==0)">
  126. <label class="col-3">单位</label>
  127. <label class="col-3 mb-0"><select v-model="item.unit_id" class="form-control" :class="errors['items.'+i+'.unit_id'] ? 'is-invalid' : ''">
  128. <option v-for="unit in pool.units" :value="unit.id" v-if="unit.name=='件' || unit.name=='箱' || unit.name=='m³' || unit.name=='T' || unit.name=='kg'">@{{ unit.name }}</option>
  129. </select></label>
  130. <label class="col-2 text-right" v-if="poolMapping.units[item.unit_id]=='箱'">零头价</label>
  131. <label class="col-3 mb-0" v-if="poolMapping.units[item.unit_id]=='箱'">
  132. <input class="form-control" :class="errors['items.'+i+'.odd_price'] ? 'is-invalid' : ''" v-model="item.odd_price" type="number" step="0.01" min="0">
  133. </label>
  134. </div>
  135. <div class="row mt-0" v-if="errors['items.'+i+'.unit_id']">
  136. <div class="offset-3"><small class="text-danger font-weight-bold ml-3">@{{ errors['items.'+i+'.unit_id'][0] }}</small></div>
  137. </div>
  138. <div class="row mt-2" v-if="item.strategy!='起步' || (item.strategy=='起步' && item.type==0)" v-show="!model.operation.isDiscount">
  139. <label class="col-3"><span v-if="item.strategy=='起步'">起步费</span><span v-else>单价</span></label>
  140. <label class="col-6 mb-0 input-group">
  141. <input type="number" min="0" step="0.01" class="form-control" v-model="item.unit_price"
  142. :class="errors['items.'+i+'.unit_price'] ? 'is-invalid' : ''">
  143. <span class="d-block input-group-append">
  144. <span class="input-group-text">元</span>
  145. </span>
  146. </label>
  147. </div>
  148. <div class="row mt-0" v-if="errors['items.'+i+'.unit_price']">
  149. <div class="offset-3"><small class="text-danger font-weight-bold ml-3"><span v-if="item.strategy=='起步'">起步费</span><span v-else>单价</span>为必填项</small></div>
  150. </div>
  151. <div class="row mt-2" v-if="model.operation.isDiscount" v-for="(value,i) in model.operation.discount_count">
  152. <label class="col-3">满减<span v-if="item.strategy=='起步'">起步费</span><span v-else>价</span>@{{ i>0 ? i : '' }}</label>
  153. <label class="col-6 mb-0 input-group">
  154. <input type="number" min="0" step="0.01" class="form-control" v-model="item.discount_price[i]"
  155. :class="errors['items.'+i+'.discount_price'] ? 'is-invalid' : ''">
  156. <span class="d-block input-group-append">
  157. <span class="input-group-text">元</span>
  158. </span>
  159. </label>
  160. <label class="col-4">@{{ value ? (model.operation.discount_count[i+1] ? value+'-'+(model.operation.discount_count[i+1]-1)+' '+(model.operation.operation_type=='入库' ? '件' : '单')+'/月' : value+'+ '+(model.operation.operation_type=='入库' ? '件' : '单')+'/月') : '' }}</label>
  161. </div>
  162. <div class="row mt-2" v-if="item.strategy=='特征'">
  163. <label class="col-3">特征:</label>
  164. <label class="col-8">
  165. <label v-if="errors['items.'+i+'.feature']" class="text-danger">@{{ errors['items.'+i+'.feature'][0] }}</label>
  166. <label v-if="item.feature">@{{ item.featureFormat }}</label><br>
  167. <button type="button" class="btn w-75 btn-dark ml-2" @click="showAddFeatureModal(i)">调整特征</button>
  168. </label>
  169. </div>
  170. </div>
  171. </div>
  172. </div>
  173. <div class="row mt-3" v-if="model.operation.operation_type=='出库' && !model.operation.isSingle">
  174. <label for="surcharge" class="col-2">耗材附加费</label>
  175. <input id="surcharge" type="number" step="0.01" min="0" class="form-control col-3" :class="errors.surcharge ? 'is-invalid' : ''" v-model="model.operation.surcharge">
  176. <label for="surcharge_unit_id" class="col-2 text-right">单位</label>
  177. <select id="surcharge_unit_id" v-model="model.operation.surcharge_unit_id" class="form-control col-2" :class="errors.surcharge_unit_id ? 'is-invalid' : ''">
  178. <option> </option>
  179. <option v-for="unit in pool.units" :value="unit.id" v-if="unit.name=='件' || unit.name=='单'">@{{ unit.name }}</option>
  180. </select>
  181. </div>
  182. <div class="row mt-3">
  183. <label for="remark" class="col-2">备注</label>
  184. <textarea id="remark" class="col-6 form-control" v-model="model.operation.remark"></textarea>
  185. </div>
  186. <div class="row mt-3">
  187. <label for="tax_rate_id" class="col-2 text-muted">税率</label>
  188. <select id="tax_rate_id" class="col-3 form-control" v-model="model.operation.tax_rate_id" :class="errors.tax_rate_id ? 'is-invalid' : ''">
  189. <option> </option>
  190. <option v-for="tax in pool.taxRates" :value="tax.id">@{{ tax.value }}%</option>
  191. </select>
  192. </div>