海南旅游SAAS
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

282 lines
8.0 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. <?php
  2. namespace App\AdminAgent\Controllers;
  3. use App\AdminAgent\Repositories\Workorder;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\AgentProductItem;
  6. use App\Models\Guide;
  7. use App\Models\OrderProductItem;
  8. use App\Models\Supplier;
  9. use App\Models\WorkorderItem;
  10. use App\Traits\DemandTraits;
  11. use App\Traits\WorkorderTraits;
  12. use Dcat\Admin\Admin;
  13. use Dcat\Admin\Form;
  14. use Dcat\Admin\Grid;
  15. use Dcat\Admin\Layout\Content;
  16. use Dcat\Admin\Show;
  17. use Dcat\Admin\Http\Controllers\AdminController;
  18. use Illuminate\Http\Request;
  19. use App\Traits\ResponseHelper;
  20. use Illuminate\Support\Facades\Storage;
  21. use Illuminate\Support\Facades\Validator;
  22. class WorkorderController extends AdminController
  23. {
  24. use ResponseHelper;
  25. public function index(Content $content)
  26. {
  27. $workorderId = \request('workorder_id',0);
  28. $userList = $msgList = [];
  29. $workorder = \App\Models\Workorder::query()
  30. ->with(['point','publisher'])
  31. ->where(['publisher_id' => Admin::user()->id,'publisher_type' => DemandTraits::$col[0]])
  32. ->orWhere(['point_id' => Admin::user()->id,'point_type' => DemandTraits::$col[0]])
  33. ->orderByDesc('updated_at')
  34. ->get();
  35. foreach ($workorder as $v) {
  36. $item = WorkorderItem::query()->where('workorder_id',$v->id)->orderByDesc('updated_at')->first();
  37. $arr = [
  38. 'workorder_id' => $v->id,
  39. 'unread' => true,
  40. 'avatar' => $v->publisher_type == DemandTraits::$col[0] ? $v->point->avatar : $v->publisher->avatar,
  41. 'name' => $v->publisher_type == DemandTraits::$col[0] ? $v->point->name : $v->publisher->name,
  42. 'content' => $v->title,
  43. 'last_message' => $item ? ($item->type == 1 ? $item->content : '【 图片 】') : '',
  44. 'last_message_time' => $item->created_at ?? '',
  45. ];
  46. $userList [] = $arr;
  47. }
  48. $workorderItem = WorkorderItem::query()
  49. ->with(['publisher'])
  50. ->where('workorder_id',$workorderId)
  51. ->get();
  52. foreach ($workorderItem as $v) {
  53. $arr = [
  54. 'type' => $v->publisher_type == DemandTraits::$col[0] ? 'my' : 'op',
  55. 'it_type' => $v->type,
  56. 'avatar' => $v->publisher->avatar,
  57. 'name' => $v->publisher->name,
  58. 'content' => $v->content,
  59. ];
  60. $msgList [] = $arr;
  61. }
  62. $data = [
  63. 'user_list' => $userList,
  64. 'msg_list' => $msgList,
  65. 'user' => Admin::user()
  66. ];
  67. return $content
  68. ->header('工单')
  69. ->description('列表')
  70. ->body(admin_view('admin.pages.index',$data));
  71. }
  72. /**
  73. * Make a grid builder.
  74. *
  75. * @return Grid
  76. */
  77. protected function grid()
  78. {
  79. return Grid::make(new Workorder(['publisher','point']), function (Grid $grid) {
  80. $grid->model()
  81. ->where(['publisher_id' => Admin::user()->id,'publisher_type' => DemandTraits::$col[0]])
  82. ->orWhere(['point_id' => Admin::user()->id,'point_type' => DemandTraits::$col[0]]);
  83. $grid->column('id')->sortable();
  84. $grid->column('title');
  85. $grid->column('content_modal','内容')->modal('详情',function ($modal) {
  86. $modal->xl();
  87. return $this->content;
  88. });
  89. $grid->column('publisher_type')->using(DemandTraits::$polymorphic);
  90. $grid->column('publisher.name','发布人');
  91. $grid->column('point_type')->using(DemandTraits::$polymorphic);
  92. $grid->column('point.name','接收人');
  93. $grid->column('status')
  94. ->using(WorkorderTraits::$stateText)
  95. ->dot(
  96. [
  97. 1 => 'yellow',
  98. 2 => 'danger',
  99. 3 => 'success',
  100. ]);
  101. $grid->column('close_time');
  102. $grid->column('created_at');
  103. $grid->column('updated_at')->sortable();
  104. $grid->disableActions();
  105. $grid->filter(function (Grid\Filter $filter) {
  106. $filter->equal('id');
  107. });
  108. });
  109. }
  110. /**
  111. * Make a show builder.
  112. *
  113. * @param mixed $id
  114. *
  115. * @return Show
  116. */
  117. protected function detail($id)
  118. {
  119. return Show::make($id, new Workorder(), function (Show $show) {
  120. $show->field('id');
  121. $show->field('title');
  122. $show->field('content');
  123. $show->field('publisher_type');
  124. $show->field('publisher_id');
  125. $show->field('point_type');
  126. $show->field('point_id');
  127. $show->field('status');
  128. $show->field('close_time');
  129. $show->field('created_at');
  130. $show->field('updated_at');
  131. });
  132. }
  133. /**
  134. * Make a form builder.
  135. *
  136. * @return Form
  137. */
  138. protected function form()
  139. {
  140. return Form::make(new Workorder(), function (Form $form) {
  141. $form->display('id');
  142. $form->text('title');
  143. $form->textarea('content');
  144. $form->select('point_type')
  145. ->when([1],function (Form $form) {
  146. $form->select('supplier_id', '供应商')->options(function () {
  147. $supplierIds = AgentProductItem::query()->where('agent_id',Admin::user()->id)->distinct()->pluck('supplier_id');
  148. return Supplier::query()->whereIn('id',$supplierIds)->pluck('name','id');
  149. });
  150. })
  151. ->when([2],function (Form $form) {
  152. $form->select('guide_id', '地接')->options(function () {
  153. return Guide::query()->pluck('name','id');
  154. });
  155. })
  156. ->options([
  157. 1 => '供应商',
  158. 2 => '地接'
  159. ])
  160. ->default(1);
  161. $form->hidden('point_id');
  162. $form->hidden('publisher_type');
  163. $form->hidden('publisher_id');
  164. $form->saving(function (Form $form) {
  165. // 判断是否是新增操作
  166. if ($form->isCreating()) {
  167. if ($form->point_type == 1) {
  168. $form->point_id = $form->supplier_id;
  169. } elseif ($form->point_type == 2) {
  170. $form->point_id = $form->guide_id;
  171. }
  172. $form->deleteInput('supplier_id');
  173. $form->deleteInput('guide_id');
  174. $form->point_type = DemandTraits::$col[$form->point_type];
  175. //发布人身份
  176. $form->publisher_type = DemandTraits::$col[0];
  177. $form->publisher_id = Admin::user()->id;
  178. }
  179. });
  180. });
  181. }
  182. public function sendImage(Request $request)
  183. {
  184. $validator = Validator::make(request()->all(), [
  185. 'workorder_id' => 'required|int',
  186. ], [
  187. '*' => '参数异常',
  188. ]);
  189. if ($validator->fails()) {
  190. return $this->jsonFailValidated('数据不全:'.$validator->errors()->first());
  191. }
  192. $image = $request->file('image');
  193. if (empty($image) || !$image->isValid()) {
  194. return $this->error('您未上传任何文件');
  195. }
  196. $mime = $image->getMimeType();
  197. if (!in_array($mime, ['image/jpeg', 'image/png', 'image/gif', 'image/pjpeg'])) {
  198. return $this->error('上传图片格式错误');
  199. }
  200. $path = $request->image->store('public/images/workorder');
  201. $path = (Storage::url($path));
  202. $item = new WorkorderItem();
  203. $item->workorder_id = request('workorder_id',0);
  204. $item->content = $path;
  205. $item->type = 2;
  206. $item->publisher_type = DemandTraits::$col[0];
  207. $item->publisher_id = Admin::user()->id;
  208. $item->save();
  209. return $this->jsonSuccess($item);
  210. }
  211. public function sendText(Request $request)
  212. {
  213. $validator = Validator::make(request()->all(), [
  214. 'workorder_id' => 'required|int',
  215. 'content' => 'required',
  216. ], [
  217. '*' => '参数异常',
  218. ]);
  219. if ($validator->fails()) {
  220. return $this->jsonFailValidated('数据不全:'.$validator->errors()->first());
  221. }
  222. $item = new WorkorderItem();
  223. $item->workorder_id = request('workorder_id',0);
  224. $item->content = request('content','');
  225. $item->type = 1;
  226. $item->publisher_type = DemandTraits::$col[0];
  227. $item->publisher_id = Admin::user()->id;
  228. $item->save();
  229. return $this->jsonSuccess($item);
  230. }
  231. public function render()
  232. {
  233. $validator = Validator::make(request()->all(), [
  234. 'workorder_id' => 'required|int',
  235. ], [
  236. '*' => '参数异常',
  237. ]);
  238. if ($validator->fails()) {
  239. return $this->jsonFailValidated('数据不全:'.$validator->errors()->first());
  240. }
  241. $data = WorkorderItem::query()
  242. ->with('publisher')
  243. ->where('workorder_id',request('workorder_id',0))
  244. ->orderBy('created_at')
  245. ->get();
  246. foreach ($data as &$v) {
  247. if ($v->publisher_type == DemandTraits::$col[0]) {
  248. $v->location = 'right';
  249. } else {
  250. $v->location = 'left';
  251. }
  252. }
  253. return $this->jsonSuccess($data);
  254. }
  255. }