shoppingmallv2/app/Controllers/Front/ProductController.php
2023-08-24 09:16:29 +09:00

77 lines
2.6 KiB
PHP

<?php
namespace App\Controllers\Front;
use App\Models\ProductModel;
use CodeIgniter\HTTP\RequestInterface;
use CodeIgniter\HTTP\ResponseInterface;
use Psr\Log\LoggerInterface;
class ProductController extends FrontController
{
public function initController(RequestInterface $request, ResponseInterface $response, LoggerInterface $logger)
{
parent::initController($request, $response, $logger);
$this->_model = new ProductModel();
$this->_viewDatas['className'] = 'Product';
$this->_viewPath .= strtolower($this->_viewDatas['className']);
$this->_viewDatas['title'] = lang($this->_viewDatas['className'] . '.title');
$this->_viewDatas['class_icon'] = CLASS_ICONS[strtoupper($this->_viewDatas['className'])];
helper($this->_viewDatas['className']);
}
public function getFields(string $action = ""): array
{
$fields = ["photo", 'user_uid', 'type', 'name', "cost", "sale", "price", "stock", "view_cnt", "content",];
switch ($action) {
case "index":
case "excel":
return ["user_uid", 'type', "photo", "cost", "sale", "price", "stock", "view_cnt"];
break;
case "view":
return ["photo", 'type', 'name', "cost", "sale", "price", "stock", "view_cnt", "created_at", "content"];
break;
default:
return $fields;
break;
}
}
public function getFieldFilters(): array
{
return ["user_uid", 'type'];
}
public function getFieldBatchFilters(): array
{
return parent::getFieldBatchFilters();
}
//권한체크
protected function isRole($action)
{
$this->_category = $this->request->getVar('category') ?: throw new \Exception("분류를 지정하지 않으셨습니다.");
parent::isRole($action);
}
//View관련
protected function view_process($entity)
{
//권한체크
$this->isRole('view', $entity);
//조회수 올리기
$entity = $this->_model->addViewCount($entity);
return parent::view_process($entity);
}
//Index관련
protected function index_process()
{
//권한체크
$this->isRole('index');
return parent::index_process();
}
//Category 및 Status 조건추가
protected function index_setCondition()
{
$this->_model->where("category_uid", $this->_viewDatas['category']->getPrimaryKey());
$this->_model->where("status", DEFAULTS['STATUS']);
parent::index_setCondition();
}
}