WaterDefault.php 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. <?php
  2. /**
  3. *
  4. * @author: xaboy<365615158@qq.com>
  5. * @day: 2017/11/11
  6. */
  7. namespace app\admin\controller\water;
  8. use app\admin\controller\AuthController;
  9. use crmeb\services\{ExpressService,
  10. JsonService,
  11. JsonService as Json,
  12. MiniProgramService,
  13. WechatService,
  14. FormBuilder as Form,
  15. CacheService,
  16. UtilService as Util};
  17. use think\facade\Route as Url;
  18. use think\facade\Validate;
  19. Use app\admin\model\water\WaterDefault as model;
  20. /**
  21. * 订单管理控制器 同一个订单表放在一个控制器
  22. * Class StoreOrder
  23. * @package app\admin\controller\store
  24. */
  25. class WaterDefault extends AuthController
  26. {
  27. /**
  28. * @return mixed
  29. */
  30. public function index()
  31. {
  32. return $this->fetch();
  33. }
  34. public function list()
  35. {
  36. $where = Util::getMore([
  37. ['page', 1],
  38. ['limit', 20],
  39. ['name', ''],
  40. ['card', ''],
  41. ['order_id', ''],
  42. ]);
  43. return Json::successlayui(model::list($where));
  44. }
  45. /**
  46. * 显示创建资源表单页.
  47. *
  48. * @return \think\Response
  49. */
  50. public function create($id = 0)
  51. {
  52. $f = [];
  53. $f[] = Form::input('high', '高度')->col(12);
  54. $f[] = Form::select('roof', '顶板', 0)->options(
  55. array_merge([['value' => 0, 'label' => '选择顶板厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 1)->field('id as value,name as label')->select()->toArray())
  56. )->filterable(true);
  57. $f[] = Form::select('floor', '底板', 0)->options(
  58. array_merge([['value' => 0, 'label' => '选择底板厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 4)->field('id as value,name as label')->select()->toArray())
  59. )->filterable(true);
  60. $f[] = Form::select('column', '立柱', 0)->options(
  61. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 5)->field('id as value,name as label')->select()->toArray())
  62. )->filterable(true);
  63. $f[] = Form::select('side_plate1', '侧板1', 0)->options(
  64. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  65. )->filterable(true);
  66. $f[] = Form::select('side_plate2', '侧板2', 0)->options(
  67. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  68. )->filterable(true);
  69. $f[] = Form::select('side_plate3', '侧板3', 0)->options(
  70. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  71. )->filterable(true);
  72. $f[] = Form::select('side_plate4', '侧板4', 0)->options(
  73. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  74. )->filterable(true);
  75. $f[] = Form::select('side_plate5', '侧板5', 0)->options(
  76. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  77. )->filterable(true);
  78. $f[] = Form::select('lacing1', '拉筋1', 0)->options(
  79. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  80. )->filterable(true);
  81. $f[] = Form::select('lacing2', '拉筋2', 0)->options(
  82. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  83. )->filterable(true);
  84. $f[] = Form::select('lacing3', '拉筋3', 0)->options(
  85. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  86. )->filterable(true);
  87. $f[] = Form::select('lacing4', '拉筋4', 0)->options(
  88. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  89. )->filterable(true);
  90. $f[] = Form::select('lacing5', '拉筋5', 0)->options(
  91. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  92. )->filterable(true);
  93. $f[] = Form::select('fula1', '辅拉1', 0)->options(
  94. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  95. )->filterable(true);
  96. $f[] = Form::select('fula2', '辅拉2', 0)->options(
  97. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  98. )->filterable(true);
  99. $f[] = Form::select('fula3', '辅拉3', 0)->options(
  100. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  101. )->filterable(true);
  102. $f[] = Form::select('fula4', '辅拉4', 0)->options(
  103. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  104. )->filterable(true);
  105. $f[] = Form::select('fula5', '辅拉5', 0)->options(
  106. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  107. )->filterable(true);
  108. $form = Form::make_post_form('添加', $f, Url::buildUrl('save'));
  109. $this->assign(compact('form'));
  110. return $this->fetch('public/form-builder');
  111. }
  112. public function save()
  113. {
  114. $model = new model;
  115. $data = Util::postMore([
  116. 'high',
  117. 'roof',
  118. 'floor',
  119. 'column',
  120. 'side_plate1',
  121. 'side_plate2',
  122. 'side_plate3',
  123. 'side_plate4',
  124. 'side_plate5',
  125. 'lacing1',
  126. 'lacing2',
  127. 'lacing3',
  128. 'lacing4',
  129. 'lacing5',
  130. 'fula1',
  131. 'fula2',
  132. 'fula3',
  133. 'fula4',
  134. 'fula5',
  135. ]);
  136. $validate = Validate::rule([
  137. 'high' => 'require',
  138. 'roof' => 'require',
  139. 'floor' => 'require',
  140. 'column' => 'require',
  141. 'side_plate1' => 'require',
  142. 'lacing1' => 'require',
  143. 'fula1' => 'require',
  144. ]);
  145. $validate->message([
  146. 'high.require' => '高度不能为空',
  147. 'roof.require' => '请选择顶板',
  148. 'floor.require' => '请选择底板',
  149. 'column.require' => '请填写立柱',
  150. 'side_plate1.require' => '最少填写侧板1',
  151. 'lacing1.require' => '最少填写拉筋1',
  152. 'fula1.require' => '最少填写辅拉1',
  153. ]);
  154. if ($data['side_plate1'] > 0) $data['side_plate'] = $data['side_plate1'];
  155. if ($data['side_plate2'] > 0) $data['side_plate'] .= ','.$data['side_plate2'];
  156. if ($data['side_plate3'] > 0) $data['side_plate'] .= ','.$data['side_plate3'];
  157. if ($data['side_plate4'] > 0) $data['side_plate'] .= ','.$data['side_plate4'];
  158. if ($data['side_plate5'] > 0) $data['side_plate'] .= ','.$data['side_plate5'];
  159. if ($data['lacing1'] > 0) $data['lacing'] = $data['lacing1'];
  160. if ($data['lacing2'] > 0) $data['lacing'] .= ','.$data['lacing2'];
  161. if ($data['lacing3'] > 0) $data['lacing'] .= ','.$data['lacing3'];
  162. if ($data['lacing4'] > 0) $data['lacing'] .= ','.$data['lacing4'];
  163. if ($data['lacing5'] > 0) $data['lacing'] .= ','.$data['lacing5'];
  164. if ($data['fula1'] > 0) $data['fula'] = $data['fula1'];
  165. if ($data['fula2'] > 0) $data['fula'] .= ','.$data['fula2'];
  166. if ($data['fula3'] > 0) $data['fula'] .= ','.$data['fula3'];
  167. if ($data['fula4'] > 0) $data['fula'] .= ','.$data['fula4'];
  168. if ($data['fula5'] > 0) $data['fula'] .= ','.$data['fula5'];
  169. if (!$validate->check($data)) {
  170. return Json::fail($validate->getError());
  171. }
  172. $res = $model->save($data);
  173. if ($res) return Json::successful('添加成功');
  174. return Json::fail('添加失败');
  175. }
  176. /**
  177. * 显示创建资源表单页.
  178. *
  179. * @return \think\Response
  180. */
  181. public function edit($id = 0)
  182. {
  183. $data = model::find($id);
  184. $f = [];
  185. $f[] = Form::input('high', '高度', $data['high'])->col(12);
  186. $f[] = Form::select('roof', '顶板', (string)$data['roof'])->options(
  187. array_merge([['value' => 0, 'label' => '选择顶板厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 1)->field('id as value,name as label')->select()->toArray())
  188. )->filterable(true);
  189. $f[] = Form::select('floor', '底板', (string)$data['floor'])->options(
  190. array_merge([['value' => 0, 'label' => '选择底板厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 4)->field('id as value,name as label')->select()->toArray())
  191. )->filterable(true);
  192. $f[] = Form::select('column', '立柱', (string)$data['column'])->options(
  193. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 5)->field('id as value,name as label')->select()->toArray())
  194. )->filterable(true);
  195. $side_plate = explode(',', $data['side_plate']);
  196. $f[] = Form::select('side_plate1', '侧板1', $side_plate[0] ?? 0)->options(
  197. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  198. )->filterable(true);
  199. $f[] = Form::select('side_plate2', '侧板2', $side_plate[1] ?? 0)->options(
  200. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  201. )->filterable(true);
  202. $f[] = Form::select('side_plate3', '侧板3', $side_plate[2]?? 0)->options(
  203. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  204. )->filterable(true);
  205. $f[] = Form::select('side_plate4', '侧板4', $side_plate[3] ?? 0)->options(
  206. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  207. )->filterable(true);
  208. $f[] = Form::select('side_plate5', '侧板5', $side_plate[4]?? 0)->options(
  209. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 2)->field('id as value,name as label')->select()->toArray())
  210. )->filterable(true);
  211. $lacing = explode(',', $data['lacing']);
  212. $f[] = Form::select('lacing1', '拉筋1', $lacing[0] ?? 0)->options(
  213. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  214. )->filterable(true);
  215. $f[] = Form::select('lacing2', '拉筋2', $lacing[1] ?? 0)->options(
  216. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  217. )->filterable(true);
  218. $f[] = Form::select('lacing3', '拉筋3', $lacing[2] ?? 0)->options(
  219. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  220. )->filterable(true);
  221. $f[] = Form::select('lacing4', '拉筋4', $lacing[3] ?? 0)->options(
  222. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  223. )->filterable(true);
  224. $f[] = Form::select('lacing5', '拉筋5', $lacing[4] ?? 0)->options(
  225. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 3)->field('id as value,name as label')->select()->toArray())
  226. )->filterable(true);
  227. $fula = explode(',', $data['fula']);
  228. $f[] = Form::select('fula1', '辅拉1', $fula[0] ?? 0)->options(
  229. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  230. )->filterable(true);
  231. $f[] = Form::select('fula2', '辅拉2', $fula[1] ?? 0)->options(
  232. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  233. )->filterable(true);
  234. $f[] = Form::select('fula3', '辅拉3', $fula[2] ?? 0)->options(
  235. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  236. )->filterable(true);
  237. $f[] = Form::select('fula4', '辅拉4', $fula[3] ?? 0)->options(
  238. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  239. )->filterable(true);
  240. $f[] = Form::select('fula5', '辅拉5', $fula[4] ?? 0)->options(
  241. array_merge([['value' => 0, 'label' => '选择立柱厚度']], \app\admin\model\water\WaterCate::order('id DESC')->where('is_show', 1)->where('type', 6)->field('id as value,name as label')->select()->toArray())
  242. )->filterable(true);
  243. $f[] = Form::hidden('id', $id);
  244. $form = Form::make_post_form('修改', $f, Url::buildUrl('update'));
  245. $this->assign(compact('form'));
  246. return $this->fetch('public/form-builder');
  247. }
  248. /**
  249. * 修改
  250. * @return void
  251. * @throws \think\db\exception\DataNotFoundException
  252. * @throws \think\db\exception\DbException
  253. * @throws \think\db\exception\ModelNotFoundException
  254. */
  255. public function update()
  256. {
  257. $model = new model;
  258. $data = Util::postMore([
  259. 'high',
  260. 'roof',
  261. 'floor',
  262. 'column',
  263. 'side_plate1',
  264. 'side_plate2',
  265. 'side_plate3',
  266. 'side_plate4',
  267. 'side_plate5',
  268. 'lacing1',
  269. 'lacing2',
  270. 'lacing3',
  271. 'lacing4',
  272. 'lacing5',
  273. 'fula1',
  274. 'fula2',
  275. 'fula3',
  276. 'fula4',
  277. 'fula5',
  278. 'id'
  279. ]);
  280. $validate = Validate::rule([
  281. 'high' => 'require',
  282. 'roof' => 'require',
  283. 'floor' => 'require',
  284. 'column' => 'require',
  285. 'side_plate1' => 'require',
  286. 'lacing1' => 'require',
  287. 'fula1' => 'require',
  288. ]);
  289. $validate->message([
  290. 'high.require' => '高度不能为空',
  291. 'roof.require' => '请选择顶板',
  292. 'floor.require' => '请选择底板',
  293. 'column.require' => '请填写立柱',
  294. 'side_plate1.require' => '最少填写侧板1',
  295. 'lacing1.require' => '最少填写拉筋1',
  296. 'fula1.require' => '最少填写辅拉1',
  297. ]);
  298. if ($data['side_plate1'] > 0) $data['side_plate'] = $data['side_plate1'];
  299. if ($data['side_plate2'] > 0) $data['side_plate'] .= ','.$data['side_plate2'];
  300. if ($data['side_plate3'] > 0) $data['side_plate'] .= ','.$data['side_plate3'];
  301. if ($data['side_plate4'] > 0) $data['side_plate'] .= ','.$data['side_plate4'];
  302. if ($data['side_plate5'] > 0) $data['side_plate'] .= ','.$data['side_plate5'];
  303. if ($data['lacing1'] > 0) $data['lacing'] = $data['lacing1'];
  304. if ($data['lacing2'] > 0) $data['lacing'] .= ','.$data['lacing2'];
  305. if ($data['lacing3'] > 0) $data['lacing'] .= ','.$data['lacing3'];
  306. if ($data['lacing4'] > 0) $data['lacing'] .= ','.$data['lacing4'];
  307. if ($data['lacing5'] > 0) $data['lacing'] .= ','.$data['lacing5'];
  308. if ($data['fula1'] > 0) $data['fula'] = $data['fula1'];
  309. if ($data['fula2'] > 0) $data['fula'] .= ','.$data['fula2'];
  310. if ($data['fula3'] > 0) $data['fula'] .= ','.$data['fula3'];
  311. if ($data['fula4'] > 0) $data['fula'] .= ','.$data['fula4'];
  312. if ($data['fula5'] > 0) $data['fula'] .= ','.$data['fula5'];
  313. $details = $model->find($data['id']);
  314. $details['high'] = $data['high'];
  315. $details['roof'] = $data['roof'];
  316. $details['floor'] = $data['floor'];
  317. $details['column'] = $data['column'];
  318. $details['side_plate'] = $data['side_plate'];
  319. $details['lacing'] = $data['lacing'];
  320. $details['fula'] = $data['fula'];
  321. $res = $details->save();
  322. if ($res) return Json::successful('修改成功');
  323. return Json::fail('修改失败');
  324. }
  325. /**
  326. * 删除
  327. * @param $id
  328. * @return void
  329. * @throws \Exception
  330. */
  331. public function delete($id)
  332. {
  333. if (!$id) Json::fail('删除失败');
  334. $model = new model;
  335. $res = model::destroy($id);
  336. if ($res){
  337. return Json::success('删除成功!');
  338. }else{
  339. return Json::fail($model->getErrorInfo());
  340. }
  341. }
  342. }