Forráskód Böngészése

配套订单能上哪些课跟着配套走,试课也是如此

lizhen_gitee 7 hónapja
szülő
commit
89cc3b540e

+ 63 - 0
application/admin/controller/Lessonpackage.php

@@ -4,6 +4,11 @@ namespace app\admin\controller;
 
 use app\common\controller\Backend;
 
+use think\Db;
+use Exception;
+use think\exception\DbException;
+use think\exception\PDOException;
+use think\exception\ValidateException;
 /**
  * 课程定价配套
  *
@@ -69,4 +74,62 @@ class Lessonpackage extends Backend
         return $this->view->fetch();
     }
 
+    /**
+     * 编辑
+     *
+     * @param $ids
+     * @return string
+     * @throws DbException
+     * @throws \think\Exception
+     */
+    public function edit($ids = null)
+    {
+        $row = $this->model->get($ids);
+        if (!$row) {
+            $this->error(__('No Results were found'));
+        }
+        $adminIds = $this->getDataLimitAdminIds();
+        if (is_array($adminIds) && !in_array($row[$this->dataLimitField], $adminIds)) {
+            $this->error(__('You have no permission'));
+        }
+        if (false === $this->request->isPost()) {
+            $this->view->assign('row', $row);
+            return $this->view->fetch();
+        }
+        $params = $this->request->post('row/a');
+        if (empty($params)) {
+            $this->error(__('Parameter %s can not be empty', ''));
+        }
+        $params = $this->preExcludeFields($params);
+        $result = false;
+        Db::startTrans();
+        try {
+            //是否采用模型验证
+            if ($this->modelValidate) {
+                $name = str_replace("\\model\\", "\\validate\\", get_class($this->model));
+                $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.edit' : $name) : $this->modelValidate;
+                $row->validateFailException()->validate($validate);
+            }
+
+            //修改所有配套订单
+            $rs_up  = Db::name('package_order')->where('package_id',$ids)->where('is_gift',0)->update(['lesson_ids'=>$params['lesson_ids']]);
+            $rs_up2 = Db::name('package_order')->where('package_id',$ids)->where('is_gift',1)->update(['lesson_ids'=>$params['gift_lesson_id']]);
+            if($rs_up === false || $rs_up2 === false){
+                Db::rollback();
+                $this->error('修改失败');
+            }
+            //
+
+            $result = $row->allowField(true)->save($params);
+            Db::commit();
+        } catch (ValidateException|PDOException|Exception $e) {
+        Db::rollback();
+        $this->error($e->getMessage());
+    }
+        if (false === $result) {
+            $this->error(__('No rows were updated'));
+        }
+        $this->success();
+    }
+
 }

+ 62 - 0
application/admin/controller/Trylesson.php

@@ -4,6 +4,11 @@ namespace app\admin\controller;
 
 use app\common\controller\Backend;
 
+use think\Db;
+use Exception;
+use think\exception\DbException;
+use think\exception\PDOException;
+use think\exception\ValidateException;
 /**
  * 试课课程
  *
@@ -69,4 +74,61 @@ class Trylesson extends Backend
         return $this->view->fetch();
     }
 
+    /**
+     * 编辑
+     *
+     * @param $ids
+     * @return string
+     * @throws DbException
+     * @throws \think\Exception
+     */
+    public function edit($ids = null)
+    {
+        $row = $this->model->get($ids);
+        if (!$row) {
+            $this->error(__('No Results were found'));
+        }
+        $adminIds = $this->getDataLimitAdminIds();
+        if (is_array($adminIds) && !in_array($row[$this->dataLimitField], $adminIds)) {
+            $this->error(__('You have no permission'));
+        }
+        if (false === $this->request->isPost()) {
+            $this->view->assign('row', $row);
+            return $this->view->fetch();
+        }
+        $params = $this->request->post('row/a');
+        if (empty($params)) {
+            $this->error(__('Parameter %s can not be empty', ''));
+        }
+        $params = $this->preExcludeFields($params);
+        $result = false;
+        Db::startTrans();
+        try {
+            //是否采用模型验证
+            if ($this->modelValidate) {
+                $name = str_replace("\\model\\", "\\validate\\", get_class($this->model));
+                $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.edit' : $name) : $this->modelValidate;
+                $row->validateFailException()->validate($validate);
+            }
+
+            //修改所有试课订单
+            $rs_up = Db::name('trylesson_order')->where('trylesson_id',$ids)->update(['lesson_ids'=>$params['lesson_ids']]);
+            if($rs_up === false){
+                Db::rollback();
+                $this->error('修改失败');
+            }
+            //
+
+            $result = $row->allowField(true)->save($params);
+            Db::commit();
+        } catch (ValidateException|PDOException|Exception $e) {
+            Db::rollback();
+            $this->error($e->getMessage());
+        }
+        if (false === $result) {
+            $this->error(__('No rows were updated'));
+        }
+        $this->success();
+    }
+
 }