Finish beforeAction

This commit is contained in:
Roland Schneider 2016-01-16 19:02:38 +01:00
commit afb79cafb8
8 changed files with 104 additions and 8 deletions

View File

@ -194,6 +194,8 @@ class AccountState extends \common\models\BaseFitnessActiveRecord
* Read last accountstates * Read last accountstates
* @param $type int the type of accountstate to load * @param $type int the type of accountstate to load
* @param $user $id of user to load the account * @param $user $id of user to load the account
* @return common\models\AccountState
*
* */ * */
public static function readLast($type, $user = null,$account = null){ public static function readLast($type, $user = null,$account = null){
$result = null; $result = null;
@ -202,10 +204,14 @@ class AccountState extends \common\models\BaseFitnessActiveRecord
if ( isset($type)){ if ( isset($type)){
$query->andWhere(['account_state.type' => $type]); $query->andWhere(['account_state.type' => $type]);
} }
if ( $account ){ if ( isset( $account ) ){
$query->andWhere(["account_state.id_account" => $account ]); $query->andWhere(["account_state.id_account" => $account ]);
} }
if ( isset( $user ) ){
$query->andWhere(["account_state.id_user" => $user ]);
}
$query->limit(1); $query->limit(1);
$query->orderBy(['created_at' => SORT_DESC]); $query->orderBy(['created_at' => SORT_DESC]);

View File

@ -48,12 +48,14 @@ class Product extends \common\models\BaseFitnessActiveRecord {
[['product_number', 'barcode'], 'string', 'max' => 20], [['product_number', 'barcode'], 'string', 'max' => 20],
[['name'], 'string', 'max' => 128], [['name'], 'string', 'max' => 128],
[['description'], 'string', 'max' => 255], [['description'], 'string', 'max' => 255],
[['product_number'], 'unique' ], // [['product_number'], 'unique' ],
[['barcode'], 'unique' ], // [['barcode'], 'unique' ],
// a1 and a2 need to be unique together, only a1 will receive error message // a1 and a2 need to be unique together, only a1 will receive error message
// ['a1', 'unique', 'targetAttribute' => ['a1', 'a2']] // ['a1', 'unique', 'targetAttribute' => ['a1', 'a2']]
[['barcode','product_number'], 'filter', 'filter' => function($value){return Helper::fixAsciiChars($value);}],
['barcode', 'unique', 'targetAttribute' => ['id_account', 'barcode']], ['barcode', 'unique', 'targetAttribute' => ['id_account', 'barcode']],
['product_number', 'unique', 'targetAttribute' => ['id_account', 'product_number']], ['product_number', 'unique', 'targetAttribute' => ['id_account', 'product_number']],
]; ];
} }

View File

@ -165,10 +165,11 @@ class Ticket extends \common\models\BaseFitnessActiveRecord
$query = Ticket::find(); $query = Ticket::find();
$today = date('Y-m-d'); $today = date('Y-m-d');
$query->andWhere(['id_card' => $card->id_card]); $query->andWhere(['ticket.id_card' => $card->id_card]);
$query->andWhere( 'start <= :today' ,[ 'today' => $today] ); $query->andWhere( 'ticket.start <= :today' ,[ 'today' => $today] );
$query->andWhere( 'end >= :today' ,[ 'today' => $today] ); $query->andWhere( 'ticket.end >= :today' ,[ 'today' => $today] );
$query->orderBy([ "created_at" =>SORT_DESC] ); $query->andWhere( 'ticket.status = :status' ,[ 'status' => Ticket::STATUS_ACTIVE] );
$query->orderBy([ "ticket.created_at" =>SORT_DESC] );
$result = $query->all(); $result = $query->all();
return $result; return $result;

View File

