create.blade.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  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">
  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="(rule,i) in model.rules" class="card row text-white col-8" :class="i>0 ? 'bg-secondary mt-2' : 'bg-info'">
  74. <div class="card-header" v-if="model.operation_type=='出库'">
  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.rules.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="model.operation_type=='出库'">起步数:</span><span v-else>计量:</span></label>
  82. <input id="amount" :readonly="(model.operation_type=='出库' && rule.strategy=='起步') || model.operation_type!='出库' ? false : true"
  83. type="number" :class="errors['rules.'+i+'.amount'] ? 'is-invalid' : ''" v-model="rule.amount" class="form-control" required>
  84. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['rules.'+i+'.amount']">
  85. <strong>必须为整数</strong>
  86. </span>
  87. </div>
  88. <div class="col-4 form-inline">
  89. <label for="unit_id">单位:</label>
  90. <select id="unit_id" v-model="rule.unit_id" class="form-control" :class="errors['rules.'+i+'.unit_id'] ? 'is-invalid' : ''" required>
  91. <option v-for="unit in units" :value="unit.id">@{{ unit.name }}</option>
  92. </select>
  93. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['rules.'+i+'.unit_id']">
  94. <strong>必选项</strong>
  95. </span>
  96. </div>
  97. <div class="col-4 form-inline">
  98. <label for="unit_price">单价:</label>
  99. <input id="unit_price" type="number" min="0" step="0.001" class="form-control" v-model="rule.unit_price" required
  100. :class="errors['rules.'+i+'.unit_price'] ? 'is-invalid' : ''">
  101. </div>
  102. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['rules.'+i+'.unit_price']">
  103. <strong>必须为数字且不得为负</strong>
  104. </span>
  105. </div>
  106. <div class="row mt-2" v-if="model.operation_type=='出库'">
  107. <label for="out_priority" class="col-2">优先级:</label>
  108. <input type="number" min="0" id="out_priority" v-model="rule.priority" :class="errors['rules.'+i+'.priority'] ? 'is-invalid' : ''" class="col-5 form-control">
  109. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['rules.'+i+'.priority']">
  110. <strong>必须为整数且数值区间为[0-100]</strong>
  111. </span>
  112. </div>
  113. <div class="row mt-2" v-if="model.operation_type=='出库'">
  114. <label for="out_storage_strategy" class="col-2">出库策略:</label>
  115. <select id="out_storage_strategy" v-model="rule.strategy" class="col-5 form-control"
  116. @change="outRuleUnique(rule.strategy)"
  117. :class="errors['rules.'+i+'.strategy'] ? 'is-invalid' : ''">
  118. <optgroup v-if="existStrategy.starting && rule.strategy!='起步'" label="起步"></optgroup>
  119. <option v-else>起步</option>
  120. <optgroup v-if="existStrategy.default && rule.strategy!='默认'" label="默认"></optgroup>
  121. <option v-else>默认</option>
  122. <option>特征</option>
  123. </select>
  124. <span class="invalid-feedback mt-0 offset-2" role="alert" v-if="errors['rules.'+i+'.strategy']">
  125. <strong>必选项</strong>
  126. </span>
  127. </div>
  128. <div class="row mt-2" v-if="model.operation_type=='出库'">
  129. <label class="col-2">特征:</label>
  130. <label v-if="rule.feature">@{{ rule.feature }}</label>
  131. <button type="button" class="btn btn-dark col-2 ml-2" @click="showAddFeatureModal(i,rule.feature)">调整特征</button>
  132. </div>
  133. </div>
  134. </div>
  135. <label hidden><input name="rules" :value="JSON.stringify(model.rules)"></label>
  136. </div>
  137. <div class="row mt-3">
  138. <label for="remark" class="col-2">备注</label>
  139. <textarea id="remark" name="remark" class="col-6 form-control" v-model="model.remark"></textarea>
  140. </div>
  141. <div class="row mt-3 offset-1">
  142. <button type="submit" class="btn btn-success col-7">提交</button>
  143. </div>
  144. </form>
  145. </div>
  146. @stop
  147. @section("lastScript")
  148. <script>
  149. new Vue({
  150. el:"#container",
  151. data:{
  152. model:{
  153. id: "{{isset($model) ? $model->id : ''}}",
  154. owner_id:{!! old('owner_id') ? json_encode(old('owner_id')) : (isset($model) ? json_encode(array_column($model->ownerPriceOperationOwners->toArray(),"id")) : '[]') !!},
  155. operation_type:"{{old('operation_type') ?? (isset($model) ? $model->operation_type : '')}}",
  156. strategy:"{{old('strategy') ?? (isset($model) ? $model->strategy : '')}}",
  157. name:"{{old('name') ?? (isset($model) ? $model->name : '')}}",
  158. priority:"{{old('priority') ?? (isset($model) ? $model->priority : '')}}",
  159. feature:"{{old('feature') ?? (isset($model) ? $model->feature : '')}}",
  160. remark:"{{old('remark') ?? (isset($model) ? $model->remark : '')}}",
  161. rules:{!! old('rules') ? json_encode(old('rules')) : (isset($model)&&$model->rules ? $model->rules : "[{strategy:'',amount:'',unit_id:'',unit_price:'',feature:'',priority:''}]")!!},
  162. },
  163. owners : [
  164. @foreach($owners as $owner)
  165. {id:"{{$owner->id}}",name:"{{$owner->name}}"},
  166. @endforeach
  167. ],
  168. units : [
  169. @foreach($units as $unit)
  170. {id:"{{$unit->id}}",name:"{{$unit->name}}"},
  171. @endforeach
  172. ],
  173. type : ['商品名称','订单类型','承运商','店铺类型'],
  174. logic : ['包含','不包含','等于'],
  175. features : [],
  176. thisIndex : "",
  177. errors:{!! $errors !!},
  178. existStrategy:{default:false,starting:false},
  179. oldFeature : '',
  180. },
  181. methods:{
  182. outRuleUnique(strategy){
  183. if (strategy==='起步') this.existStrategy.starting = true;
  184. if (strategy==='默认') this.existStrategy.default = true;
  185. let startingSign = true;
  186. let defaultSign = true;
  187. this.model.rules.forEach(rule=>{
  188. if (rule.strategy == '默认')defaultSign = false;
  189. if (rule.strategy == '起步')startingSign = false;
  190. });
  191. if (startingSign)this.existStrategy.starting = false;
  192. if (defaultSign)this.existStrategy.default = false;
  193. },
  194. addRule(){
  195. this.model.rules.push({
  196. "strategy" : "",
  197. "amount" : "",
  198. "unit_id" : "",
  199. "unit_price" : "",
  200. "feature" : "",
  201. "priority" : "",
  202. });
  203. },
  204. delRule(index){
  205. this.$delete(this.model.rules,index);
  206. },
  207. showAddFeatureModal(index,feature){
  208. if (!feature){
  209. this.features = [{
  210. "strategyGroupStartSign": false,
  211. "calculation" : "",
  212. "type" : "",
  213. "id" : "", //特征ID
  214. "logic" : "", //特征逻辑
  215. "describe" : "", //特征信息
  216. "strategyGroupEndSign" : false,
  217. }];
  218. this.thisIndex = index;
  219. $("#addFeatureModal").modal("show");
  220. return;
  221. }
  222. if (this.oldFeature == feature) {
  223. this.thisIndex = index;
  224. $("#addFeatureModal").modal("show");
  225. return;
  226. }
  227. window.axios.post("{{url('maintenance/priceModel/operation/getFeatures')}}", {feature:feature})
  228. .then(res=>{
  229. if (res.data.success){
  230. this.features = res.data.data;
  231. this.oldFeature = feature;
  232. if (!this.features || this.features.length === 0){
  233. this.features = [{
  234. "strategyGroupStartSign": false,
  235. "calculation" : "",
  236. "type" : "",
  237. "id" : "", //特征ID
  238. "logic" : "", //特征逻辑
  239. "describe" : "", //特征信息
  240. "strategyGroupEndSign" : false,
  241. }];
  242. }
  243. this.thisIndex = index;
  244. $("#addFeatureModal").modal("show");
  245. return;
  246. }
  247. window.tempTip.setDuration(3000);
  248. window.tempTip.show(res.data.data);
  249. }).catch(err=>{
  250. window.tempTip.setDuration(3000);
  251. window.tempTip.show("网络错误:"+err);
  252. });
  253. },
  254. addFeature(){
  255. this.features.push({
  256. "strategyGroupStartSign": false,
  257. "calculation" : "",
  258. "type" : "",
  259. "id" : "", //特征ID
  260. "logic" : "", //特征逻辑
  261. "describe" : "", //特征信息
  262. "strategyGroupEndSign" : false,
  263. });
  264. },
  265. delFeature(index) {
  266. this.$delete(this.features,index);
  267. },
  268. submitFeature(){
  269. window.axios.post("{{url('maintenance/priceModel/operation/getFeature')}}",
  270. {features:this.features})
  271. .then(res=>{
  272. if (res.data.success){
  273. if (this.thisIndex == '-1') this.model.feature = res.data.data;
  274. else this.model.rules[this.thisIndex].feature = res.data.data;
  275. $("#addFeatureModal").modal("hide");
  276. window.tempTip.setDuration(2000);
  277. window.tempTip.setIndex(1099);
  278. window.tempTip.showSuccess("已更新特征");
  279. return;
  280. }
  281. window.tempTip.setDuration(3000);
  282. window.tempTip.setIndex(1099);
  283. window.tempTip.show(res.data.data);
  284. }).catch(err=>{
  285. window.tempTip.setDuration(3000);
  286. window.tempTip.setIndex(1099);
  287. window.tempTip.show("网络错误:"+err);
  288. });
  289. },
  290. },
  291. });
  292. </script>
  293. @stop