shoppingmallv2 init...
This commit is contained in:
parent
5775f24f9e
commit
8d1c3639d4
@ -519,7 +519,7 @@ abstract class BaseController extends Controller
|
||||
$this->_viewDatas['word'] = $this->request->getVar('word') ?: '';
|
||||
$this->_viewDatas['start'] = $this->request->getVar('start') ?: '';
|
||||
$this->_viewDatas['end'] = $this->request->getVar('end') ?: '';
|
||||
$this->_viewDatas['order_field'] = $this->request->getVar('order_field') ?: 'uid';
|
||||
$this->_viewDatas['order_field'] = $this->request->getVar('order_field') ?: 'created_at';
|
||||
$this->_viewDatas['order_value'] = $this->request->getVar('order_value') ?: 'DESC';
|
||||
$this->_model->setCondition(
|
||||
$filterFields,
|
||||
|
||||
@ -29,7 +29,7 @@ class CartController extends OrderController
|
||||
public function getFields(string $action = ""): array
|
||||
{
|
||||
switch ($action) {
|
||||
case 'update':
|
||||
case 'insert':
|
||||
return ["product_uid", "quantity", "price"];
|
||||
break;
|
||||
default:
|
||||
@ -40,10 +40,12 @@ class CartController extends OrderController
|
||||
protected function getFieldRule(string $field, array $rules, string $action = ""): array
|
||||
{
|
||||
switch ($field) {
|
||||
case "product_uid":
|
||||
case "quantity":
|
||||
case "price":
|
||||
$rules = $this->_model->getFieldRule($field, $rules, $action);
|
||||
case 'product_uid':
|
||||
$rules[$field] = "required|regex_match[/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/]";
|
||||
break;
|
||||
case 'quantity':
|
||||
case 'price':
|
||||
$rules[$field] = "required|numeric";
|
||||
break;
|
||||
default:
|
||||
$rules = parent::getFieldRule($field, $rules, $action);
|
||||
@ -60,14 +62,28 @@ class CartController extends OrderController
|
||||
return parent::getFieldBatchFilters();
|
||||
}
|
||||
|
||||
//주문(장바구니담기)
|
||||
protected function insert_process()
|
||||
{
|
||||
//addCart용 데이터 재처리 작업
|
||||
$orderFormDatas = [];
|
||||
$orderFormDatas[$this->_model->getTitleField()] = $this->_viewDatas['fieldDatas'][$this->_model->getTitleField()];
|
||||
$orderFormDatas['product_uid'] = $this->_viewDatas['fieldDatas']['product_uid'];
|
||||
$orderFormDatas['cost'] = $this->_viewDatas['fieldDatas']['price'];
|
||||
$orderFormDatas['sale'] = 0;
|
||||
$orderFormDatas['quantity'] = $this->_viewDatas['fieldDatas']['quantity'];
|
||||
$orderFormDatas['price'] = $orderFormDatas['cost'] * $orderFormDatas['quantity'];
|
||||
$this->_viewDatas['fieldDatas'] = $orderFormDatas;
|
||||
// echo var_export($this->_viewDatas['fieldDatas']);
|
||||
// exit;
|
||||
return parent::insert_process();
|
||||
}
|
||||
|
||||
//주문(uid->product_uid)
|
||||
public function insert()
|
||||
{
|
||||
$msg = "";
|
||||
try {
|
||||
$this->_viewDatas = $this->init(__FUNCTION__);
|
||||
//Transaction 시작
|
||||
$this->_model->transStart();
|
||||
//장바구니정보 검증
|
||||
$this->insert_validate();
|
||||
//상품정보 가져오기
|
||||
@ -81,12 +97,13 @@ class CartController extends OrderController
|
||||
if ($price != $this->_viewDatas['fieldDatas']['price']) {
|
||||
throw new \Exception("실 상품금액{$price} 와 구매금액{$this->_viewDatas['fieldDatas']['price']}이 서로 다릅니다.");
|
||||
}
|
||||
// echo var_export($this->_viewDatas['fieldDatas']);
|
||||
// exit;
|
||||
//상품명을 복사해서 구매한 상품명에 넣기
|
||||
$this->_viewDatas['fieldDatas'][$this->_model->getTitleField()] = $product->getTitle();
|
||||
|
||||
//Transaction 시작
|
||||
$this->_model->transStart();
|
||||
//주문추가
|
||||
$entity = $this->_model->addCart($this->_viewDatas['fieldDatas']);
|
||||
$entity = $this->insert_process();
|
||||
//상품재고감소
|
||||
$product = $this->getProductModel()->addCart($product, $this->_viewDatas['fieldDatas']['quantity']);
|
||||
//주문정보 세션에 넣기
|
||||
@ -124,16 +141,12 @@ class CartController extends OrderController
|
||||
try {
|
||||
//주문정보 가져오기
|
||||
$entity = $this->_model->getEntity([$this->_model->getPrimaryKey() => $uid]);
|
||||
//상품정보 가져오기
|
||||
$product = $this->getProductModel()->getEntity([$this->getProductModel()->getPrimaryKey() => $entity->product_uid]);
|
||||
//Transaction 시작
|
||||
$this->_model->transStart();
|
||||
//주문취소
|
||||
if (!$this->_model->cancelCart($entity)) {
|
||||
log_message("error", __FUNCTION__ . "에서 호출:" . $this->_model->getLastQuery());
|
||||
log_message("error", implode("\n", $this->_model->errors()));
|
||||
throw new \Exception(__FUNCTION__ . " 오류 발생.\n" . var_export($this->_model->errors(), true));
|
||||
}
|
||||
//상품정보 가져오기
|
||||
$product = $this->getProductModel()->getEntity([$this->getProductModel()->getPrimaryKey() => $entity->product_uid]);
|
||||
$entity = $this->_model->modify($entity, ['status' => 'unuse']);
|
||||
//상품반환
|
||||
$product = $this->getProductModel()->cancelCart($product, $entity->quantity);
|
||||
//주문정보 세션에서 빼기
|
||||
|
||||
@ -127,27 +127,27 @@ function getFieldIndex_Row_OrderHelper($field, $entity, array $viewDatas): strin
|
||||
switch ($field) {
|
||||
case 'title':
|
||||
case 'name':
|
||||
return anchor(
|
||||
$uid = lang("{$viewDatas['className']}.label.uid") . ' : ' . str_split($entity->getPrimaryKey(), 4)[0] . '-xx-' . str_split($entity->getPrimaryKey(), 4)[1];
|
||||
$title = anchor(
|
||||
current_url() . '/view/' . $entity->getPrimaryKey() . '?category=' . $viewDatas['category']->getPrimaryKey(),
|
||||
$value,
|
||||
["target" => "_self"]
|
||||
);
|
||||
return sprintf("%s<BR>%s", $uid, $title);
|
||||
break;
|
||||
case 'status':
|
||||
if ($value == DEFAULTS['STATUS']) {
|
||||
return sprintf(
|
||||
"<div class=\"payment\">%s</div><div class=\"payment\">%s</div>",
|
||||
anchor(
|
||||
URLS['cardPayment'] . '/' . $entity->getPrimaryKey(),
|
||||
ICONS['CARD'] . " 카 드 결 제",
|
||||
["class" => "btn btn-sm btn-primary btn-circle", "style" => "color:white", "target" => "_self"]
|
||||
),
|
||||
anchor(
|
||||
URLS['depositPayment'] . '/' . $entity->getPrimaryKey(),
|
||||
ICONS['DEPOSIT'] . " 무통장입금",
|
||||
["class" => "btn btn-sm btn-info btn-circle", "style" => "color:white", "target" => "_self"]
|
||||
)
|
||||
$card = anchor(
|
||||
URLS['cardPayment'] . '/' . $entity->getPrimaryKey(),
|
||||
ICONS['CARD'] . lang("{$viewDatas['className']}.PAYMENT.CARD"),
|
||||
["class" => "btn btn-sm btn-primary btn-circle", "style" => "color:white", "target" => "_self"]
|
||||
);
|
||||
$deposit = anchor(
|
||||
URLS['depositPayment'] . '/' . $entity->getPrimaryKey(),
|
||||
ICONS['DEPOSIT'] . lang("{$viewDatas['className']}.PAYMENT.DEPOSIT"),
|
||||
["class" => "btn btn-sm btn-info btn-circle", "style" => "color:white", "target" => "_self"]
|
||||
);
|
||||
return sprintf("%s<BR>%s", $card, $deposit);
|
||||
} else {
|
||||
return getFieldView_OrderHelper($field, $entity, $viewDatas);
|
||||
}
|
||||
@ -164,11 +164,16 @@ function getFieldIndex_Row_OrderHelper_Admin($field, $entity, array $viewDatas):
|
||||
switch ($field) {
|
||||
case 'title':
|
||||
case 'name':
|
||||
return anchor(
|
||||
$uid = lang("{$viewDatas['className']}.label.uid") . ' : ' . str_split($entity->getPrimaryKey(), 4)[0] . '-xx-' . str_split($entity->getPrimaryKey(), 4)[1];
|
||||
$title = anchor(
|
||||
current_url() . '/view/' . $entity->getPrimaryKey(),
|
||||
$value,
|
||||
["target" => "_self"]
|
||||
);
|
||||
return sprintf("%s<BR>%s", $uid, $title);
|
||||
break;
|
||||
case 'user_uid':
|
||||
return getFieldView_OrderHelper($field, $entity, $viewDatas);
|
||||
break;
|
||||
default:
|
||||
if (in_array($field, $viewDatas['fieldFilters'])) {
|
||||
|
||||
9
app/Language/ko/Cart.php
Normal file
9
app/Language/ko/Cart.php
Normal file
@ -0,0 +1,9 @@
|
||||
<?php
|
||||
return [
|
||||
'title' => "장바구니",
|
||||
'label' => [
|
||||
'product_uid' => '상품번호',
|
||||
'quantity' => '구매수량',
|
||||
'price' => '구매금액',
|
||||
],
|
||||
];
|
||||
@ -2,7 +2,7 @@
|
||||
return [
|
||||
'title' => "주문 정보",
|
||||
'label' => [
|
||||
'uid' => "주문ID",
|
||||
'uid' => "주문번호",
|
||||
'product_uid' => "상품정보",
|
||||
'sess_id' => "세션ID",
|
||||
'user_uid' => "사용자정보",
|
||||
@ -22,5 +22,9 @@ return [
|
||||
"Deposit" => "무통장입금",
|
||||
"Card" => "카드결제",
|
||||
"paid" => "결제완료"
|
||||
],
|
||||
"PAYMENT" => [
|
||||
'CARD' => " 카 드 결 제",
|
||||
'DEPOSIT' => " 무통장입금",
|
||||
]
|
||||
];
|
||||
|
||||
@ -268,13 +268,9 @@ abstract class BaseModel extends Model
|
||||
$this->where("created_at <=", $end);
|
||||
}
|
||||
}
|
||||
public function setIndexOrderBy(?string $field, ?string $order)
|
||||
public function setIndexOrderBy(string $field, string $order)
|
||||
{
|
||||
if ($this->useAutoIncrement) {
|
||||
$this->orderBy($field ?: $this->primaryKey, $order ?: "DESC");
|
||||
} else {
|
||||
$this->orderBy($field ?: "created_at", $order ?: "DESC");
|
||||
}
|
||||
$this->orderBy($field, $order);
|
||||
}
|
||||
final public function setCondition(array $filterFields, $word, $start, $end, $order_field, $order_value)
|
||||
{
|
||||
|
||||
@ -84,24 +84,4 @@ class OrderModel extends BaseModel
|
||||
$this->orLike($this->getTitleField(), $word, "both");
|
||||
}
|
||||
}
|
||||
|
||||
//장바구니에 넣기
|
||||
public function addCart(array $formDatas): OrderEntity
|
||||
{
|
||||
$orderFormDatas = [];
|
||||
$orderFormDatas[$this->getTitleField()] = $formDatas[$this->getTitleField()];
|
||||
$orderFormDatas['product_uid'] = $formDatas['product_uid'];
|
||||
$orderFormDatas['cost'] = $formDatas['price'];
|
||||
$orderFormDatas['sale'] = 0;
|
||||
$orderFormDatas['quantity'] = $formDatas['quantity'];
|
||||
$orderFormDatas['price'] = ($orderFormDatas['cost'] - $orderFormDatas['sale']) * $orderFormDatas['quantity'];
|
||||
// echo var_export($orderFormDatas);
|
||||
// exit;
|
||||
return $this->create_process(new OrderEntity(), $orderFormDatas);
|
||||
}
|
||||
//장바구니에 빼기
|
||||
public function cancelCart(OrderEntity $entity)
|
||||
{
|
||||
return $this->delete($entity->getPrimaryKey());
|
||||
}
|
||||
}
|
||||
|
||||
@ -114,19 +114,21 @@ class ProductModel extends BaseModel
|
||||
//장바구니에 넣기(재고수량빼기)
|
||||
final public function addCart(ProductEntity $entity, int $quantity): ProductEntity
|
||||
{
|
||||
$formDatas = array();
|
||||
if ($entity->stock == $quantity) {
|
||||
$entity->status = self::STATUS_OUTOFSTOCK;
|
||||
$formDatas['status'] = self::STATUS_OUTOFSTOCK;
|
||||
}
|
||||
$entity->stock -= $quantity;
|
||||
return $this->save_process($entity);
|
||||
$formDatas['stock'] = $entity->stock - $quantity;
|
||||
return $this->modify($entity, $formDatas);
|
||||
}
|
||||
//장바구니에 빼기(재고수량더하기)
|
||||
public function cancelCart(ProductEntity $entity, int $quantity)
|
||||
{
|
||||
$formDatas = array();
|
||||
if ($entity->status == self::STATUS_OUTOFSTOCK) {
|
||||
$entity->status = DEFAULTS['STATUS'];
|
||||
$formDatas['status'] = DEFAULTS['STATUS'];
|
||||
}
|
||||
$entity->stock += $quantity;
|
||||
return $this->save_process($entity);
|
||||
$formDatas['stock'] = $entity->stock + $quantity;
|
||||
return $this->modify($entity, $formDatas);
|
||||
}
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue
Block a user