RecordRepository.php 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\common\repositories\system;
  12. use app\common\dao\system\RecordDao;
  13. use app\common\repositories\BaseRepository;
  14. use app\common\repositories\user\UserAddressRepository;
  15. class RecordRepository extends BaseRepository
  16. {
  17. //文章关联商品
  18. const TYPE_ADDRESS_RECORD = 'address_record';
  19. protected $dao;
  20. /**
  21. * @param RecordDao $dao
  22. */
  23. public function __construct(RecordDao $dao)
  24. {
  25. $this->dao = $dao;
  26. }
  27. /**
  28. * 添加记录到数据库。
  29. *
  30. * 根据传入的类型和数据,对特定类型的记录进行增加操作。目前支持的类型主要是地址记录。
  31. * 该方法首先检查传入的数据是否为空,如果为空,则直接返回,不进行任何操作。
  32. * 根据传入的类型,使用工厂模式获取相应的用户地址仓库实例。
  33. * 对于地址记录,通过地址ID获取地址详情,然后根据地址的省市信息,分别对省份和城市(如果城市为市辖区,则为区县)的记录数量进行增加操作。
  34. *
  35. * @param string $type 记录的类型,用于确定具体的操作逻辑。
  36. * @param array $data 记录的数据,包含相关字段的信息,如地址ID和增加的数量。
  37. */
  38. public function addRecord(string $type, array $data)
  39. {
  40. // 如果数据为空,则直接返回,不进行后续操作。
  41. if (empty($data)) return ;
  42. // 根据类型执行不同的操作逻辑。
  43. switch ($type) {
  44. case self::TYPE_ADDRESS_RECORD :
  45. // 通过依赖注入获取用户地址仓库实例。
  46. $userAddressRepository = app()->make(UserAddressRepository::class);
  47. // 根据地址ID获取地址详情。
  48. $addres = $userAddressRepository->getWhere(['address_id' => $data['address_id']]);
  49. // 如果城市为市辖区,则使用区县ID和区县名称,否则使用城市ID和城市名称。
  50. $cityid = ($addres['city'] == '市辖区') ? $addres['district_id'] : $addres['city_id'] ;
  51. $city = ($addres['city'] == '市辖区') ? $addres['district'] : $addres['city'] ;
  52. // 分别对省份和城市(区县)的记录数量进行增加操作。
  53. $this->dao->incType($type, $addres['province_id'], $data['num'],['title' => $addres['province']]);
  54. $this->dao->incType($type, $cityid, $data['num'],['title' => $city]);
  55. break;
  56. }
  57. }
  58. }