GoodsCollectLists.php 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeshop100%开源免费商用商城系统
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | 商业版本务必购买商业授权,以免引起法律纠纷
  8. // | 禁止对系统程序代码以任何目的,任何形式的再发布
  9. // | gitee下载:https://gitee.com/likeshop_gitee
  10. // | github下载:https://github.com/likeshop-github
  11. // | 访问官网:https://www.likeshop.cn
  12. // | 访问社区:https://home.likeshop.cn
  13. // | 访问手册:http://doc.likeshop.cn
  14. // | 微信公众号:likeshop技术社区
  15. // | likeshop团队 版权所有 拥有最终解释权
  16. // +----------------------------------------------------------------------
  17. // | author: likeshopTeam
  18. // +----------------------------------------------------------------------
  19. namespace app\shopapi\lists;
  20. use app\common\model\GoodsCollect;
  21. /**
  22. * 收藏商品列表接口
  23. * Class GoodsCollectLists
  24. * @package app\shopapi\lists
  25. */
  26. class GoodsCollectLists extends BaseShopDataLists
  27. {
  28. /**
  29. * @notes 商品收藏列表
  30. * @return array
  31. * @throws \think\db\exception\DataNotFoundException
  32. * @throws \think\db\exception\DbException
  33. * @throws \think\db\exception\ModelNotFoundException
  34. * @author cjhao
  35. * @date 2021/8/3 10:20
  36. */
  37. public function lists(): array
  38. {
  39. $list = GoodsCollect::with(['goods'])
  40. ->where(['user_id'=>$this->userId])
  41. ->limit($this->limitOffset, $this->limitLength)
  42. ->select()
  43. ->toArray();
  44. // 按日期分组
  45. $groupedData = [];
  46. foreach ($list as $item) {
  47. $date = date('Y-m-d', strtotime($item['create_time']));
  48. if (!isset($groupedData[$date])) {
  49. $groupedData[$date] = [
  50. 'date' => $date,
  51. 'date_text' => date('Y年m月d日', strtotime($item['create_time'])),
  52. 'goods_list' => []
  53. ];
  54. }
  55. $groupedData[$date]['goods_list'][] = $item;
  56. }
  57. // 转换为数组格式并按日期倒序排列
  58. return array_values($groupedData);
  59. //
  60. // return $list;
  61. }
  62. /**
  63. * @notes 商品收藏合计
  64. * @return int
  65. * @author cjhao
  66. * @date 2021/8/3 10:20
  67. */
  68. public function count(): int
  69. {
  70. return GoodsCollect::where(['user_id'=>$this->userId])->count();
  71. }
  72. }