create.blade.php 20 KB

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