<?php
// +----------------------------------------------------------------------
// | likeshop开源商城系统
// +----------------------------------------------------------------------
// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
// | gitee下载:https://gitee.com/likeshop_gitee
// | github下载:https://github.com/likeshop-github
// | 访问官网:https://www.likeshop.cn
// | 访问社区:https://home.likeshop.cn
// | 访问手册:http://doc.likeshop.cn
// | 微信公众号:likeshop技术社区
// | likeshop系列产品在gitee、github等公开渠道开源版本可免费商用,未经许可不能去除前后端官方版权标识
// |  likeshop系列产品收费版本务必购买商业授权,购买去版权授权后,方可去除前后端官方版权标识
// | 禁止对系统程序代码以任何目的,任何形式的再发布
// | likeshop团队版权所有并拥有最终解释权
// +----------------------------------------------------------------------
// | author: likeshop.cn.team
// +----------------------------------------------------------------------


namespace app\admin\logic\goods;


use app\common\basics\Logic;
use app\common\model\goods\Goods;
use app\common\model\goods\GoodsColumn;

/**
 * 商品栏目-逻辑
 * Class GoodsColumnLogic
 * @package app\admin\logic
 */
class ColumnLogic extends Logic
{

    /**
     * Notes: 列表
     * @param $get
     * @author 段誉(2021/4/15 10:53)
     * @return array
     * @throws \think\db\exception\DataNotFoundException
     * @throws \think\db\exception\DbException
     * @throws \think\db\exception\ModelNotFoundException
     */
    public static function lists($get)
    {
        $result = GoodsColumn::where(['del' =>0])
            ->order('sort')
            ->paginate([
                'list_rows'=> $get['limit'],
                'page'=> $get['page']
            ]);

        return ['count' => $result->total(), 'lists' => $result->getCollection()];
    }


    /**
     * Notes: 添加
     * @param $post
     * @return GoodsColumn|\think\Model
     *@author 段誉(2021/4/15 10:54)
     */
    public static function add($post)
    {
        return GoodsColumn::create([
            'name'     => $post['name'],
            'remark'   => $post['remark'] ?? '',
            'status'   => isset($post['status']) && $post['status'] == 'on' ? 1 : 0,
        ]);
    }


    /**
     * Notes: 编辑
     * @param $post
     * @return GoodsColumn
     *@author 段誉(2021/4/15 10:54)
     */
    public static function edit($post)
    {
        return GoodsColumn::update([
            'name'     => $post['name'],
            'remark'   => $post['remark'] ?? '',
            'status'   => isset($post['status']) && $post['status'] == 'on' ? 1 : 0,
        ], ['id' => $post['id']]);
    }


    /**
     * Notes: 删除
     * @param $id
     * @author 段誉(2021/6/24 2:51)
     * @return bool
     */
    public static function del($id)
    {
        //栏目删除,则栏目商品都删除
        GoodsColumn::update(['del' => 1], ['id' => $id]);
        Goods::whereFindInSet('column_ids', $id)->update(['column_ids' => '']);
        return true;
    }

    /**
     * 列表(不分页)
     */
    public static function getList()
    {
        return GoodsColumn::where(['del' => 0])->order('sort', 'desc')->column('id,name');
    }
}