create.blade.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  1. @extends('layouts.app')
  2. @section('title')计费模型-仓储计费@endsection
  3. @section('content')
  4. <div id="nav2">
  5. @component('maintenance.menu')@endcomponent
  6. @component('maintenance.priceModel.operation.menu')
  7. @if(isset($model))
  8. <li class="nav-item">
  9. <a class="nav-link" href="{{URL::current()}}" :class="{active:isActive('edit',5)}">编辑</a>
  10. </li>
  11. @endif
  12. @endcomponent
  13. </div>
  14. <div class="container-fluid mt-2 card" id="container">
  15. @include("maintenance.priceModel.operation._addFeature")
  16. <form method="POST" action="{{url('maintenance/priceModel/operation')}}@if(isset($model))/{{$model->id}}/edit @endif" class="card-body offset-3">
  17. @csrf
  18. <div class="row">
  19. <label class="col-2" for="owner_id">项目</label>
  20. <select id="owner_id" class="selectpicker" multiple data-live-search="true" title="项目(多选)" :class="errors.owner_id ? 'is-invalid' : ''" v-model="model.owner_id">
  21. <option v-for="owner in owners" :value="owner.id">@{{ owner.name }}</option>
  22. </select>
  23. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors.owner_id">
  24. <strong>@{{ errors.owner_id[0] }}</strong>
  25. </span>
  26. <label hidden><input :value="model.owner_id" name="owner_id"></label>
  27. </div>
  28. <div class="row mt-3">
  29. <label for="operation_type" class="col-2">操作类型</label>
  30. <select id="operation_type" :disabled="model.id ? true : false" :class="errors.operation_type ? 'is-invalid' : ''" v-model="model.operation_type" class="col-3 form-control" required>
  31. <option value="入库">入库</option>
  32. <option value="出库">出库</option>
  33. </select>
  34. <label hidden><input name="operation_type" :value="model.operation_type"></label>
  35. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors.operation_type">
  36. <strong>@{{ errors.operation_type[0] }}</strong>
  37. </span>
  38. </div>
  39. <div class="row mt-3">
  40. <label for="strategy" class="col-2">计费策略</label>
  41. <select id="strategy" :disabled="model.id ? true : false" :class="errors.strategy ? 'is-invalid' : ''" class="col-3 form-control" v-model="model.strategy" required>
  42. <option value="默认">默认</option>
  43. <option value="特征">特征</option>
  44. </select>
  45. <label hidden><input name="strategy" :value="model.strategy"></label>
  46. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors.strategy">
  47. <strong>@{{ errors.strategy[0] }}</strong>
  48. </span>
  49. </div>
  50. <div class="row mt-3">
  51. <label for="name" class="col-2">名称</label>
  52. <input id="name" type="text" name="name" :class="errors.name ? 'is-invalid' : ''" class="col-6 form-control" v-model="model.name" required>
  53. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors.name">
  54. <strong>@{{ errors.name[0] }}</strong>
  55. </span>
  56. </div>
  57. <div class="row mt-3" v-if="model.strategy == '特征'">
  58. <label class="col-2">特征:</label>
  59. <label v-if="model.feature">
  60. @{{ model.feature }}
  61. <input hidden name="feature" :value="model.feature" type="text">
  62. </label>
  63. <button type="button" class="btn btn-dark col-2 ml-2" @click="showAddFeatureModal(-1,model.feature)">调整特征</button>
  64. </div>
  65. <div class="row mt-3">
  66. <label for="priority" class="col-2">优先级</label>
  67. <input id="priority" type="number" min="0" value="0" name="priority" :class="errors.priority ? 'is-invalid' : ''" class="col-6 form-control" v-model="model.priority" required>
  68. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors.priority">
  69. <strong>@{{ errors.priority[0] }}</strong>
  70. </span>
  71. </div>
  72. <div class="row mt-3">
  73. <div v-for="(item,i) in model.items" class="card row text-white col-8" :class="i>0 ? 'bg-secondary mt-2' : 'bg-info'">
  74. <div class="card-header">
  75. <div class="pull-left" v-if="i==0"><span @click="addRule()" class="fa fa-plus-square-o" style="cursor: pointer"></span></div>
  76. <div class="pull-right" v-if="model.items.length > 1"><span @click="delRule(i)" class="fa fa-window-close-o" style="cursor: pointer"></span></div>
  77. </div>
  78. <div class="card-body">
  79. <div class="row">
  80. <div class="col-4 form-inline">
  81. <label for="amount"><span v-if="item.strategy=='起步'">起步数:</span><span v-else>计量:</span></label>
  82. <input id="amount" type="number" :class="errors['items.'+i+'.amount'] ? 'is-invalid' : ''" v-model="item.amount" class="form-control" required>
  83. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['items.'+i+'.amount']">
  84. <strong>必须为整数</strong>
  85. </span>
  86. </div>
  87. <div class="col-4 form-inline">
  88. <label for="unit_id">单位:</label>
  89. <select id="unit_id" v-model="item.unit_id" class="form-control" :class="errors['items.'+i+'.unit_id'] ? 'is-invalid' : ''" required>
  90. <option v-for="unit in units" :value="unit.id">@{{ unit.name }}</option>
  91. </select>
  92. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['items.'+i+'.unit_id']">
  93. <strong>必选项</strong>
  94. </span>
  95. </div>
  96. <div class="col-4 form-inline">
  97. <label for="unit_price">单价:</label>
  98. <input id="unit_price" type="number" min="0" step="0.001" class="form-control" v-model="item.unit_price" required
  99. :class="errors['items.'+i+'.unit_price'] ? 'is-invalid' : ''">
  100. </div>
  101. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['items.'+i+'.unit_price']">
  102. <strong>必须为数字且不得为负</strong>
  103. </span>
  104. </div>
  105. <div class="row mt-2">
  106. <label for="out_priority" class="col-2">优先级:</label>
  107. <input type="number" min="0" id="out_priority" v-model="item.priority" :class="errors['items.'+i+'.priority'] ? 'is-invalid' : ''" class="col-5 form-control">
  108. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['items.'+i+'.priority']">
  109. <strong>必须为整数且数值区间为[0-100]</strong>
  110. </span>
  111. </div>
  112. <div class="row mt-2">
  113. <label for="out_storage_strategy" class="col-2">子策略:</label>
  114. <select id="out_storage_strategy" v-model="item.strategy" class="col-5 form-control"
  115. @change="outRuleUnique(item.strategy)"
  116. :class="errors['items.'+i+'.strategy'] ? 'is-invalid' : ''">
  117. <optgroup v-if="existStrategy.starting && item.strategy!='起步'" label="起步"></optgroup>
  118. <option v-else>起步</option>
  119. <optgroup v-if="existStrategy.default && item.strategy!='默认'" label="默认"></optgroup>
  120. <option v-else>默认</option>
  121. <option>特征</option>
  122. </select>
  123. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['items.'+i+'.strategy']">
  124. <strong>必选项</strong>
  125. </span>
  126. </div>
  127. <div class="row mt-2" v-if="item.strategy == '特征'">
  128. <label class="col-2">特征:</label>
  129. <label v-if="item.feature">@{{ item.feature }}</label>
  130. <button type="button" class="btn btn-dark col-2 ml-2" @click="showAddFeatureModal(i,item.feature)">调整特征</button>
  131. </div>
  132. </div>
  133. </div>
  134. <label hidden><input name="items" :value="JSON.stringify(model.items)"></label>
  135. </div>
  136. <div class="row mt-3">
  137. <label for="remark" class="col-2">备注</label>
  138. <textarea id="remark" name="remark" class="col-6 form-control" v-model="model.remark"></textarea>
  139. </div>
  140. <div class="row mt-3 offset-1">
  141. <button type="submit" class="btn btn-success col-7">提交</button>
  142. </div>
  143. </form>
  144. </div>
  145. @stop
  146. @section("lastScript")
  147. <script>
  148. new Vue({
  149. el:"#container",
  150. data:{
  151. model:{
  152. id: "{{isset($model) ? $model->id : ''}}",
  153. owner_id:{!! old('owner_id') ? json_encode(old('owner_id')) : (isset($model) ? json_encode(array_column($model->ownerPriceOperationOwners->toArray(),"id")) : '[]') !!},
  154. operation_type:"{{old('operation_type') ?? (isset($model) ? $model->operation_type : '')}}",
  155. strategy:"{{old('strategy') ?? (isset($model) ? $model->strategy : '')}}",
  156. name:"{{old('name') ?? (isset($model) ? $model->name : '')}}",
  157. priority:"{{old('priority') ?? (isset($model) ? $model->priority : '')}}",
  158. feature:"{{old('feature') ?? (isset($model) ? $model->feature : '')}}",
  159. remark:"{{old('remark') ?? (isset($model) ? $model->remark : '')}}",
  160. items:{!! old('items') ? json_encode(old('items')) : (isset($model)&&$model->items ? $model->items : "[{strategy:'',amount:'',unit_id:'',unit_price:'',feature:'',priority:''}]")!!},
  161. },
  162. owners : [
  163. @foreach($owners as $owner)
  164. {id:"{{$owner->id}}",name:"{{$owner->name}}"},
  165. @endforeach
  166. ],
  167. units : [
  168. @foreach($units as $unit)
  169. {id:"{{$unit->id}}",name:"{{$unit->name}}"},
  170. @endforeach
  171. ],
  172. type : ['商品名称','订单类型','承运商','店铺类型'],
  173. logic : ['包含','不包含','等于'],
  174. features : [],
  175. thisIndex : "",
  176. errors:{!! $errors !!},
  177. existStrategy:{default:false,starting:false},
  178. oldFeature : '',
  179. },
  180. methods:{
  181. outRuleUnique(strategy){
  182. if (strategy==='起步') this.existStrategy.starting = true;
  183. if (strategy==='默认') this.existStrategy.default = true;
  184. let startingSign = true;
  185. let defaultSign = true;
  186. this.model.items.forEach(item=>{
  187. if (item.strategy === '默认')defaultSign = false;
  188. if (item.strategy === '起步')startingSign = false;
  189. });
  190. if (startingSign)this.existStrategy.starting = false;
  191. if (defaultSign)this.existStrategy.default = false;
  192. },
  193. addRule(){
  194. this.model.items.push({
  195. "strategy" : "",
  196. "amount" : "",
  197. "unit_id" : "",
  198. "unit_price" : "",
  199. "feature" : "",
  200. "priority" : "",
  201. });
  202. },
  203. delRule(index){
  204. this.$delete(this.model.items,index);
  205. },
  206. showAddFeatureModal(index,feature){
  207. if (!feature){
  208. this.features = [{
  209. "strategyGroupStartSign": false,
  210. "calculation" : "",
  211. "type" : "",
  212. "id" : "", //特征ID
  213. "logic" : "", //特征逻辑
  214. "describe" : "", //特征信息
  215. "strategyGroupEndSign" : false,
  216. }];
  217. this.thisIndex = index;
  218. $("#addFeatureModal").modal("show");
  219. return;
  220. }
  221. if (this.oldFeature === feature) {
  222. this.thisIndex = index;
  223. $("#addFeatureModal").modal("show");
  224. return;
  225. }
  226. window.axios.post("{{url('maintenance/priceModel/operation/getFeatures')}}", {feature:feature})
  227. .then(res=>{
  228. if (res.data.success){
  229. this.features = res.data.data;
  230. this.oldFeature = feature;
  231. if (!this.features || this.features.length === 0){
  232. this.features = [{
  233. "strategyGroupStartSign": false,
  234. "calculation" : "",
  235. "type" : "",
  236. "id" : "", //特征ID
  237. "logic" : "", //特征逻辑
  238. "describe" : "", //特征信息
  239. "strategyGroupEndSign" : false,
  240. }];
  241. }
  242. this.thisIndex = index;
  243. $("#addFeatureModal").modal("show");
  244. return;
  245. }
  246. window.tempTip.setDuration(3000);
  247. window.tempTip.show(res.data.data);
  248. }).catch(err=>{
  249. window.tempTip.setDuration(3000);
  250. window.tempTip.show("网络错误:"+err);
  251. });
  252. },
  253. addFeature(){
  254. this.features.push({
  255. "strategyGroupStartSign": false,
  256. "calculation" : "",
  257. "type" : "",
  258. "id" : "", //特征ID
  259. "logic" : "", //特征逻辑
  260. "describe" : "", //特征信息
  261. "strategyGroupEndSign" : false,
  262. });
  263. },
  264. delFeature(index) {
  265. this.$delete(this.features,index);
  266. },
  267. submitFeature(){
  268. window.axios.post("{{url('maintenance/priceModel/operation/getFeature')}}",
  269. {features:this.features})
  270. .then(res=>{
  271. if (res.data.success){
  272. if (this.thisIndex == '-1') this.model.feature = res.data.data;
  273. else this.model.items[this.thisIndex].feature = res.data.data;
  274. $("#addFeatureModal").modal("hide");
  275. window.tempTip.setDuration(2000);
  276. window.tempTip.setIndex(1099);
  277. window.tempTip.showSuccess("已更新特征");
  278. return;
  279. }
  280. window.tempTip.setDuration(3000);
  281. window.tempTip.setIndex(1099);
  282. window.tempTip.show(res.data.data);
  283. }).catch(err=>{
  284. window.tempTip.setDuration(3000);
  285. window.tempTip.setIndex(1099);
  286. window.tempTip.show("网络错误:"+err);
  287. });
  288. },
  289. },
  290. });
  291. </script>
  292. @stop