@ -0,0 +1,37 @@
<?php
namespace frontend\components;
use yii\base\Behavior;
use yii\web\Controller;
use common\models\Account;
use common\models\AccountState;
class CassaOpenBehavior extends Behavior
{
// ...
public function events()
{
return [
Controller::EVENT_BEFORE_ACTION => 'validateCassaOpen',
];
}
public function validateCassaOpen($event){
$cassaOpen = AccountState::readLast(null, null, Account::readDefault() );
if ( !isset($cassaOpen) ){
return $this->redirectToCassaOpen($event);
}else if ( !$cassaOpen->isTypeOpen() ){
return $this->redirectToCassaOpen($event);
}
}
protected function redirectToCassaOpen($event ) {
\Yii::$app->session->setFlash ( 'error', 'Nem nyitottál kasszát!');
$this->owner->redirect([ 'account-state/open' ]);
$event->isValid = false;
$event->handled = true;
}
}

View File

@ -0,0 +1,31 @@
<?php
namespace frontend\components;
use yii\base\Behavior;
use yii\web\Controller;
use common\models\Account;
class DefaultAccountBehavior extends Behavior
{
// ...
public function events()
{
return [
Controller::EVENT_BEFORE_ACTION => 'validateDefaultAccount',
];
}
public function validateDefaultAccount($event){
echo "deafult";
$account = Account::readDefault();
if ( !isset($account) ){
$this->owner->redirect([ 'account/select' ]);
\Yii::$app->session->setFlash ( 'error', 'Válassz kasszát!!');
$event->isValid = false;
$event->handled = true;
return false;
}
}
}

View File

@ -74,6 +74,8 @@ class AccountStateController extends Controller {
$lastStates = AccountState::readLastForUser ( AccountState::TYPE_CLOSE ); $lastStates = AccountState::readLastForUser ( AccountState::TYPE_CLOSE );
$lastStates = AccountState::modelsToArray ( $lastStates ); $lastStates = AccountState::modelsToArray ( $lastStates );
// \Yii::$app->session->setFlash('error','ok');
$model = new AccountState (); $model = new AccountState ();
$model->type = AccountState::TYPE_OPEN; $model->type = AccountState::TYPE_OPEN;
$model->id_user = Yii::$app->user->id; $model->id_user = Yii::$app->user->id;

View File

@ -24,6 +24,8 @@ use common\models\ShoppingCart;
use frontend\models\ReceptionForm; use frontend\models\ReceptionForm;
use frontend\models\CustomerCartPayoutForm; use frontend\models\CustomerCartPayoutForm;
use frontend\models\UserCartPayoutForm; use frontend\models\UserCartPayoutForm;
use frontend\components\DefaultAccountBehavior;
use frontend\components\CassaOpenBehavior;
/** /**
* ProductController implements the CRUD actions for Product model. * ProductController implements the CRUD actions for Product model.
@ -61,7 +63,14 @@ class ProductController extends Controller {
] ]
// everything else is denied // everything else is denied
] ] ,
// named behavior, configuration array
'defaultAccount' => [
'class' => DefaultAccountBehavior::className(),
],
'cassaIsOpen' => [
'class' => CassaOpenBehavior::className(),
],
]; ];
} }
public function actionSale($number = null) { public function actionSale($number = null) {

View File

@ -19,6 +19,8 @@ use common\models\User;
use common\models\ShoppingCart; use common\models\ShoppingCart;
use common\models\UserSoldItem; use common\models\UserSoldItem;
use frontend\components\FrontendController; use frontend\components\FrontendController;
use frontend\components\DefaultAccountBehavior;
use frontend\components\CassaOpenBehavior;
/** /**
* TicketController implements the CRUD actions for Ticket model. * TicketController implements the CRUD actions for Ticket model.
@ -46,6 +48,12 @@ class TicketController extends FrontendController
// everything else is denied // everything else is denied
], ],
], ],
'defaultAccount' => [
'class' => DefaultAccountBehavior::className(),
],
'cassaIsOpen' => [
'class' => CassaOpenBehavior::className(),
],
]; ];
} }