statistics.blade.php 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469
  1. @extends('layouts.app')
  2. @section('title')统计@endsection
  3. @section('content')
  4. <span id="nav2">
  5. @component('weight.menu')@endcomponent
  6. </span>
  7. <div class="d-none" id="statistics">
  8. <div class="container-fluid">
  9. <div class="">
  10. <form method="GET" action="{{url('package/statistics')}}" id="optionSubmit">
  11. <table class="table table-sm table-bordered text-nowrap mb-0">
  12. <tr v-if="isBeingFilterConditions">
  13. <td colspan="10"><div class="col" style="padding:0">
  14. <a href="{{url('package/statistics')}}"><span class="btn btn-warning text-dark">清除筛选</span></a>
  15. </div></td>
  16. </tr>
  17. <tr >
  18. <td>
  19. <div class="form-inline pl-3" style="height: 100px">
  20. <div class="align-items-center">
  21. <div class="text-right form-inline">货主:
  22. <input type="text" style="width: 100px;opacity: 0.6" class="form-control form-control-sm tooltipTarget" placeholder="定位货主"
  23. @input="owner_seek"
  24. title="输入关键词快速定位下拉列表"></div>
  25. </div>
  26. <div style="max-height: 90px; overflow-y: scroll;border: solid 1px #ddd;border-radius:5px;opacity:0.5;text-align: center;transform:scale(0.9)" v-if="ownersCopy.length>0">
  27. <ul class="list-group tooltipTarget" id="seek" onselectstart="return false;">
  28. <li title="单击添加货主" v-for="ownerCopy in ownersCopy" :id="ownerCopy.name" class="list-group-item list-group-item-action pt-0 pb-0"
  29. @click="selectedOwner(ownerCopy)" :class="ownerCopy.style ? 'active' :''"><span style="cursor: default;" :id="ownerCopy.name">@{{ ownerCopy.name }}</span></li>
  30. </ul>
  31. <input hidden name="owner_id" :value="selectedOwners">
  32. </div>
  33. </div>
  34. </td>
  35. <td >
  36. <div class="form-inline pl-3" style="height: 100px">
  37. <div class="align-items-center ">
  38. <div class="text-right form-inline" >物流公司:
  39. <input type="text" style="width: 100px;opacity: 0.6" class="form-control form-control-sm tooltipTarget" placeholder="定位物流公司"
  40. @input="logistic_seek"
  41. title="输入关键词快速定位下拉列表"></div>
  42. </div>
  43. <div style="max-height: 90px;overflow-y: scroll;border: solid 1px #ddd;border-radius:5px;text-align: center;transform:scale(0.9)" v-if="logisticsAll.length>0">
  44. <ul class="list-group tooltipTarget" onselectstart="return false;">
  45. <li title="单击添加物流公司" v-for="logistic in logisticsAll" class=" list-group-item list-group-item-action pt-0 pb-0"
  46. @click="selectedLogistic(logistic)" :class="logistic.style ? 'active' :''" >
  47. <span style="cursor: default;" :id="logistic.name">@{{ logistic.name }}</span></li>
  48. </ul>
  49. <input hidden name="logistic_id" :value="selectedLogistics">
  50. </div>
  51. </div>
  52. </td>
  53. <td style="position: relative">
  54. <table class="table table-sm table-borderless">
  55. <tr>
  56. <td class="text-right" style="line-height: 60px">
  57. 时间:
  58. </td>
  59. <td>
  60. <div class="form-inline">
  61. <div class="form-group">
  62. <input style="width: 170px;transform:scale(0.8)" type="date" v-model="filterData.date_start" class="form-control" @change="makeFilterDuration">
  63. <input id="hour_input" type="text" class="form-control" placeholder="00:00" @change="makeFilterDuration" autocomplete="off"
  64. @input="hourFilter($event)" v-model="inputtingAdd_start" style="transform:scale(0.8);width: 80px"
  65. @keypress="hourFilter($event)" >
  66. <input v-if="filterData.date_start" hidden name="date_start" :value="filterData.date_start+' '+inputtingAdd_start">
  67. </div>
  68. </div>
  69. <div class="form-inline">
  70. <div class="form-group">
  71. <input style="transform:scale(0.8);width: 170px" type="date" v-model="filterData.date_end" class="form-control" @change="makeFilterDuration">
  72. <input type="text" class="form-control" placeholder="00:00" @change="makeFilterDuration" autocomplete="off"
  73. @input="hourFilter($event)" v-model="inputtingAdd_end" style="transform:scale(0.8);width:80px"
  74. @keypress="hourFilter($event)" >
  75. <input v-if="filterData.date_end" hidden name="date_end" :value="filterData.date_end+' '+inputtingAdd_end">
  76. </div>
  77. </div>
  78. </td>
  79. </tr>
  80. <tr>
  81. <td class="text-center" colspan="2">
  82. <button class="btn btn-primary btn-sm pl-5 pr-5">提交</button>
  83. </td>
  84. </tr>
  85. </table>
  86. <span class="text-muted"
  87. style="position: absolute; bottom: 48px;left:30px;transform: scale(0.65)" v-if="filterData.date_start || filterData.date_end">
  88. @{{ dateTime }}</span>
  89. </td>
  90. <td>
  91. </td>
  92. </tr>
  93. <tr></tr>
  94. <tr>
  95. <td colspan="3">
  96. <span class="dropdown">
  97. <button class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget" {{--:class="[rejectedBills_checkBoxes.length>0?'btn-dark text-light':'']"--}}
  98. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的筛选结果,将其全部记录(每一页)导出">
  99. 导出Excel
  100. </button>
  101. <div class="dropdown-menu">
  102. <a class="dropdown-item" @click="statisticExport(false)" href="javascript:">导出勾选内容</a>
  103. <a class="dropdown-item" @click="statisticExport(true)" href="javascript:">导出所有页</a>
  104. </div>
  105. </span>
  106. </td>
  107. </tr>
  108. </table>
  109. </form>
  110. <div class="">
  111. <table class="table table-striped table-sm text-nowrap table-hover">
  112. <tr>
  113. <th>
  114. <label for="all">
  115. <input id="all" type="checkbox" @click="checkAll($event)">全选
  116. </label>
  117. </th>
  118. <th>货主</th>
  119. <th>总计</th>
  120. <th v-for="logistic in logisticsAll" v-if="logistics[logistic.id]">@{{ logistic.name }}</th>
  121. </tr>
  122. <tr v-for="ownerModel in ownersModel">
  123. <td>
  124. <input class="checkItem" type="checkbox" :value="ownerModel.id" v-model="checkData">
  125. </td>
  126. <th class="text-muted">@{{ ownerModel.name }}</th>
  127. <td><p v-if="ownerModel.sum">@{{ ownerModel.sum }}</p><p v-else>0</p></td>
  128. <td class="text-muted" v-for="logistic in logisticsAll" v-if="logistics[logistic.id]"><p v-if="ownerModel.logistics[logistic.id]">@{{ ownerModel.logistics[logistic.id] }}</p>
  129. <p v-else>0</p></td>
  130. </tr>
  131. </table>
  132. </div>
  133. </div>
  134. </div>
  135. </div>
  136. @endsection
  137. @section('lastScript')
  138. <script type="text/javascript" src="{{asset('js/queryForm/export200818a.js')}}"></script>
  139. <script>
  140. new Vue({
  141. el:"#statistics",
  142. data:{
  143. packages:[
  144. @foreach($packages as $package)
  145. {owner_id:'{{$package->owner_id}}',logistic_id:'{{$package->logistic_id}}',count:'{{$package->count}}',
  146. owner_name:'',logistic_name:''},
  147. @endforeach
  148. ],
  149. owners:{
  150. @foreach($owners as $owner)
  151. '{{$owner->id}}' : "{{$owner->name}}",
  152. @endforeach
  153. },
  154. logisticsAll:[
  155. @foreach($logistics as $logistic)
  156. {id:'{{$logistic->id}}', name: '{{$logistic->name}}',style:false},
  157. @endforeach
  158. ],
  159. ownersCopy:[
  160. @foreach($owners as $owner)
  161. {id:'{{$owner->id}}',name:"{{$owner->name}}",style:false},
  162. @endforeach
  163. ],
  164. logistics:[],
  165. ownersModel:[],
  166. filterData:
  167. {date_start:'',date_end:''},
  168. selectedOwners:[],
  169. selectedLogistics:[],
  170. checkData:[],
  171. checkSign:'',
  172. inputtingAdd_start:'',
  173. inputtingAdd_end:'',
  174. dateTime:'',
  175. },
  176. computed:{
  177. isBeingFilterConditions:function(){
  178. for(let key in this.filterData){
  179. if(this.filterData[key]){
  180. return true
  181. }
  182. }
  183. if (this.selectedOwners.length>0||this.selectedLogistics.length>0){
  184. return true;
  185. }
  186. return false;
  187. },
  188. },
  189. watch:{
  190. checkData:{
  191. handler(){
  192. if (this.checkData.length === this.ownersModel.length){
  193. document.querySelector('#all').checked = true;
  194. }else {
  195. document.querySelector('#all').checked = false;
  196. }
  197. },
  198. deep:true
  199. }
  200. },
  201. mounted:function(){
  202. let _this=this;
  203. let owners=this.owners;
  204. this.packages.forEach(function (package){
  205. if (owners[package.owner_id]){
  206. package.owner_name=owners[package.owner_id];
  207. }
  208. let isEvery=true;
  209. if (_this.ownersModel) {
  210. isEvery=_this.ownersModel.every(function (ownerModel) {
  211. if (ownerModel.name==package.owner_name){
  212. ownerModel.logistics[package.logistic_id]=package.count;
  213. ownerModel.sum=parseInt(ownerModel.sum)+parseInt(package.count);
  214. return false;
  215. }
  216. return true;
  217. });
  218. }
  219. if (isEvery){
  220. let obj={};
  221. _this.logisticsAll.every(function (logistic) {
  222. if (logistic.id==package.logistic_id) {
  223. obj[package.logistic_id]=package.count;
  224. return false;
  225. }
  226. return true;
  227. });
  228. _this.ownersModel.push({'id':package.owner_id,'name':package.owner_name,'sum':package.count,'logistics':obj,});
  229. }
  230. });
  231. this.initInputs();
  232. $(".tooltipTarget").tooltip({'trigger':'hover'});
  233. $('#statistics').removeClass('d-none');
  234. this.makeFilterDuration();
  235. },
  236. methods: {
  237. makeFilterDuration(){
  238. let date=new Date();
  239. let thisDate=this.getDate(date);
  240. let startTime=this.inputtingAdd_start;
  241. let endTime=this.inputtingAdd_end;
  242. let endDate=this.filterData.date_end;
  243. let startDate=this.filterData.date_start;
  244. if (this.filterData.date_start && !this.inputtingAdd_start) startTime="00:00";
  245. if (this.filterData.date_end && !this.inputtingAdd_end) endTime="23:59";
  246. if (this.filterData.date_start && !this.filterData.date_end) endDate=thisDate;
  247. if (this.filterData.date_end && !this.filterData.date_start) startDate="2000-01-01 00:00";
  248. this.dateTime="选择区间:"+startDate+" "+startTime+" 至 "+endDate+" "+endTime;
  249. },
  250. getDate(date){
  251. let da=[
  252. date.getFullYear(),
  253. date.getMonth()+1,
  254. date.getDate(),
  255. date.getHours(),
  256. date.getMinutes(),
  257. ]
  258. return da.slice(0,3).join("-")+" "+
  259. da.slice(3).join(":");
  260. },
  261. initInputs:function(){
  262. let data=this;
  263. let uriParts =decodeURI(location.href).split("?");
  264. let isLogistic=true;
  265. if(uriParts.length>1){
  266. let params = uriParts[1].split('&');
  267. params.every(function(paramPair){
  268. let pair=paramPair.split('=');
  269. let key = pair[0], val = pair[1];
  270. $('input[name="'+key+'"]').val(val);
  271. $('select[name="'+key+'"]').val(val);
  272. if (key!='owner_id'||key!='logistic_id') {
  273. decodeURI(data.filterData[key]=val);
  274. }
  275. let str=unescape(val);
  276. let strs=new Array();
  277. strs=str.split(",");
  278. if (key=='owner_id' && val){
  279. for (let i=0;i<strs.length;i++){
  280. data.selectedOwners.push(strs[i]);
  281. data.ownersCopy.every(function (ownerCopy) {
  282. if (strs[i]==ownerCopy.id){
  283. ownerCopy.style=true;
  284. return false;
  285. }
  286. return true;
  287. });
  288. }
  289. }
  290. if (key=='logistic_id' && val){
  291. for (let i=0;i<strs.length;i++){
  292. data.selectedLogistics.push(strs[i]);
  293. data.logisticsAll.every(function (logistic) {
  294. if (strs[i]==logistic.id){
  295. logistic.style=true;
  296. return false;
  297. }
  298. return true;
  299. });
  300. }
  301. {{--URL有参数且有logistic字段 --}}
  302. let logistics=data.selectedLogistics;
  303. if (logistics.length>0){
  304. for (let i=0;i<logistics.length;i++){
  305. data.logisticsAll.every(function (logistic) {
  306. if (logistic.id==logistics[i]){
  307. data.logistics[logistic.id]=logistic.name;
  308. return false;
  309. }
  310. return true;
  311. });
  312. }
  313. }else{
  314. data.logisticsAll.every(function (logistic) {
  315. data.logistics[logistic.id]=logistic.name;
  316. return true;
  317. });
  318. };
  319. isLogistic=false;
  320. }
  321. if (key=='date_start'){
  322. strs=str.split("+");
  323. if (strs.length!=2) return;
  324. data.filterData.date_start=strs[0];
  325. data.inputtingAdd_start=strs[1];
  326. }
  327. if (key=='date_end'){
  328. strs=str.split("+");
  329. if (strs.length!=2) return;
  330. data.filterData.date_end=strs[0];
  331. data.inputtingAdd_end=strs[1];
  332. }
  333. return true;
  334. });
  335. }
  336. {{--URL无参数以packages所存在物流公司为显示标准 --}}
  337. if (uriParts.length<=1 || isLogistic){
  338. data.packages.every(function (package) {
  339. data.logisticsAll.every(function (logistic) {
  340. if (package.logistic_id==logistic.id){
  341. data.logistics[logistic.id]=logistic.name;
  342. return false;
  343. }
  344. return true;
  345. });
  346. return true;
  347. });
  348. }
  349. },
  350. owner_seek:function (e) {
  351. let _this=this;
  352. let $val=e.target.value;
  353. if($val==='')_this.filterData.owner_id='';
  354. else{
  355. @foreach($owners as $owner)
  356. if ("{{ $owner->name }}".includes($val)){
  357. _this.filterData.owner_id="{{ $owner->id }}";
  358. location.href="#{{$owner->name}}";
  359. }
  360. @endforeach
  361. }
  362. $(e.target).focus();
  363. },
  364. logistic_seek:function(e){
  365. let _this=this;
  366. let $val=e.target.value;
  367. if($val){
  368. _this.logisticsAll.every(function (logistic) {
  369. let name=logistic.name;
  370. if (name.includes($val)){
  371. location.href="#"+logistic.name;
  372. return false;
  373. }
  374. return true;
  375. });
  376. }
  377. $(e.target).focus();
  378. },
  379. selectedOwner:function (e) {
  380. let selectedOwners=this.selectedOwners;
  381. let sign = true;
  382. for (let i=0;i<selectedOwners.length;i++){
  383. if (selectedOwners[i]==e.id){
  384. selectedOwners.splice(i,1);
  385. this.ownersCopy.every(function (ownerCopy) {
  386. if (ownerCopy.id==e.id) {
  387. ownerCopy.style=false;
  388. return false;
  389. }
  390. return true;
  391. });
  392. sign=false;
  393. break;
  394. }
  395. }
  396. if (sign) {
  397. this.selectedOwners.push(e.id);
  398. this.ownersCopy.every(function (ownerCopy) {
  399. if (ownerCopy.id==e.id) {
  400. ownerCopy.style=true;
  401. return false;
  402. }
  403. return true;
  404. });
  405. }
  406. },
  407. selectedLogistic:function (e) {
  408. let selectedLogistics=this.selectedLogistics;
  409. let sign = true;
  410. for (let i=0;i<selectedLogistics.length;i++){
  411. if (selectedLogistics[i]==e.id){
  412. selectedLogistics.splice(i,1);
  413. this.logisticsAll.every(function (logistic) {
  414. if (logistic.id==e.id) {
  415. logistic.style=false;
  416. return false;
  417. }
  418. return true;
  419. });
  420. sign=false;
  421. break;
  422. }
  423. }
  424. if (sign) {
  425. this.selectedLogistics.push(e.id);
  426. this.logisticsAll.every(function (logistic) {
  427. if (logistic.id==e.id) {
  428. logistic.style=true;
  429. return false;
  430. }
  431. return true;
  432. });
  433. }
  434. },
  435. checkAll(e){
  436. if (e.target.checked){
  437. this.ownersModel.forEach((el)=>{
  438. if (this.checkData.indexOf(el.id) == '-1'){
  439. this.checkData.push(el.id);
  440. }
  441. });
  442. }else {
  443. this.checkData = [];
  444. }
  445. },
  446. statisticExport:function (checkAllSign) {
  447. let url = '{{url('package/statistics/export')}}';
  448. let token='{{ csrf_token() }}';
  449. //excelExport 定义在 js/queryForm/export200818a.js
  450. excelExport(checkAllSign,this.checkData,url,this.sum,token);
  451. },
  452. hourFilter:function(e){
  453. datetimeRelating.verifyTime(e);
  454. },
  455. }
  456. });
  457. </script>
  458. @endsection