<?php

namespace app\admin\controller\qywx;

use addons\qyexternal\model\Corp as Qywx;
use app\common\controller\Backend;
use think\Model;

/**
 * 企业微信客户管理
 *
 * @icon fa fa-circle-o
 */
class Corp extends Backend
{
    /**
     * @var null | Model
     */
    protected $model = null;

    public function _initialize()
    {
        parent::_initialize();
        $this->model = new Qywx();
    }

    /**
     * 列表
     */
    public function index()
    {
        if ($this->request->isAjax()) {
            list($where, $sort, $order, $offset, $limit) = $this->buildparams();

            $total = $this->model
                ->where($where)
                ->where("admin_id", $this->auth->id)
                ->order($sort, $order)
                ->count();

            $list = $this->model
                ->withCount(['contacts','chats'])
                ->where($where)
                ->where("admin_id", $this->auth->id)
                ->order($sort, $order)
                ->limit($offset, $limit)
                ->select();

            $result = array("total" => $total, "rows" => $list);

            return json($result);
        }

        return $this->view->fetch();
    }

    /**
     * 添加
     */
    public function add()
    {
        if ($this->request->isAjax()) {

            $params = $this->request->post("row/a");

            $params['admin_id'] = $this->auth->id;

            //判断是否存在
            $info = $this->model
                ->where('name', $params['name'])
                ->where('admin_id', $this->auth->id)
                ->where('corp_id', $params['corp_id'])
                ->find();

            if ($info) {
                $this->error("名称为 【" . $params['name'] . "】 的实例已经存在");
            }

            $this->model->startTrans();

            try {
                $this->model->save($params);

                $this->model->commit();

            } catch (\Exception $e) {

                $this->model->rollback();
                $this->error("请确认填写的参数信息是否正确,错误信息:" . $e->getMessage());
            }

            $this->success("成功");
        }
        return $this->view->fetch();
    }

    public function edit($ids = NULL)
    {
        $row = $this->model->get($ids);

        if ($this->request->isAjax()) {
            $params = $this->request->post("row/a");

            //判断是否存在
            $info = $this->model
                ->where('id', '<>', $row->id)
                ->where('name', $params['name'])
                ->where('admin_id', $this->auth->id)
                ->fetchSql(false)
                ->find();
            if ($info) {
                $this->error("名称为 【" . $params['name'] . "】 的实例已经存在");
            }

            $this->model->startTrans();
            try {

                $this->model->save($params, ['id' => $row->id]);

                $this->model->commit();

            } catch (\Exception $e) {

                $this->model->rollback();

                $this->error("请确认填写的参数信息是否正确,错误信息:" . $e->getMessage());
            }

            $this->success("成功");
        }
        $this->view->assign('row', $row);
        return $this->view->fetch();
    }
}