海南旅游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.

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