diff --git a/app/adminapi/controller/administrative/AdministrativeTicketCollectionController.php b/app/adminapi/controller/administrative/AdministrativeTicketCollectionController.php new file mode 100644 index 000000000..5e287f07e --- /dev/null +++ b/app/adminapi/controller/administrative/AdministrativeTicketCollectionController.php @@ -0,0 +1,108 @@ +dataLists(new AdministrativeTicketCollectionLists()); + } + + + /** + * @notes 添加 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function add() + { + $params = (new AdministrativeTicketCollectionValidate())->post()->goCheck('add'); + $result = AdministrativeTicketCollectionLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(AdministrativeTicketCollectionLogic::getError()); + } + + + /** + * @notes 编辑 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function edit() + { + $params = (new AdministrativeTicketCollectionValidate())->post()->goCheck('edit'); + $result = AdministrativeTicketCollectionLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(AdministrativeTicketCollectionLogic::getError()); + } + + + /** + * @notes 删除 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function delete() + { + $params = (new AdministrativeTicketCollectionValidate())->post()->goCheck('delete'); + AdministrativeTicketCollectionLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取详情 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function detail() + { + $params = (new AdministrativeTicketCollectionValidate())->goCheck('detail'); + $result = AdministrativeTicketCollectionLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/lists/administrative/AdministrativeTicketCollectionLists.php b/app/adminapi/lists/administrative/AdministrativeTicketCollectionLists.php new file mode 100644 index 000000000..3e848bc1b --- /dev/null +++ b/app/adminapi/lists/administrative/AdministrativeTicketCollectionLists.php @@ -0,0 +1,94 @@ + ['org_id', 'dept_id', 'administrative_contract_id', 'invoice_type', 'invoice_sn', 'invoice_amount'], + ]; + } + + + /** + * @notes 获取列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function lists(): array + { + return AdministrativeTicketCollection::where($this->searchWhere) + ->field(['id', 'org_id', 'dept_id', 'administrative_contract_id', 'invoicing_date', 'commitor', 'invoice_type', 'invoice_sn', 'invoice_amount', 'invoice_tax_rate', 'tax', 'amount_excluding_tax', 'receipt_date', 'remark', 'annex']) + ->limit($this->limitOffset, $this->limitLength) + ->order(['id' => 'desc']) + ->select() + ->toArray(); + return Db::name('AdministrativeTicketCollection')->alias('atc') + ->where($this->searchWhere) + ->whereNull('er.delete_time') + ->leftJoin('orgs o','o.id = er.org_id') + ->leftJoin('dept d','d.id = er.dept_id') + ->leftJoin('custom ct','ct.id = er.customer_id') + ->field('er.*, d.name as dept_name, o.name as org_name, ct.name as customer_name') + ->limit($this->limitOffset, $this->limitLength) + ->order(['er.id' => 'desc']) + ->select()->each(function($item, $key){ + //关联数据后续添加 + $item['approve_no'] = '付款单号'; + $item['approve_step'] = '流程步骤'; + $item['approve_settle_status'] = 1; + return $item; + }) + ->toArray(); + } + + + /** + * @notes 获取数量 + * @return int + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function count(): int + { + return AdministrativeTicketCollection::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/logic/administrative/AdministrativeTicketCollectionLogic.php b/app/adminapi/logic/administrative/AdministrativeTicketCollectionLogic.php new file mode 100644 index 000000000..e8405ad8e --- /dev/null +++ b/app/adminapi/logic/administrative/AdministrativeTicketCollectionLogic.php @@ -0,0 +1,132 @@ + $params['org_id'], + 'dept_id' => $params['dept_id'], + 'administrative_contract_id' => $params['administrative_contract_id'], + 'invoicing_date' => $params['invoicing_date'], + 'commitor' => $params['commitor'], + 'invoice_type' => $params['invoice_type'], + 'invoice_sn' => $params['invoice_sn'], + 'invoice_amount' => $params['invoice_amount'], + 'invoice_tax_rate' => $params['invoice_tax_rate'], + 'tax' => $params['tax'], + 'amount_excluding_tax' => $params['amount_excluding_tax'], + 'receipt_date' => $params['receipt_date'], + 'remark' => $params['remark'], + 'annex' => $params['annex'], + ]); + + Db::commit(); + return true; + } catch (\Exception $e) { + Db::rollback(); + self::setError($e->getMessage()); + return false; + } + } + + + /** + * @notes 编辑 + * @param array $params + * @return bool + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public static function edit(array $params): bool + { + Db::startTrans(); + try { + AdministrativeTicketCollection::where('id', $params['id'])->update([ + 'org_id' => $params['org_id'], + 'dept_id' => $params['dept_id'], + 'administrative_contract_id' => $params['administrative_contract_id'], + 'invoicing_date' => $params['invoicing_date'], + 'commitor' => $params['commitor'], + 'invoice_type' => $params['invoice_type'], + 'invoice_sn' => $params['invoice_sn'], + 'invoice_amount' => $params['invoice_amount'], + 'invoice_tax_rate' => $params['invoice_tax_rate'], + 'tax' => $params['tax'], + 'amount_excluding_tax' => $params['amount_excluding_tax'], + 'receipt_date' => $params['receipt_date'], + 'remark' => $params['remark'], + 'annex' => $params['annex'], + ]); + + Db::commit(); + return true; + } catch (\Exception $e) { + Db::rollback(); + self::setError($e->getMessage()); + return false; + } + } + + + /** + * @notes 删除 + * @param array $params + * @return bool + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public static function delete(array $params): bool + { + return AdministrativeTicketCollection::destroy($params['id']); + } + + + /** + * @notes 获取详情 + * @param $params + * @return array + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public static function detail($params): array + { + return AdministrativeTicketCollection::findOrEmpty($params['id'])->toArray(); + } +} \ No newline at end of file diff --git a/app/adminapi/validate/administrative/AdministrativeTicketCollectionValidate.php b/app/adminapi/validate/administrative/AdministrativeTicketCollectionValidate.php new file mode 100644 index 000000000..03d3f0665 --- /dev/null +++ b/app/adminapi/validate/administrative/AdministrativeTicketCollectionValidate.php @@ -0,0 +1,104 @@ + 'require', + 'org_id' => 'require', + 'dept_id' => 'require', + 'administrative_contract_id' => 'require', + 'invoice_amount' => 'require', + 'receipt_date' => 'require', + ]; + + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'id' => 'id', + 'org_id' => '组织id', + 'dept_id' => '部门id', + 'administrative_contract_id' => '行政合同id', + 'invoice_amount' => '发票金额', + 'receipt_date' => '收票日期', + ]; + + + /** + * @notes 添加场景 + * @return AdministrativeTicketCollectionValidate + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function sceneAdd() + { + return $this->only(['org_id','dept_id','administrative_contract_id','invoice_amount','receipt_date']); + } + + + /** + * @notes 编辑场景 + * @return AdministrativeTicketCollectionValidate + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function sceneEdit() + { + return $this->only(['id','org_id','dept_id','administrative_contract_id','invoice_amount','receipt_date']); + } + + + /** + * @notes 删除场景 + * @return AdministrativeTicketCollectionValidate + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function sceneDelete() + { + return $this->only(['id']); + } + + + /** + * @notes 详情场景 + * @return AdministrativeTicketCollectionValidate + * @author likeadmin + * @date 2023/12/19 14:00 + */ + public function sceneDetail() + { + return $this->only(['id']); + } + +} \ No newline at end of file diff --git a/app/common/model/administrative/AdministrativeTicketCollection.php b/app/common/model/administrative/AdministrativeTicketCollection.php new file mode 100644 index 000000000..3cd5cc6a2 --- /dev/null +++ b/app/common/model/administrative/AdministrativeTicketCollection.php @@ -0,0 +1,45 @@ +hasOne(\app\common\model\contract\AdministrativeContract::class, 'id', 'administrative_contract_id'); + } + +} \ No newline at end of file