show.blade.php 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718
  1. @extends('layouts.app')
  2. @section('title')任务-盘收一体@endsection
  3. @section('content')
  4. <div id="container" class="d-none container-fluid">
  5. @include('store.checkingReceive._modal')
  6. @can('入库管理-盘收一体-盘收-编辑')
  7. <div class="row m-2 card" v-if="is_show">
  8. <audio src="{{asset('sound/warning_otherBarcode.mp3')}}" controls="controls" preload id="soundWarning" hidden>
  9. </audio>
  10. <audio src="{{asset('sound/ding.mp3')}}" controls="controls" preload id="soundDing" hidden>
  11. </audio>
  12. <div class="card-body col-12">
  13. <div class="col-12">
  14. <p class="text-muted small" v-if="inputMode=='regular'">常规:可输入效期,相同条码记录不会合并</p>
  15. <p class="text-muted small" v-if="inputMode=='increasing'">逐一扫描:处理单一重复商品,每扫一次对应隔口总数量自动递增,扫到不同条码会提示</p>
  16. <p class="text-muted small" v-if="inputMode=='multiIncreasing'">边扫边分:处理多种商品,自动将扫到的不同条码数量递增到各自隔口号</p>
  17. <ul class="nav nav-tabs mb-4 mt-n3">
  18. <li class="nav-item"><a style="cursor: pointer" class="nav-link text-primary" :class="inputMode=='regular'?'active':''"
  19. @click="switchMenu('regular')">常规</a></li>
  20. <li class="nav-item"><a style="cursor: pointer" class="nav-link text-primary" :class="inputMode=='increasing'?'active':''"
  21. @click="switchMenu('increasing')">逐一扫描</a></li>
  22. <li class="nav-item"><a style="cursor: pointer" class="nav-link text-primary" :class="inputMode=='multiIncreasing'?'active':''"
  23. @click="switchMenu('multiIncreasing')">边扫边分</a></li>
  24. </ul>
  25. </div>
  26. <div class="col-12 row">
  27. <div class="col-6">
  28. <div v-if="inputMode=='regular'">
  29. <div class="btn btn-sm btn-outline-primary" v-if="status.barcodeDisable" @click="status.barcodeDisable=false">手动输入</div>
  30. <div class="btn btn-sm btn-outline-danger" v-if="!status.barcodeDisable" @click="status.barcodeDisable=true">扫描输入</div>
  31. </div>
  32. <input type="text" id="barcode" class="form-control" @blur="showCommitButton()"
  33. :placeholder="status.barcodeDisable ? '扫入条码' : '输入条码'" :disabled="status.barcodeDisable" v-model="inputting.barcode" :class="inputMode=='regular' ? '' : 'mt-4'"
  34. @focusin="focusOutDocument" @focusout="focusDocument">
  35. <div v-if="inputMode=='regular'">
  36. <div class="card-title">生产日期:</div>
  37. <input type="date" class="form-control mb-2"
  38. v-model="inputting.produce_date" @focusin="focusOutDocument" @focusout="focusDocument" @keyup="oninputEnter">
  39. <div class="card-title">失效日期:</div>
  40. <input type="date" class="form-control mb-2"
  41. v-model="inputting.valid_date" @focusin="focusOutDocument" @focusout="focusDocument" @keyup="oninputEnter">
  42. <div class="card-title">唯一码:</div>
  43. <input type="text" class="form-control mb-2"
  44. v-model="inputting.unique_code" @focusin="focusOutDocument" @focusout="focusDocument" @keyup="oninputEnter">
  45. </div>
  46. </div>
  47. <div class="col-6">
  48. <div class="card-title" id="amountLabel">输入数量:</div>
  49. <div class="input-group mt-n2 mb-2">
  50. <input type="number" id="amount" style='height: 40px;font-size: 1.6em;color:blue;font-weight: bolder;padding: 3px;text-align: center' class="form-control" placeholder="" @blur="showCommitButton()"
  51. :disabled="status.amountDisable" v-model="inputting.amount" @focusin="focusOutDocument" @focusout="focusDocument" @keyup="oninputEnter">
  52. </div>
  53. <div class="card-title">格口号:</div>
  54. <input type="number" id="bin_number" class="form-control mt-n2 mb-2" style='height: 100px;font-size: 5em;color:red;font-weight: bolder;padding: 3px;text-align: center'
  55. v-model="inputting.bin_number" :disabled="status.binDisable" @focusin="focusOutDocument" @focusout="focusDocument" @keyup="oninputEnter">
  56. <div v-if="inputMode=='regular'" class="mt-4">
  57. <div class="card-title">批次号:</div>
  58. <input type="text" class="form-control mb-2"
  59. v-model="inputting.batch_number" @focusin="focusOutDocument" @focusout="focusDocument" @keyup="oninputEnter">
  60. </div>
  61. </div>
  62. <div class="col-12" v-if="status.commitButtonVisible && inputMode=='regular'" >
  63. <button class="btn btn-success btn form-control" @click="commitGoods">确定</button>
  64. </div>
  65. </div>
  66. </div>
  67. </div>
  68. @endcan
  69. <div class="ml-2 mt-2">
  70. <button type="button" class="btn btn-sm btn-outline-dark" @click="exportItem()">导出</button>
  71. @can('入库管理-盘收一体-盘收-编辑')<button type="button" v-if="storeCheckingReceive.status != '已收货'" class="btn btn-sm btn-outline-danger" @click="isResetAmount()">重新清点</button>@endcan
  72. @can('入库管理-盘收一体-盘收-编辑')<button type="button" v-if="storeCheckingReceive.status != '已收货'" class="btn btn-sm btn-outline-success" data-toggle="modal" data-target="#asnWindow">匹配ASN单据</button>@endcan
  73. </div>
  74. <div class="row text-primary ml-1 mr-2 mt-1 mb-1 w-100" style="background-color: #c3e3b5">
  75. <span class="ml-md-1">任务ID: <b class="text-dark">@{{ storeCheckingReceive.id }}</b></span>
  76. <span class="ml-md-3"> &nbsp;货主: <b class="text-dark">@{{ storeCheckingReceive.owner_name }}</b></span>
  77. <span class="ml-md-3">创建时间: <b class="text-dark">@{{ storeCheckingReceive.created_at }}</b></span>
  78. <span class="ml-md-3">ASN号: <b class="text-dark">@{{ storeCheckingReceive.asn }}</b></span>
  79. </div>
  80. <!-- pc >544 -->
  81. <div class="d-none d-sm-block">
  82. <table class="table table-striped table-sm text-nowrap table-hover mt-1 td-min-width-80" id="table">
  83. <tr v-for="(storeCheckingReceiveItem,i) in storeCheckingReceiveItems" @click="selectedColor(storeCheckingReceiveItem.id)" :class="selectTr==storeCheckingReceiveItem.id ? 'focusing' : ''">
  84. <td><span>@{{ i+1 }}</span></td>
  85. <td><span>@{{ storeCheckingReceiveItem.bin_number }}</span></td>
  86. <td><span>@{{ storeCheckingReceiveItem.commodity_name }}</span></td>
  87. <td>
  88. <span v-for="commodity_barcode in storeCheckingReceiveItem.commodity_barcodes">
  89. <small>@{{ commodity_barcode.code }}</small><br>
  90. </span>
  91. </td>
  92. <td><span>@{{ storeCheckingReceiveItem.imported_amount }}</span></td>
  93. <td @click="showInput(storeCheckingReceiveItem.id)" v-if="is_show">
  94. <div class="form-inline">
  95. <input @focus="showInput(storeCheckingReceiveItem.id)" @blur="delFocus()" :id = "'counted_amount_'+storeCheckingReceiveItem.id" :value="storeCheckingReceiveItem.counted_amount"
  96. class="form-control form-control-sm" type="number" :disabled="disabledItemId == storeCheckingReceiveItem.id ? false : true">
  97. <button v-if="disabledItemId == storeCheckingReceiveItem.id" type="button" class="btn btn-sm btn-success ml-1"
  98. @click="updateCountedAmount(storeCheckingReceiveItem)">确定</button>
  99. <button v-if="disabledItemId == storeCheckingReceiveItem.id" type="button" class="btn btn-sm btn-danger"
  100. @click.stop="disabledItemId = ''">取消</button>
  101. </div>
  102. </td>
  103. <td v-if="!is_show"><span>@{{ storeCheckingReceiveItem.counted_amount }}</span></td>
  104. <td><span>@{{ storeCheckingReceiveItem.asn_amount }}</span></td>
  105. <td><span>@{{ storeCheckingReceiveItem.imported_diff_amount }}</span></td>
  106. <td><span>@{{ storeCheckingReceiveItem.asn_diff_amount }}</span></td>
  107. <td><span>@{{ storeCheckingReceiveItem.produced_at }}</span></td>
  108. <td><span>@{{ storeCheckingReceiveItem.invalid_at }}</span></td>
  109. <td><span>@{{ storeCheckingReceiveItem.batch_code }}</span></td>
  110. <td><span>@{{ storeCheckingReceiveItem.unique_code }}</span></td>
  111. <td></td>
  112. </tr>
  113. </table>
  114. </div>
  115. <!-- phone <544 -->
  116. <div class="d-xl-none">
  117. <div v-for="(storeCheckingReceiveItem,i) in storeCheckingReceiveItems" class="mt-1 border border-1 rounded"
  118. @click="openAll(storeCheckingReceiveItem.id)">
  119. <div class="row">
  120. <div class="col-6">
  121. <label class="text-muted">序号:</label>@{{ i+1 }}
  122. </div>
  123. <div class="col-6">
  124. <span class="pull-right mr-1 text-primary font-weight-bold small">点击展开</span>
  125. </div>
  126. </div>
  127. <div class="row">
  128. <div class="col-12 row">
  129. <label class="text-primary col-3 mr-0">条码:</label>
  130. <div class="col-9 ml-0">
  131. <span v-for="commodity_barcode in storeCheckingReceiveItem.commodity_barcodes">
  132. <small>@{{ commodity_barcode.code }}</small><br>
  133. </span>
  134. </div>
  135. </div>
  136. </div>
  137. <div class="row">
  138. <div class="col-12 form-inline">
  139. <label class="text-muted w-25">名称:</label><div class="w-75">@{{ storeCheckingReceiveItem.commodity_name }}</div>
  140. </div>
  141. </div>
  142. <div class="row">
  143. <div class="col-6">
  144. <label class="text-muted">格口号:</label>@{{ storeCheckingReceiveItem.bin_number }}
  145. </div>
  146. <div class="col-6">
  147. <label class="text-muted">实盘数:</label>@{{ storeCheckingReceiveItem.counted_amount }}
  148. </div>
  149. </div>
  150. <div class="row">
  151. <div class="col-6">
  152. <label class="text-muted">导入差异:</label><small class="text-danger font-weight-bold">@{{ storeCheckingReceiveItem.imported_diff_amount }}</small>
  153. </div>
  154. <div class="col-6">
  155. <label class="text-muted">ASN差异:</label><small class="text-danger font-weight-bold">@{{ storeCheckingReceiveItem.asn_amount }}</small>
  156. </div>
  157. </div>
  158. <div :id="'detail_'+storeCheckingReceiveItem.id" class="up">
  159. <div class="row">
  160. <div class="col-6">
  161. <label class="text-muted">导入数:</label>@{{ storeCheckingReceiveItem.imported_amount }}
  162. </div>
  163. <div class="col-6">
  164. <label class="text-muted">ASN数:</label>@{{ storeCheckingReceiveItem.asn_amount }}
  165. </div>
  166. </div>
  167. <div class="row">
  168. <div class="col-6">
  169. <label class="text-muted">生产日期:</label>@{{ storeCheckingReceiveItem.produced_at }}
  170. </div>
  171. <div class="col-6">
  172. <label class="text-muted">有效日期:</label>@{{ storeCheckingReceiveItem.invalid_at }}
  173. </div>
  174. </div>
  175. <div class="row">
  176. <div class="col-6">
  177. <label class="text-muted">唯一号码:</label>@{{ storeCheckingReceiveItem.unique_code }}
  178. </div>
  179. <div class="col-6">
  180. <label class="text-muted">批次号码:</label>@{{ storeCheckingReceiveItem.batch_code }}
  181. </div>
  182. </div>
  183. <div class="row">
  184. <div class="col-10 offset-1">
  185. @can('入库管理-盘收一体-盘收-编辑')<button @click.stop="destroyItem(storeCheckingReceiveItem,i)" class="btn btn-sm btn-outline-danger w-100">删除</button>@endcan
  186. </div>
  187. </div>
  188. </div>
  189. </div>
  190. </div>
  191. </div>
  192. @stop
  193. @section('lastScript')
  194. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版2--}}
  195. <script>
  196. new Vue({
  197. el:"#container",
  198. data:{
  199. storeCheckingReceive:{id:'{{$storeCheckingReceive->id}}',
  200. owner_id:'{{$storeCheckingReceive->owner_id}}',
  201. owner_name:'{{$storeCheckingReceive->owner ? $storeCheckingReceive->owner->name : ''}}',
  202. created_at:'{{$storeCheckingReceive->created_at}}',asn:'{{$storeCheckingReceive->asn}}',status:'{{$storeCheckingReceive->status}}'},
  203. storeCheckingReceiveItems:[
  204. @foreach($storeCheckingReceive->storeCheckingReceiveItems as $storeCheckingReceiveItem)
  205. {id:'{{$storeCheckingReceiveItem->id}}',bin_number:'{{$storeCheckingReceiveItem->bin_number}}',
  206. commodity_name:"{{$storeCheckingReceiveItem->commodity ? $storeCheckingReceiveItem->commodity->name : ''}}",
  207. commodity_barcodes:{!! $storeCheckingReceiveItem->commodity ? ($storeCheckingReceiveItem->commodity->barcodes ? $storeCheckingReceiveItem->commodity->barcodes : json_encode([])) : json_encode([]) !!},
  208. imported_amount:'{{$storeCheckingReceiveItem->imported_amount}}',counted_amount:'{{$storeCheckingReceiveItem->counted_amount}}',
  209. asn_amount:'{{$storeCheckingReceiveItem->asn_amount}}',imported_diff_amount:'{{$storeCheckingReceiveItem->imported_diff_amount}}',
  210. asn_diff_amount:'{{$storeCheckingReceiveItem->asn_diff_amount}}',produced_at:'{{$storeCheckingReceiveItem->produced_at}}',
  211. invalid_at:'{{$storeCheckingReceiveItem->invalid_at}}',batch_code:'{{$storeCheckingReceiveItem->batch_code}}',
  212. unique_code:'{{$storeCheckingReceiveItem->unique_code}}'},
  213. @endforeach
  214. ],
  215. inputMode : 'regular',
  216. status:{
  217. barcodeDisable : true,
  218. commitButtonVisible:false,
  219. scanEndInputted:false,
  220. amountDisable : false,
  221. binDisable : false,
  222. },
  223. focusing : 'document',
  224. inputting:{
  225. barcode : '',
  226. amount : '',
  227. bin_number : '',
  228. batch_number : '',
  229. produce_date : '',
  230. valid_date : '',
  231. unique_code:'',
  232. },
  233. lastScannedBarcode : '',
  234. asn : '',
  235. is_show : {!! $is_show !!},
  236. disabledItemId : "",
  237. upId:"",
  238. selectTr:''
  239. },
  240. mounted(){
  241. $(".up").slideUp();
  242. $('#container').removeClass('d-none');
  243. $(".tooltipTarget").tooltip({'trigger':'hover'});
  244. let column = [
  245. {name:'index',value: '序号', neglect: true},
  246. {name:'bin_number',value: '格口号'},
  247. {name:'commodity_name',value: '商品名'},
  248. {name:'commodity_barcode',value: '商品条码'},
  249. {name:'imported_amount',value: '导入数量', neglect: true},
  250. {name:'counted_amount',value: '实盘数量', neglect: true},
  251. {name:'asn_amount',value: 'ASN数量', neglect: true},
  252. {name:'imported_diff_amount',value: '导入差异数', neglect: true},
  253. {name:'asn_diff_amount',value: 'ASN差异数', neglect: true},
  254. {name:'produced_at',value: '生产日期'},
  255. {name:'invalid_at',value: '有效期'},
  256. {name:'batch_code',value: '批次号'},
  257. {name:'unique_code',value: '唯一码'},
  258. {name:'operating',value: '操作', neglect: true},
  259. ];
  260. new Header({
  261. el: "table",
  262. name: "checkingReceive",
  263. column: column,
  264. data: this.storeCheckingReceiveItems,
  265. }).init();
  266. this.scanListening();
  267. },
  268. methods:{
  269. selectedColor(id){
  270. this.selectTr=id;
  271. },
  272. //显示该条全部信息
  273. openAll(id){
  274. if (this.upId == id) {$("#detail_"+id).slideUp(); this.upId = ''}
  275. else {
  276. this.upId = id;
  277. $("#detail_"+id).slideDown();
  278. }
  279. },
  280. //获取焦点,取消全局监听
  281. showInput(id){
  282. if (this.disabledItemId === id)return;
  283. this.focusing = "";
  284. document.getElementById('counted_amount_'+id).focus();
  285. this.disabledItemId = id;
  286. },
  287. //实盘数量输出框失焦
  288. delFocus(){
  289. this.focusDocument();
  290. },
  291. //执行修改
  292. updateCountedAmount(item){
  293. let counted_amount = document.getElementById('counted_amount_'+item.id).value;
  294. if(!counted_amount || parseInt(counted_amount) != counted_amount){
  295. tempTip.setDuration(3000);
  296. tempTip.show('请输入正整数!');
  297. return;
  298. }
  299. axios.post('{{url('store/checkingReceive/updateCountedAmount')}}',{id : item.id,counted_amount : counted_amount})
  300. .then((res)=>{
  301. if (res.data.success){
  302. item.counted_amount = counted_amount;
  303. item.imported_diff_amount = res.data.data.imported_diff_amount;
  304. item.asn_diff_amount = res.data.data.asn_diff_amount;
  305. this.disabledItemId = "";
  306. tempTip.setDuration(2000);
  307. tempTip.showSuccess("实盘数量成功修改为“"+counted_amount+"”");
  308. return;
  309. }
  310. tempTip.setDuration(3000);
  311. tempTip.show(res.data.data);
  312. })
  313. .catch((err)=>{
  314. tempTip.setDuration(3000);
  315. tempTip.show('网络错误:'+err);
  316. });
  317. },
  318. switchMenu(menuName){
  319. this.inputMode = menuName;
  320. this.cleanInputs();
  321. if (menuName === 'regular') {
  322. this.status.amountDisable = false;
  323. $('#amountLabel').text('输入数量:');
  324. }else {
  325. this.status.amountDisable = true;
  326. $('#amountLabel').text('扫入数量:');
  327. }
  328. },
  329. scanListening: function () {
  330. let _this = this;
  331. $(document).on('keypress', function (e) {
  332. if (!status.barcodeDisable && !_this.focusing && e.keyCode===13 && !_this.inputting.amount){
  333. document.getElementById('amount').focus();
  334. return;
  335. }
  336. if(_this.focusing!=='document'){return}
  337. if(!_this.status.barcodeDisable){return}
  338. if (e.keyCode !== 13) {
  339. if(_this.status.scanEndInputted){
  340. _this.inputting.barcode='';
  341. _this.status.scanEndInputted=false;
  342. }
  343. _this.inputting.barcode += String.fromCharCode(e.keyCode);
  344. } else {
  345. if(_this.inputting.barcode.length<=1){
  346. window.tempTip.setDuration(4500);
  347. window.tempTip.show('未扫入条码,请检查扫码枪设置,尝试调至“直接键盘输出”模式');
  348. return;
  349. }
  350. _this.status.scanEndInputted = true;
  351. switch(_this.inputMode){
  352. case 'regular' : _this.commitGoodsOnRegularMode();break;
  353. case 'increasing': _this.commitGoodsOnIncreasingMode();break;
  354. case 'multiIncreasing': _this.commitGoodsOnIncreasingMode(false);break;
  355. }
  356. }
  357. });
  358. },
  359. showCommitButton: function () {
  360. if(this.inputting.barcode && this.inputting.amount /*&& this.inputting.bin_number*/){
  361. if (this.status.commitButtonVisible){
  362. this.commitGoods();
  363. }else this.status.commitButtonVisible=true;
  364. }else{
  365. if (this.status.barcodeDisable){
  366. this.focusing = '';
  367. document.getElementById('amount').focus();
  368. }
  369. }
  370. },
  371. _isExist(item){
  372. if (item.bin_number == this.inputting.bin_number
  373. && item.batch_code == this.inputting.batch_number
  374. && item.produced_at == this.inputting.produce_date
  375. && item.unique_code == this.inputting.unique_code
  376. && item.invalid_at == this.inputting.valid_date){
  377. return true;
  378. }
  379. return false;
  380. },
  381. commitGoods: function () {
  382. window.tempTip.setDuration(3000);
  383. if (this.inputMode === 'regular'){
  384. if (!this.inputting.amount) {window.tempTip.show('请输入数量');return;}
  385. let item = this.getItem();
  386. if (item){
  387. if (item.produced_at && !this.inputting.produce_date){window.tempTip.show('请输入生产日期');return;}
  388. if (item.invalid_at && !this.inputting.valid_date){window.tempTip.show('请输入失效日期');return;}
  389. if (item.batch_code && !this.inputting.batch_number){window.tempTip.show('请输入批次号');return;}
  390. if (this._isExist(item)){
  391. if (!confirm('该单盘点已存在是否叠加数量?'))return;
  392. }
  393. }
  394. }
  395. if(!this.inputting.barcode){window.tempTip.show('请扫入条码');return;}
  396. else if(!this.inputting.bin_number){window.tempTip.show('请输入隔口号');return;}
  397. window.axios.post('{{url('maintenance/commodity/isExist')}}',{owner_id:this.storeCheckingReceive.owner_id,barcode:this.inputting.barcode})
  398. .then(res=>{
  399. if (res.data.success) exe();
  400. else{
  401. window.tempTip.confirm("商品信息不存在,是否录入为新商品",function () {
  402. exe();
  403. });
  404. }
  405. }).catch(err=>{
  406. window.tempTip.setDuration(3000);
  407. window.tempTip.show("网络错误:"+err);
  408. });
  409. let _this = this;
  410. function exe(){
  411. axios.post('{{url('store/checkingReceive/insertItem')}}',{mission_id : _this.storeCheckingReceive.id,goods : _this.inputting})
  412. .then(res=>{
  413. if (res.data.success) {
  414. _this.lastScannedBarcode = _this.inputting.barcode;
  415. if (res.data.type === 'create'){
  416. _this._addStoreCheckingReceiveItem(res.data.data);
  417. window.tempTip.setDuration(2000);
  418. window.tempTip.showSuccess('成功提交:' + _this.inputting.barcode);
  419. }else{
  420. if (_this.storeCheckingReceiveItems.length > 0 && res.data.data.id === _this.storeCheckingReceiveItems[0].id){
  421. _this.storeCheckingReceiveItems[0].counted_amount = res.data.data.counted_amount;
  422. _this.storeCheckingReceiveItems[0].imported_diff_amount = res.data.data.imported_diff_amount;
  423. _this.storeCheckingReceiveItems[0].asn_diff_amount = res.data.data.asn_diff_amount;
  424. _this.storeCheckingReceiveItems[0].bin_number = res.data.data.bin_number;
  425. }else{
  426. _this._removeCheckingReceiveItem(res.data.data.id);
  427. _this._addStoreCheckingReceiveItem(res.data.data);
  428. }
  429. _this.inputting.amount = res.data.data.counted_amount;
  430. window.tempTip.setDuration(2000);
  431. window.tempTip.showSuccess('成功增加“'+_this.inputting.barcode+'”实盘数量')
  432. }
  433. if (_this.status.commitButtonVisible) _this.status.commitButtonVisible=false;
  434. _this.audioDing();
  435. if (_this.inputMode === 'regular')_this.cleanInputs();
  436. if (_this.inputting.bin_number && !_this.status.binDisable)_this.status.binDisable = true;
  437. return;
  438. }
  439. window.tempTip.setDuration(3000);
  440. window.tempTip.show(res.data.data);
  441. }).catch(err=>{
  442. window.tempTip.setDuration(3000);
  443. window.tempTip.show("网络错误:"+err);
  444. });
  445. }
  446. },
  447. _addStoreCheckingReceiveItem(item){
  448. let storeCheckingReceiveItem = {
  449. id:item.id,
  450. bin_number:item.bin_number,
  451. commodity_name:item.commodity ? item.commodity.name : '',
  452. commodity_barcodes:item.commodity ? item.commodity.barcodes : [],
  453. imported_amount:item.imported_amount,
  454. counted_amount:item.counted_amount,
  455. asn_amount:item.asn_amount,
  456. imported_diff_amount:item.imported_diff_amount,
  457. asn_diff_amount:item.asn_diff_amount,
  458. produced_at:item.produced_at,
  459. invalid_at:item.invalid_at,
  460. batch_code:item.batch_code,
  461. unique_code:item.unique_code,
  462. };
  463. this.storeCheckingReceiveItems.unshift(storeCheckingReceiveItem);
  464. },
  465. _removeCheckingReceiveItem(id){
  466. this.storeCheckingReceiveItems.some((item,index)=>{
  467. if (item.id == id){
  468. this.storeCheckingReceiveItems.splice(index,1);
  469. return true;
  470. }
  471. });
  472. },
  473. cleanInputs: function () {
  474. this.inputting.barcode='';
  475. this.inputting.amount='';
  476. this.inputting.bin_number='';
  477. this.inputting.produce_date='';
  478. this.inputting.unique_code='';
  479. this.inputting.valid_date='';
  480. this.inputting.batch_number='';
  481. this.status.commitButtonVisible=false;
  482. this.status.binDisable=false;
  483. this.status.barcodeDisable = true;
  484. },
  485. autoFillBin: function () {
  486. let isNotRepeatingBarcode=this.storeCheckingReceiveItems.every(item=>{
  487. if (item.commodity_barcodes.length > 0){
  488. return item.commodity_barcodes.every(barcode=> {
  489. if (barcode.code === this.inputting.barcode){
  490. if (item.bin_number){
  491. this.inputting.bin_number=item.bin_number;
  492. this.status.binDisable=true;
  493. }
  494. return false;
  495. }
  496. return true;
  497. });
  498. }else return true;
  499. });
  500. if(isNotRepeatingBarcode) this.status.binDisable=false;
  501. },
  502. commitGoodsOnRegularMode(){
  503. this.showCommitButton();
  504. },
  505. commitGoodsOnIncreasingMode: function (signIncreasing = true) {
  506. let item = this.getItem();
  507. let _this = this;
  508. if (!item){
  509. _this.focusOutDocument();
  510. window.tempTip.setInputType('number');
  511. window.tempTip.inputVal('该商品第一件递增请输入隔口号:', function (bin_number) {
  512. if (bin_number === '') {
  513. window.tempTip.setDuration(2200);
  514. window.tempTip.show('未输入隔口号,请重新扫描');
  515. _this.alertVibrate();
  516. _this.focusDocument();
  517. return;
  518. }
  519. _this.inputting.bin_number = bin_number;
  520. _this.inputting.amount = 1;
  521. _this.commitGoods();
  522. _this.focusDocument();
  523. });
  524. return;
  525. }
  526. _this.status.binDisable=true;
  527. if (item.bin_number) {
  528. _this.inputting.bin_number = item.bin_number;
  529. _this.commit(item, signIncreasing);
  530. }else{
  531. _this.lastScannedBarcode = _this.inputting.barcode;
  532. _this.focusOutDocument();
  533. window.tempTip.setInputType('number');
  534. window.tempTip.inputVal('该条码存在但无隔口号,请输入:', function (bin_number) {
  535. if (bin_number === '') {
  536. window.tempTip.setDuration(2200);
  537. window.tempTip.show('未输入隔口号,请重新扫描');
  538. _this.alertVibrate();
  539. _this.focusDocument();
  540. return;
  541. }
  542. _this.inputting.bin_number = bin_number;
  543. _this.commit(item, signIncreasing);
  544. });
  545. }
  546. },
  547. commit(item, signIncreasing){
  548. this.inputting.amount = '';
  549. this.inputting.produce_date=item.produced_at;
  550. this.inputting.unique_code=item.unique_code;
  551. this.inputting.valid_date=item.invalid_at;
  552. this.inputting.batch_number=item.batch_code;
  553. if (signIncreasing && this.lastScannedBarcode && this.lastScannedBarcode !== this.inputting.barcode) {
  554. this.audioWarning_otherBarcode();
  555. this.focusOutDocument();
  556. window.tempTip.confirm('扫到其它条码,是否切换至新条码并记录?', ()=>{
  557. this.commitGoods();
  558. this.focusDocument();
  559. }, () => {
  560. this.focusDocument();
  561. });
  562. }else{
  563. this.commitGoods();
  564. this.focusDocument();
  565. }
  566. },
  567. getItem: function () {
  568. let repeatedGoods=null;
  569. this.storeCheckingReceiveItems.every(item=>{
  570. if (item.commodity_barcodes.length > 0){
  571. return item.commodity_barcodes.every(barcode=> {
  572. if (barcode.code === this.inputting.barcode){
  573. repeatedGoods = item;
  574. return false;
  575. }
  576. return true;
  577. });
  578. }else return true;
  579. });
  580. return repeatedGoods;
  581. },
  582. oninputEnter:function(e){
  583. if (e.key === 'Enter') {
  584. this.focusDocument();
  585. this.showCommitButton();
  586. }
  587. },
  588. focusDocument: function () {
  589. this.focusing = 'document';
  590. },
  591. focusOutDocument: function () {
  592. this.focusing = '';
  593. this.autoFillBin();
  594. },
  595. audioWarning_otherBarcode: function () {
  596. let audio = document.getElementById('soundWarning');
  597. audio.currentTime = 0;//重新播放
  598. if(audio.paused){
  599. audio.play();// 播放
  600. }
  601. this.alertVibrate();
  602. },
  603. audioDing: function () {
  604. let audio = document.getElementById('soundDing');
  605. audio.currentTime = 0;//重新播放
  606. audio.play();// 播放
  607. //手机震动
  608. function startVibrate(duration) {
  609. if (navigator.vibrate) {
  610. navigator.vibrate(duration);
  611. } else if (navigator.webkitVibrate) {
  612. navigator.webkitVibrate(duration);
  613. }
  614. }
  615. startVibrate(500);
  616. },
  617. alertVibrate: function () {
  618. function startVibrate(duration) {
  619. if (navigator.vibrate) {
  620. navigator.vibrate(duration);
  621. } else if (navigator.webkitVibrate) {
  622. navigator.webkitVibrate(duration);
  623. }
  624. }
  625. let vibrateInterval = setInterval(function() {
  626. startVibrate(150);
  627. }, 50);
  628. setTimeout(function() {
  629. clearInterval(vibrateInterval)
  630. }, 2000);
  631. },
  632. exportItem(){
  633. let url = '{{url('store/checkingReceive/mission/export?mission_id=')}}'+this.storeCheckingReceive.id;
  634. window.open(url);
  635. },
  636. isResetAmount(){
  637. window.tempTip.confirm('是否要进行重新清点,该操作会重置当前任务所有已盘数量!',()=>{
  638. this.resetAmount();
  639. });
  640. },
  641. resetAmount(){
  642. axios.post('{{url('store/checkingReceive/mission/resetAmount')}}',{mission_id:this.storeCheckingReceive.id})
  643. .then(res=>{
  644. if (res.data.success){
  645. this.storeCheckingReceiveItems.forEach(function (item) {
  646. item.counted_amount = 0;
  647. item.imported_diff_amount = '';
  648. item.asn_diff_amount = '';
  649. item.bin_number = '';
  650. });
  651. window.tempTip.setDuration(2000);
  652. window.tempTip.showSuccess('重新清点完毕,数量已重置为0');
  653. return;
  654. }
  655. window.tempTip.setDuration(3000);
  656. window.tempTip.show(res.data.data);
  657. }).catch(err=>{
  658. window.tempTip.setDuration(3000);
  659. window.tempTip.show("网络错误:"+err);
  660. });
  661. },
  662. matchASN(){
  663. if (!this.asn){
  664. window.tempTip.setIndex(1099);
  665. window.tempTip.setDuration(3000);
  666. window.tempTip.show('请输入ASN号!');
  667. return;
  668. }
  669. axios.post('{{url('store/checkingReceive/mission/matchASN')}}',{asn:this.asn,mission_id:this.storeCheckingReceive.id})
  670. .then(res=>{
  671. if (res.data.success){
  672. window.tempTip.setIndex(1099);
  673. window.tempTip.setDuration(2000);
  674. window.tempTip.showSuccess("匹配成功");
  675. location.reload();
  676. return;
  677. }
  678. window.tempTip.setIndex(1099);
  679. window.tempTip.setDuration(3000);
  680. window.tempTip.show(res.data.data);
  681. }).catch(err=>{
  682. window.tempTip.setIndex(1099);
  683. window.tempTip.setDuration(3000);
  684. window.tempTip.show("网络错误:"+err);
  685. });
  686. },
  687. destroyItem(item,index){
  688. let url = "{{url("store/checkingReceive/destroyItem")}}";
  689. let param = {id:item.id};
  690. window.tempTip.confirm("确定要删除商品“"+item.commodity_name+"”的盘点吗?",()=>{
  691. window.axios.post(url,param).then((res)=>{
  692. if (res.data.success){
  693. this.$delete(this.storeCheckingReceiveItems,index);
  694. window.tempTip.setDuration(2000);
  695. window.tempTip.showSuccess("删除成功");
  696. return;
  697. }
  698. window.tempTip.setDuration(3000);
  699. window.tempTip.show(res.data.data);
  700. }).catch(err=>{
  701. window.tempTip.setDuration(3000);
  702. window.tempTip.show("网络错误:"+err);
  703. })
  704. });
  705. }
  706. },
  707. });
  708. </script>
  709. @stop