index.blade.php 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615
  1. @extends('layouts.app')
  2. @section('title')临时工报表@endsection
  3. @section('content')
  4. <div id="nav2">
  5. @component('personnel.menu')@endcomponent
  6. </div>
  7. <div class="d-none container-fluid" id="list">
  8. <div id="form_div"></div>
  9. <span class="dropdown">
  10. <button class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget mt-1 mb-1" :class="[checkData.length>0?'btn-dark text-light':'']"
  11. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的过滤结果,将其全部记录(每一页)导出">
  12. 导出Excel
  13. </button>
  14. <div class="dropdown-menu">
  15. <a class="dropdown-item" @click="laborReportExport(false)" href="javascript:">导出勾选内容</a>
  16. <a class="dropdown-item" @click="laborReportExport(true)" href="javascript:">导出所有页</a>
  17. </div>
  18. </span>
  19. <table class="table table-sm table-hover table-striped d-none d-sm-block p-0 text-nowrap table-bordered" >
  20. <tr>
  21. <th class="text-center">
  22. <label for="all">
  23. <input id="all" type="checkbox" @click="checkAll($event)">全选
  24. </label>
  25. </th>
  26. <th class="text-center">序号</th>
  27. {{-- <th>ID</th>--}}
  28. <th class="text-center">操作</th>
  29. <th class="text-center">进场时间</th>
  30. <th class="text-center">退场时间</th>
  31. <th class="text-center" style="background-color: rgb(241, 234, 190)">进厂编号</th>
  32. <th class="text-center" style="background-color: rgb(241, 234, 190)">小组</th>
  33. <th class="text-center" style="background-color: rgb(241, 234, 190)">临时工</th>
  34. <th class="text-center" style="background-color: rgb(241, 234, 190)">电话</th>
  35. <th class="text-center" style="background-color: rgb(241, 234, 190)">身份证号</th>
  36. <th class="text-center" style="background-color: rgb(241, 234, 190)">劳务所</th>
  37. <th class="text-center">进组时间</th>
  38. <th class="text-center">退组时间</th>
  39. <th class="text-center">审核时间</th>
  40. <th class="text-center">审核人</th>
  41. <th class="text-center">晚饭打卡(分)</th>
  42. <th class="text-center">在线时长</th>
  43. <th class="text-center">本次工作时长</th>
  44. <th class="text-center">备注</th>
  45. </tr>
  46. <tr v-for="(laborReport,i) in laborReports" @click="selectedColor(laborReport.id)" :style="{'font-weight': laborReport.id==selectedStyle?'bold':''}">
  47. <td>
  48. <input class="checkItem" type="checkbox" :value="laborReport.id" v-model="checkData">
  49. </td>
  50. <td>@{{ i+1 }}</td>
  51. <td >
  52. @can('人事管理-门卫审核')
  53. <span >
  54. <span v-if="laborReport.userDutyCheckVerifyUserId&&laborReport.amountOfJoined==1" class="text-success">已审核</span>
  55. <span v-else-if="laborReport.userDutyCheckVerifyUserId&&laborReport.amountOfJoined&&laborReport.sequence" class="text-black">&nbsp;&nbsp;&nbsp;@{{laborReport.sequence}}/@{{laborReport.amountOfJoined}}</span>
  56. <button v-else class="btn btn-sm btn-outline-secondary" @click="guardClockAudit(laborReport.id,laborReport.userDutyCheckId)">门卫审核</button>
  57. </span>
  58. @else
  59. <span v-if="laborReport.userDutyCheckVerifyUserId&&laborReport.amountOfJoined==1" class="text-success">已审核</span>
  60. <span v-else-if="laborReport.userDutyCheckVerifyUserId&&laborReport.amountOfJoined&&laborReport.sequence" class="text-black">&nbsp;&nbsp;&nbsp;@{{ laborReport.sequence }}/@{{ laborReport.amountOfJoined }}</span>
  61. <span v-else class="text-center"><b class="text-danger">门卫未审核</b></span>
  62. @endcan
  63. &nbsp;&nbsp;&nbsp;&nbsp;
  64. @can('人事管理-组长审核')
  65. <span>
  66. <button v-if="laborReport.groupUserId&&!laborReport.is_exportGroup" @click="groupExport(laborReport.id,laborReport.name)" class="btn btn-sm btn-outline-danger">退组</button>
  67. <span v-else-if="laborReport.groupUserId&&laborReport.is_exportGroup&&!laborReport.is_export" class="text-info">已退组</span>
  68. <span v-else-if="laborReport.is_export" class="text-black">已退场</span>
  69. <button v-else-if="laborReport.userWorkGroupId" @click="groupClockAudit(laborReport.id,laborReport.userWorkgroupNeedRemark)" class="btn btn-sm btn-outline-primary">组长审核</button>
  70. </span>
  71. @else
  72. <span v-if="laborReport.groupUserId&&!laborReport.is_exportGroup"><b class="text-success">在组</b></span>
  73. <span v-else-if="laborReport.groupUserId&&laborReport.is_exportGroup&&!laborReport.is_export" class="text-info">已退组</span>
  74. <span v-else-if="laborReport.is_export" class="text-black">已退场</span>
  75. <span v-else-if="laborReport.userWorkGroupId" class="text-center"><b class="text-danger">组长未审核</b></span>
  76. @endcan
  77. </td>
  78. <td class="text-muted">@{{laborReport.enter_at}}</td>
  79. <td >@{{ laborReport.exit_at }}</td>
  80. <td class="text-muted">@{{laborReport.enterNumber}}</td>
  81. <td>@{{laborReport.userWorkGroupName}}</td>
  82. <td >@{{laborReport.name}}</td>
  83. <td class="text-muted">@{{laborReport.mobilePhone}}</td>
  84. <td class="text-muted">@{{laborReport.identityNumber}}</td>
  85. <td class="text-muted">@{{laborReport.laborCompany}}</td>
  86. <td>@{{laborReport.checkInAt}}</td>
  87. <td class="text-muted">@{{laborReport.checkOutAt}}</td>
  88. <td class="text-muted">@{{laborReport.verifyAt}}</td>
  89. <td class="text-muted"><span v-if="laborReport.verifyPerson">@{{laborReport.verifyPerson}}</span></td>
  90. <td class="text-muted"><span v-if="laborReport.relax_time">@{{laborReport.relax_time}}</span></td>
  91. {{-- <td class="text-muted"><span v-if="laborReport.onlineDuration">@{{laborReport.onlineDuration}}</span></td>--}}
  92. <td class="text-muted"><span v-if="laborReport.thisRecordOnlineTime">@{{laborReport.thisRecordOnlineTime}}</span></td>
  93. <td><span v-if="laborReport.thisRecordWorkingTime">@{{laborReport.thisRecordWorkingTime}}</span></td>
  94. {{-- <td><span v-if="laborReport.workingDuration">@{{laborReport.workingDuration}}</span></td>--}}
  95. <td><span v-if="laborReport.remark">@{{laborReport.remark}}</span></td>
  96. </tr>
  97. </table>
  98. <table class="table table-striped table-sm table-bordered table-hover p-0 d-block d-sm-none" style="background: rgb(255, 255, 255);">
  99. <tbody>
  100. <tr v-for="laborReport in laborReports">
  101. <td style="filter:grayscale(30%); ">
  102. <div class="pl-3 mt-1">
  103. <div style="transform:scale(1)" class="pl-0">
  104. <span class="mr-3 text-nowrap">
  105. <span >操作:</span>
  106. <span >
  107. @can('人事管理-门卫审核')
  108. <span >
  109. <b v-if="laborReport.userDutyCheckVerifyUserId&&laborReport.amountOfJoined==1" class="text-success">已审核</b>
  110. <b v-else-if="laborReport.userDutyCheckVerifyUserId&&laborReport.amountOfJoined&&laborReport.sequence" class="text-black">&nbsp;&nbsp;&nbsp;@{{laborReport.sequence}}/@{{laborReport.amountOfJoined}}</b>
  111. <button v-else style="transform:scale(1.1)" class="btn btn-lg btn-outline-secondary" @click="guardClockAudit(laborReport.id,laborReport.userDutyCheckId)">门卫审核</button>
  112. </span>
  113. @else
  114. <b v-if="laborReport.userDutyCheckVerifyUserId&&laborReport.amountOfJoined==1" class="text-success">已审核</b>
  115. <b v-else-if="laborReport.userDutyCheckVerifyUserId&&laborReport.amountOfJoined&&laborReport.sequence" class="text-black">&nbsp;&nbsp;&nbsp;@{{ laborReport.sequence }}/@{{ laborReport.amountOfJoined }}</b>
  116. <span v-else class="text-center"><b class="text-danger">门卫未审核</b></span>
  117. @endcan
  118. &nbsp;&nbsp;&nbsp;&nbsp;
  119. @can('人事管理-组长审核')
  120. <span>
  121. <button v-if="laborReport.groupUserId&&!laborReport.is_exportGroup" @click="groupExport(laborReport.id,laborReport.name)" style="transform:scale(1.1)" class="btn btn-lg btn-danger">退组</button>
  122. <b v-else-if="laborReport.groupUserId&&laborReport.is_exportGroup&&!laborReport.is_export" class="text-info">已退组</b>
  123. <b v-else-if="laborReport.is_export" class="text-black">已退场</b>
  124. <button v-else-if="laborReport.userWorkGroupId" @click="groupClockAudit(laborReport.id,laborReport.userWorkgroupNeedRemark)" class="btn btn-lg btn-outline-primary" style="transform:scale(1.1)" >组长审核</button>
  125. </span>
  126. @else
  127. <span v-if="laborReport.groupUserId&&!laborReport.is_exportGroup"><b class="text-success">在组</b></span>
  128. <b v-else-if="laborReport.groupUserId&&laborReport.is_exportGroup&&!laborReport.is_export" class="text-info">已退组</b>
  129. <b v-else-if="laborReport.is_export" class="text-black">已退场</b>
  130. <span v-else-if="laborReport.userWorkGroupId" class="text-center"><b class="text-danger">组长未审核</b></span>
  131. @endcan
  132. </span>
  133. </span>
  134. <span class="mr-3 text-nowrap"><span class="text-black">进场时间:</span><span class="text-black-50">@{{laborReport.enter_at }}</span></span>
  135. {{-- <span class="mr-3 text-nowrap"><span class="text-black">退场时间:</span><span style="color:#af7651">@{{ laborReport.exit_at }}</span></span>--}}
  136. {{-- <span class="mr-3 text-nowrap"><span class="text-black">进场编号:</span><span style="color:#af7651">@{{ laborReport.enterNumber }}</span></span>--}}
  137. <span class="mr-3 text-nowrap"><span class="text-black">小组:</span><span class="text-black-50">@{{laborReport.userWorkGroupName }}</span></span>
  138. <span class="mr-3 text-nowrap"><span class="text-black">临时工:</span><span class="text-black-50">@{{ laborReport.name }} </span></span>
  139. {{-- <span class="mr-3 text-nowrap"><span class="text-black">电话:</span><span style="color:#af7651" v-if="">@{{ laborReport.mobilePhone }} </span></span>--}}
  140. {{-- <span class="mr-3 text-nowrap"><span class="text-black">身份证号:</span><span style="color:#af7651" v-if="">@{{ laborReport.identityNumber }} </span></span>--}}
  141. {{-- <span class="mr-3 text-nowrap"><span class="text-black">劳务所:</span><span style="color:#af7651" v-if="">@{{ laborReport.laborCompany }} </span></span>--}}
  142. {{-- <span class="mr-3 text-nowrap"><span class="text-black">进组时间:</span><span style="color:#af7651" v-if="">@{{ laborReport.checkInAt }} </span></span>--}}
  143. {{-- <span class="mr-3 text-nowrap"><span class="text-black">退组时间:</span><span style="color:#af7651" v-if="">@{{ laborReport.checkOutAt }} </span></span>--}}
  144. {{-- <span class="mr-3 text-nowrap"><span class="text-black">审核时间:</span><span style="color:#af7651" v-if="">@{{ laborReport.verifyAt }} </span></span>--}}
  145. {{-- <span class="mr-3 text-nowrap"><span class="text-black">审核人:</span><span style="color:#af7651" v-if="">@{{ laborReport.verifyPerson }} </span></span>--}}
  146. {{-- <span class="mr-3 text-nowrap"><span class="text-black">晚饭打卡(分):</span><span style="color:#af7651" v-if="">@{{ laborReport.relax_time }} </span></span>--}}
  147. {{-- <span class="mr-3 text-nowrap"><span class="text-black">在线时长:</span><span style="color:#af7651" v-if="">@{{ laborReport.onlineDuration }} </span></span>--}}
  148. {{-- <span class="mr-3 text-nowrap"><span class="text-black">本次工作时长:</span><span style="color:#af7651" v-if="">@{{ laborReport.workingDuration }} </span></span>--}}
  149. </div>
  150. </div>
  151. </td>
  152. </tr>
  153. </tbody>
  154. </table>
  155. <div class="text-info h5 btn btn">{{$laborReports->count()}}/@{{ sum }}</div>
  156. <div>{{$laborReports->appends($paginateParams)->links()}}</div>
  157. {{-- 选择晚饭时长弹框 --}}
  158. <div class="modal fade" id="exampleModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
  159. <div class="modal-dialog">
  160. <div class="modal-content">
  161. <div class="modal-header">
  162. <h5 class="modal-title" id="exampleModalLabel">晚餐时长</h5>
  163. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  164. <span aria-hidden="true">&times;</span>
  165. </button>
  166. </div>
  167. <div class="modal-body">
  168. <form>
  169. <div class="form-group">
  170. <label for="relax_time" class="col-form-label">选择晚饭时长:</label>
  171. <select class="form-control" id="relax_time" v-model="relax_time">
  172. <option value="30">30分</option>
  173. <option value="60">60分</option>
  174. </select>
  175. </div>
  176. </form>
  177. </div>
  178. <div class="modal-footer">
  179. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  180. <span class="btn btn-block" aria-hidden="true">取消</span>
  181. </button>
  182. <button type="button" class="btn btn-primary" data-dismiss="modal" @click="makeSureRelax_time">确定</button>
  183. </div>
  184. </div>
  185. </div>
  186. </div>
  187. {{-- 特定组需要添加备注 --}}
  188. <div class="modal fade" id="remarkModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
  189. <div class="modal-dialog">
  190. <div class="modal-content">
  191. <div class="modal-header">
  192. <h5 class="modal-title" id="exampleModalLabel">添加所需备注</h5>
  193. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  194. <span aria-hidden="true">&times;</span>
  195. </button>
  196. </div>
  197. <div class="modal-body">
  198. <form>
  199. <div class="form-group">
  200. <label for="remark" class="col-form-label">备注:</label>
  201. <textarea class="form-control" id="remark"></textarea>
  202. </div>
  203. </form>
  204. </div>
  205. <div class="modal-footer">
  206. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  207. <span class="btn btn-block" aria-hidden="true">取消</span>
  208. </button>
  209. <button type="button" class="btn btn-primary" data-dismiss="modal" @click="addRemarkAndGroupClock">确定</button>
  210. </div>
  211. </div>
  212. </div>
  213. </div>
  214. <!-- 是否晚餐弹框 -->
  215. <div class="modal fade" id="dinnerModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" >
  216. <div class="modal-dialog">
  217. <div class="modal-content">
  218. <div class="modal-body">
  219. <b class="font-weight-bold">是否晚餐?</b>
  220. </div>
  221. <div class="modal-footer">
  222. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  223. <span class="btn btn-block" @click="noDinner">否</span>
  224. </button>
  225. <button type="button" class="btn btn-primary" data-dismiss="modal" @click="haveDinner">是</button>
  226. </div>
  227. </div>
  228. </div>
  229. </div>
  230. </div>
  231. @endsection
  232. @section('lastScript')
  233. <script type="text/javascript" src="{{asset('js/queryForm/export.js')}}"></script>
  234. <script type="text/javascript" src="{{asset('js/queryForm/queryForm200803a.js')}}"></script>
  235. <script>
  236. @if(isset($request))
  237. let request={!! json_encode($request) !!};
  238. @endif
  239. new Vue({
  240. el:"#list",
  241. data:{
  242. laborReports:[
  243. @foreach($laborReports as $laborReport)
  244. {id:'{{$laborReport->id}}',enterNumber:'{{$laborReport->enter_number}}'
  245. ,@if($laborReport->userWorkgroup)userWorkGroupId:'{{$laborReport->userWorkgroup->id}}',
  246. userWorkgroupNeedRemark:'{{$laborReport->userWorkgroup->isNeedRemark}}',
  247. userWorkGroupName:'{{$laborReport->userWorkgroup->name}}',@endif
  248. userId:'{{$laborReport->user_id}}',name:'{{$laborReport->name}}'
  249. ,mobilePhone:'{{$laborReport->mobile_phone}}',identityNumber:'{{$laborReport->identity_number}}',laborCompany:'{{$laborReport->labor_company}}'
  250. ,checkInAt:'{{$laborReport->check_in_at}}', relax_time:'{{$laborReport->relax_time}}',
  251. is_exportGroup:'{{$laborReport->is_exportGroup}}',is_export:'{{$laborReport->is_export}}',
  252. verifyAt:'{{$laborReport->verify_at}}',groupUserId:'{{$laborReport->group_user_id}}',verifyPerson:'{{$laborReport->user['name']}}',
  253. checkOutAt:'{{$laborReport->check_out_at}}',onlineDuration:'{{$laborReport->online_duration}}',
  254. workingDuration:'{{$laborReport->working_duration}}', created_at:'{{$laborReport->created_at}}',
  255. enter_at:'{{$laborReport->enter_at}}',exit_at:'{{$laborReport->exit_at}}',
  256. thisRecordOnlineTime:'{{$laborReport->thisRecordOnlineTime}}',
  257. thisRecordWorkingTime:'{{$laborReport->thisRecordWorkingTime}}',
  258. sequence:'{{$laborReport->sequence}}',amountOfJoined:'{{$laborReport->amountOfJoined}}',remark:'{{$laborReport->remark}}',
  259. @if($laborReport->userDutyCheck)userDutyCheckId:'{{$laborReport->userDutyCheck->id}}', userDutyCheckVerifyUserId:'{{$laborReport->userDutyCheck->verify_user_id}}'
  260. ,userDutyCheckType:'{{$laborReport->userDutyCheck->type}}',userDutyCheckAt:'{{$laborReport->userDutyCheck->checked_at}}',@endif},
  261. @endforeach
  262. ],
  263. i:0,
  264. userWorkGroups:[
  265. @foreach($userWorkGroups as $userWorkGroup)
  266. {name:'{{$userWorkGroup->id}}',value:'{{$userWorkGroup->name}}'},
  267. @endforeach
  268. ],
  269. checkData:[],
  270. permittingWorkgroups:{!! $permittingWorkgroups !!},
  271. relax_time:'',dateTime:'',selectedStyle:'',
  272. sum:{!! $laborReports->total() !!},
  273. },
  274. mounted:function(){
  275. initEcho();
  276. //进场
  277. Echo.channel('{{$laravelEchoPrefix}}userDutyCheck').listen('ImportEvent',(e)=>{
  278. window.location.reload();
  279. });
  280. //退场
  281. Echo.channel('{{$laravelEchoPrefix}}userDutyCheck').listen('ExportEvent',(e)=>{
  282. window.location.reload();
  283. });
  284. //门卫审核
  285. Echo.channel('{{$laravelEchoPrefix}}userDutyCheck').listen('GuardAuditEvent',(e)=>{
  286. setTimeout(function (){
  287. window.location.reload();
  288. }, 500);
  289. });
  290. {{--Echo.channel('{{$laravelEchoPrefix}}userDutyCheck').listen('GuardAuditEvent',(e)=>{--}}
  291. {{-- let userDutyCheck=e.userDutyCheck;--}}
  292. {{-- let _this=this;--}}
  293. {{-- _this.laborReports.every(function (laborReport) {--}}
  294. {{-- if (laborReport.userDutyCheckId==userDutyCheck.id){--}}
  295. {{-- laborReport.userDutyCheck=userDutyCheck;--}}
  296. {{-- laborReport.userDutyCheckVerifyUserId=userDutyCheck.verify_user_id;--}}
  297. {{-- return false--}}
  298. {{-- }--}}
  299. {{-- return true;--}}
  300. {{-- });--}}
  301. {{--});--}}
  302. //组长审核
  303. Echo.channel('{{$laravelEchoPrefix}}laborReport').listen('TeamAuditEvent',(e)=>{
  304. setTimeout(function (){
  305. window.location.reload();
  306. }, 500);
  307. });
  308. {{--Echo.channel('{{$laravelEchoPrefix}}laborReport').listen('TeamAuditEvent',(e)=>{--}}
  309. {{-- let labor=e.laborReport;--}}
  310. {{-- let _this=this;--}}
  311. {{-- setTimeout(function (){--}}
  312. {{-- _this.laborReports.every(function (laborReport) {--}}
  313. {{-- if (laborReport.id==labor.id){--}}
  314. {{-- laborReport.groupUserId==labor.group_user_id;--}}
  315. {{-- return false--}}
  316. {{-- }--}}
  317. {{-- return true;--}}
  318. {{-- });--}}
  319. {{-- }, 500);--}}
  320. {{--});--}}
  321. //进组
  322. this.permittingWorkgroups.forEach(function(workgroup){
  323. Echo.channel('{{$laravelEchoPrefix}}'+workgroup.token).listen('ClockinEvent',(e)=>{
  324. window.location.reload();
  325. });
  326. });
  327. //退组
  328. this.permittingWorkgroups.forEach(function(workgroup){
  329. Echo.channel('{{$laravelEchoPrefix}}'+workgroup.token).listen('ClockoutEvent',(e)=>{
  330. setTimeout(function (){
  331. window.location.reload();
  332. }, 500);
  333. });
  334. });
  335. $(".tooltipTarget").tooltip({'trigger':'hover'});
  336. $('#list').removeClass('d-none');
  337. let data=[
  338. [
  339. {name:'created_at_start',type:'dataTime',tip:'选择显示指定日期的起始时间'},
  340. {name:'user_workgroup_id',type:'search_select',tip:['',''],placeholder:['小组',''],data:this.userWorkGroups},
  341. {name:'enter_number',type:'input',tip:'进场编号:可在两侧增加百分号(%)进行模糊搜索',placeholder: '进场编号'},
  342. ],
  343. [
  344. {name:'created_at_end',type:'dataTime',tip:'选择显示指定日期的结束时间'},
  345. {name:'mobile_phone',type:'input',tip:'电话号:可在两侧增加百分号(%)进行模糊搜索',placeholder: '电话号'},
  346. {name:'identity_number',type:'input',tip:'身份证号:可在两侧增加百分号(%)进行模糊搜索',placeholder: '身份证号'},
  347. ],
  348. ];
  349. this.form = new query({
  350. el:"#form_div",
  351. condition:data,
  352. });
  353. this.form.init();
  354. },
  355. watch:{
  356. checkData:{
  357. handler(){
  358. if (this.checkData.length === this.laborReports.length){
  359. document.querySelector('#all').checked = true;
  360. }else {
  361. document.querySelector('#all').checked = false;
  362. }
  363. },
  364. deep:true
  365. }
  366. },
  367. methods:{
  368. selectedColor(id){
  369. if (id==this.selectedStyle){
  370. this.selectedStyle='';
  371. return;
  372. }
  373. this.selectedStyle=id;
  374. },
  375. checkAll(e){
  376. if (e.target.checked){
  377. this.laborReports.forEach((el,i)=>{
  378. if (this.checkData.indexOf(el.id) == '-1'){
  379. this.checkData.push(el.id);
  380. }
  381. });
  382. }else {
  383. this.checkData = [];
  384. }
  385. },
  386. laborReportExport(checkAllSign){
  387. let url = '{{url('laborReport/export')}}';
  388. let token='{{ csrf_token() }}';
  389. excelExport(checkAllSign,this.checkData,url,this.sum,token);
  390. },
  391. //门卫审核
  392. guardClockAudit(id,userDutyCheckId){
  393. let url='{{url("laborReport/guardClockAudit")}}';
  394. let _this=this;
  395. axios.post(url,{id:id,userDutyCheckId:userDutyCheckId})
  396. .then(function (response) {
  397. if (!response.data.success){
  398. tempTip.setDuration(3000);
  399. tempTip.show(response.data.data);
  400. return;
  401. }
  402. _this.laborReports.every(function (laborReport) {
  403. if (laborReport.id==id){
  404. laborReport.userDutyCheckVerifyUserId=response.data.data;
  405. tempTip.setDuration(3000);
  406. tempTip.showSuccess('审核通过!');
  407. return false
  408. }
  409. return true;
  410. });
  411. }).catch(function (err) {
  412. tempTip.setDuration(4000);
  413. tempTip.show('审核失败!网络错误:'+err);
  414. });
  415. },
  416. ////组长打卡审核(特定组添加备注)
  417. addRemarkAndGroupClock(){
  418. let _this=this;
  419. let id = getSelectId();
  420. let remark=document.getElementById('remark').value;
  421. let url='{{url("laborReport/addRemarkAndGroupClock")}}';
  422. if (remark==null|| remark=='' || remark=="undefined"){
  423. tempTip.setDuration(3000);
  424. tempTip.show("您还未添加任何备注");
  425. return;
  426. }
  427. axios.post(url,{id:id,remark:remark})
  428. .then(function (response) {
  429. if (!response.data.success){
  430. tempTip.setDuration(3000);
  431. tempTip.show(response.data.data);
  432. return;
  433. }
  434. _this.laborReports.every(function (laborReport) {
  435. if (laborReport.id==id){
  436. laborReport.groupUserId=response.data.data.group_user_id;
  437. laborReport.verifyAt=response.data.data.verify_at;
  438. laborReport.verifyPerson=response.data.data.verifyPerson;
  439. laborReport.remark=response.data.data.remark;
  440. tempTip.setDuration(3000);
  441. tempTip.showSuccess('审核通过!');
  442. return false
  443. }
  444. return true;
  445. });
  446. }).catch(function (err) {
  447. tempTip.setDuration(4000);
  448. tempTip.show('审核失败!网络错误:'+err);
  449. });
  450. },
  451. //组长打卡审核
  452. groupClockAudit(id,userWorkgroupNeedRemark){
  453. let url='{{url("laborReport/groupClockAudit")}}';
  454. let _this=this;
  455. if (userWorkgroupNeedRemark){
  456. $('#remarkModal').modal('show');
  457. selectId(id);
  458. return;
  459. }
  460. axios.post(url,{id:id})
  461. .then(function (response) {
  462. if (!response.data.success){
  463. tempTip.setDuration(3000);
  464. tempTip.show(response.data.data);
  465. return;
  466. }
  467. _this.laborReports.every(function (laborReport) {
  468. if (laborReport.id==id){
  469. laborReport.groupUserId=response.data.data.group_user_id;
  470. laborReport.verifyAt=response.data.data.verify_at;
  471. laborReport.verifyPerson=response.data.data.verifyPerson;
  472. tempTip.setDuration(3000);
  473. tempTip.showSuccess('审核通过!');
  474. return false
  475. }
  476. return true;
  477. });
  478. }).catch(function (err) {
  479. tempTip.setDuration(4000);
  480. tempTip.show('审核失败!网络错误:'+err);
  481. });
  482. },
  483. //有晚餐
  484. haveDinner(){
  485. $('#exampleModal').modal('show');
  486. },
  487. noDinner(){
  488. let _this=this;
  489. let id = getSelectId();
  490. let url='{{url("laborReport/groupExport")}}';
  491. axios.post(url,{id:id})
  492. .then(function (response) {
  493. if (!response.data.success){
  494. tempTip.setDuration(3000);
  495. tempTip.show(response.data.data);
  496. return;
  497. }
  498. _this.laborReports.every(function (laborReport) {
  499. if (laborReport.id==id){
  500. laborReport.checkOutAt=response.data.data.check_out_at;
  501. laborReport.workingDuration=response.data.data.working_duration;
  502. laborReport.is_exportGroup=response.data.data.is_exportGroup;
  503. laborReport.onlineDuration=response.data.data.online_duration;
  504. tempTip.setDuration(3000);
  505. tempTip.showSuccess('退组成功!');
  506. return false
  507. }
  508. return true;
  509. });
  510. }).catch(function (err) {
  511. tempTip.setDuration(4000);
  512. tempTip.show('退组失败!网络错误:'+err);
  513. });
  514. },
  515. //退场有晚饭时间
  516. makeSureRelax_time(){
  517. let url='{{url("laborReport/groupExportEnsure")}}';
  518. let _this=this;
  519. let id = getSelectId();
  520. axios.post(url,{id:id,relax_time:_this.relax_time})
  521. .then(function (response) {
  522. if (!response.data.success){
  523. tempTip.setDuration(3000);
  524. tempTip.show(response.data.data);
  525. return;
  526. }
  527. _this.laborReports.every(function (laborReport) {
  528. if (laborReport.id==id){
  529. laborReport.checkOutAt=response.data.data.check_out_at;
  530. laborReport.workingDuration=response.data.data.working_duration;
  531. laborReport.relax_time=response.data.data.relax_time;
  532. laborReport.is_exportGroup=response.data.data.is_exportGroup;
  533. laborReport.onlineDuration=response.data.data.online_duration;
  534. tempTip.setDuration(3000);
  535. tempTip.showSuccess('退组成功!');
  536. return false
  537. }
  538. return true;
  539. });
  540. }).catch(function (err) {
  541. tempTip.setDuration(4000);
  542. tempTip.show('退组失败!网络错误:'+err);
  543. });
  544. },
  545. //组长点击退组,
  546. groupExport(id,name){
  547. let _this=this;
  548. _this.laborReports.every(function (laborReport) {
  549. if (laborReport.id==id){
  550. _this.dateTime=new Date(new Date(laborReport.created_at).toLocaleDateString());
  551. return false;
  552. }
  553. return true;
  554. });
  555. const dateTime=new Date(_this.dateTime.setDate(_this.dateTime.getDate()+1));
  556. const start = new Date(new Date(new Date().toLocaleDateString()).getTime()+19*60*60*1000);
  557. if(!confirm("确定要临时工“"+name+"“退组吗?")){return}
  558. if (new Date()>=start || new Date()>dateTime){
  559. $('#dinnerModal').modal('show');
  560. selectId(id);
  561. return;
  562. }
  563. let url='{{url("laborReport/groupExport")}}';
  564. axios.post(url,{id:id})
  565. .then(function (response) {
  566. if (!response.data.success){
  567. tempTip.setDuration(3000);
  568. tempTip.show(response.data.data);
  569. return;
  570. }
  571. _this.laborReports.every(function (laborReport) {
  572. if (laborReport.id==id){
  573. laborReport.checkOutAt=response.data.data.check_out_at;
  574. laborReport.workingDuration=response.data.data.working_duration;
  575. laborReport.is_exportGroup=response.data.data.is_exportGroup;
  576. laborReport.onlineDuration=response.data.data.online_duration;
  577. tempTip.setDuration(3000);
  578. tempTip.showSuccess('退组成功!');
  579. return false
  580. }
  581. return true;
  582. });
  583. }).catch(function (err) {
  584. tempTip.setDuration(5000);
  585. tempTip.show('退组失败!网络错误:'+err);
  586. });
  587. },
  588. owner_seek:function (e) {
  589. let _this=this;
  590. let $val=e.target.value;
  591. if($val==='')_this.filterData.user_workgroup_id='';
  592. else
  593. _this.userWorkGroups.forEach(function (userWorkGroup) {
  594. if (userWorkGroup.name.includes($val)){
  595. _this.filterData.user_workgroup_id=userWorkGroup.id;
  596. }
  597. });
  598. },
  599. },
  600. });
  601. let select_id = 0;
  602. function selectId(id) {
  603. select_id = id;
  604. }
  605. function getSelectId() {
  606. return select_id;
  607. }
  608. </script>
  609. @endsection