+----------------------------------------------------------------------------------------------- */ declare(strict_types=1); namespace app\finance\controller; use app\base\BaseController; use app\finance\model\Expense as ExpenseModel; use app\finance\validate\ExpenseValidate; use think\exception\ValidateException; use think\facade\Db; use think\facade\View; class Expense extends BaseController { /** * 构造函数 */ protected $model; public function __construct() { parent::__construct(); // 调用父类构造函数 $this->model = new ExpenseModel(); } /** * 数据列表 */ public function datalist() { $param = get_params(); if (request()->isAjax()) { $tab = isset($param['tab']) ? $param['tab'] : 0; $uid = $this->uid; $where = array(); $whereOr = array(); $where[] = ['delete_time', '=', 0]; if ($tab == 0) { //全部 $whereOr[] = ['admin_id', '=', $this->uid]; $whereOr[] = ['', 'exp', Db::raw("FIND_IN_SET('{$uid}',check_uids)")]; $whereOr[] = ['', 'exp', Db::raw("FIND_IN_SET('{$uid}',check_history_uids)")]; $whereOr[] = ['', 'exp', Db::raw("FIND_IN_SET('{$uid}',check_copy_uids)")]; $auth = isAuthExpense($uid); if ($auth == 0) { $dids_a = get_leader_departments($uid); $dids_b = get_role_departments($uid); $dids = array_merge($dids_a, $dids_b); if (!empty($dids)) { $whereOr[] = ['did', 'in', $dids]; } } } if ($tab == 1) { //我创建的 $where[] = ['admin_id', '=', $this->uid]; } if ($tab == 2) { //待我审核的 $where[] = ['', 'exp', Db::raw("FIND_IN_SET('{$uid}',check_uids)")]; } if ($tab == 3) { //我已审核的 $where[] = ['', 'exp', Db::raw("FIND_IN_SET('{$uid}',check_history_uids)")]; } if ($tab == 4) { //抄送给我的 $where[] = ['', 'exp', Db::raw("FIND_IN_SET('{$uid}',check_copy_uids)")]; } if ($tab == 5) { //已打款的 $where[] = ['pay_status', '=', 1]; $auth = isAuthExpense($uid); if ($auth == 0) { $dids_a = get_leader_departments($uid); $dids_b = get_role_departments($uid); $dids = array_merge($dids_a, $dids_b); if (!empty($dids)) { $whereOr[] = ['did', 'in', $dids]; } } } //按时间检索 if (!empty($param['diff_time'])) { $diff_time = explode('~', $param['diff_time']); $where[] = ['income_month', 'between', [strtotime(urldecode($diff_time[0])), strtotime(urldecode($diff_time[1] . ' 23:59:59'))]]; } if (isset($param['pay_status']) && $param['pay_status'] != "") { $where[] = ['pay_status', '=', $param['pay_status']]; } if (isset($param['check_status']) && $param['check_status'] != "") { $where[] = ['check_status', '=', $param['check_status']]; } $list = $this->model->datalist($param, $where, $whereOr); return table_assign(0, '', $list); } else { return view(); } } /** * 添加/编辑 */ public function add() { $param = get_params(); if (request()->isAjax()) { $param['income_month'] = isset($param['income_month']) ? strtotime(urldecode($param['income_month'])) : 0; $param['expense_time'] = isset($param['expense_time']) ? strtotime(urldecode($param['expense_time'])) : 0; $amountData = isset($param['amount']) ? $param['amount'] : '0'; $cost = 0; if ($amountData == 0) { return to_assign(1, '报销金额不完善'); } else { foreach ($amountData as $key => $value) { if ($value == 0) { return to_assign(1, '第' . ($key + 1) . '条报销选项的金额不能为零'); } else { $cost += $value; } } } if ($cost == 0) { return to_assign(1, '报销金额不能为零'); } $param['admin_id'] = $this->uid; $param['did'] = $this->did; $param['cost'] = $cost; if (!empty($param['id']) && $param['id'] > 0) { try { validate(ExpenseValidate::class)->scene('edit')->check($param); } catch (ValidateException $e) { // 验证失败 输出错误信息 return to_assign(1, $e->getError()); } $this->model->edit($param); } else { try { validate(ExpenseValidate::class)->scene('add')->check($param); } catch (ValidateException $e) { // 验证失败 输出错误信息 return to_assign(1, $e->getError()); } $this->model->add($param); } } else { $id = isset($param['id']) ? $param['id'] : 0; View::assign('expense_cate', Db::name('ExpenseCate')->where(['status' => 1])->select()->toArray()); View::assign('user', get_admin($this->uid)); if ($id > 0) { $detail = $this->model->getById($id); View::assign('detail', $detail); if (is_mobile()) { return view('qiye@/finance/add_expense'); } return view('edit'); } if (is_mobile()) { return view('qiye@/finance/add_expense'); } return view(); } } /** * 查看 */ public function view($id) { $detail = $this->model->getById($id); if (!empty($detail)) { $file_array = Db::name('File')->where('id', 'in', $detail['file_ids'])->select(); $detail['file_array'] = $file_array; View::assign('detail', $detail); View::assign('create_user', get_admin($detail['admin_id'])); if (is_mobile()) { return view('qiye@/finance/view_expense'); } return view(); } else { return view(EEEOR_REPORTING, ['code' => 404, 'warning' => '找不到页面']); } } /** * 删除 */ public function del() { $param = get_params(); $id = isset($param['id']) ? $param['id'] : 0; if (request()->isDelete()) { $this->model->delById($id); } else { return to_assign(1, "错误的请求"); } } //报销记录 public function record() { if (request()->isAjax()) { $param = get_params(); $where = []; $where[] = ['delete_time', '=', 0]; $where[] = ['check_status', '=', 2]; if (isAuthExpense($this->uid) == 0) { $where[] = ['admin_id', '=', $this->uid]; } //按时间检索 if (!empty($param['diff_time'])) { $diff_time = explode('~', $param['diff_time']); $where[] = ['expense_time', 'between', [strtotime(urldecode($diff_time[0])), strtotime(urldecode($diff_time[1] . ' 23:59:59'))]]; } if (isset($param['pay_status']) && $param['pay_status'] != "") { $where[] = ['pay_status', '=', $param['pay_status']]; } $list = $this->model->datalist($param, $where); $cost = $this->model::where($where)->sum('cost'); $totalRow['cost'] = sprintf("%.2f", $cost); return table_assign(0, '', $list); } else { View::assign('authExpense', isAuthExpense($this->uid)); return view(); } } }