[ 'class' => VerbFilter::className(), 'actions' => [ 'delete' => ['post'], ], ], 'access' => [ 'class' => \yii\filters\AccessControl::className(), 'only' => [ 'sale','clear-list', 'lookup'], 'rules' => [ // allow authenticated users [ 'allow' => true, 'roles' => ['@'], ], // everything else is denied ], ], ]; } public function actionSale( $number = null){ $this->findByNumber($number); $model = new ProductSaleForm(); $lookupModel = new ProductLookupForm(); $currencies = Currency::find()->all(); $accounts = Account::readAccounts(); $discounts = Discount::read(); $user = User::findOne(Yii::$app->user->id ); if (Yii::$app->request->isAjax) { \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; $model->currencies = $currencies; $model->accounts = $accounts; $model->discounts = $discounts; $result = []; $result['code'] = 'unknown'; if ($model->load(Yii::$app->request->post()) ) { if ( $model->save()){ $result['code'] = 'success'; $result['message'] = Yii::t('common/product',"Sold: {product}" ,[ 'product' => $model->transfer->toProductSoldString() ]); }else{ $result['code'] = 'invalid'; $result['errors'] = $model->getErrors(); } } $userTransfers = Transfer::modelsToArray( Transfer::readUserSoldTransfers($user) ); $result['transfers'] = $userTransfers; return $result; }else{ // $userTransfers = Transfer::readUserSoldTransfers( $user ); $userTransfers = Transfer::modelsToArray( Transfer::readUserSoldTransfers($user) ); return $this->render("sale",[ 'customer' => $this->customer, 'card' => $this->card, 'model' => $model, 'lookupModel' =>$lookupModel, 'currencies' => $currencies, 'accounts' => $accounts, 'discounts' => $discounts, 'userTransfers' => $userTransfers ]); } } public function actionClearList(){ if (Yii::$app->request->isAjax) { $result = []; \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; $user = User::findOne(Yii::$app->user->id ); UserSoldItem::deleteAll(['id_user' => Yii::$app->user->id]); $userTransfers = Transfer::modelsToArray( Transfer::readUserSoldTransfers($user) ); $result['transfers'] = $userTransfers; $result['code'] = 'success'; return $result; } } /** */ public function actionLookup($query = null) { $result = []; $product = Product::findProduct($query); $product = Product::modelToArray($product); $result['product'] = $product; \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; return $result; } /** * Finds the Product model based on its primary key value. * If the model is not found, a 404 HTTP exception will be thrown. * @param integer $id * @return Product the loaded model * @throws NotFoundHttpException if the model cannot be found */ protected function findModel($id) { if (($model = Product::findOne($id)) !== null) { return $model; } else { throw new NotFoundHttpException('The requested page does not exist.'); } } protected function findByNumber($number){ $this->card = null; $this->customer = null; if ( $number != null ){ $this->card = Card::readCard($number); if ( $this->card != null ){ $this->customer = Customer::find()->innerJoin(Card::tableName(), "customer.id_customer_card = card.id_card")->andWhere( [ 'customer.id_customer_card' => $this->card->id_card ])->one(); } } } /** * Lists all Product models. * @return mixed */ /* public function actionIndex() { $searchModel = new ProductSearch(); $dataProvider = $searchModel->search(Yii::$app->request->queryParams); return $this->render('index', [ 'searchModel' => $searchModel, 'dataProvider' => $dataProvider, ]); } */ /** * Displays a single Product model. * @param integer $id * @return mixed */ /* public function actionView($id) { return $this->render('view', [ 'model' => $this->findModel($id), ]); } */ /** * Updates an existing Product model. * If update is successful, the browser will be redirected to the 'view' page. * @param integer $id * @return mixed */ /* public function actionUpdate($id) { $model = $this->findModel($id); if ($model->load(Yii::$app->request->post()) && $model->save()) { return $this->redirect(['view', 'id' => $model->id_product]); } else { return $this->render('update', [ 'model' => $model, ]); } } */ /** * Deletes an existing Product model. * If deletion is successful, the browser will be redirected to the 'index' page. * @param integer $id * @return mixed */ /* public function actionDelete($id) { $this->findModel($id)->delete(); return $this->redirect(['index']); } */ /** * Creates a new Product model. * If creation is successful, the browser will be redirected to the 'view' page. * @return mixed */ /* public function actionCreate() { $model = new Product(); if ($model->load(Yii::$app->request->post()) && $model->save()) { return $this->redirect(['view', 'id' => $model->id_product]); } else { return $this->render('create', [ 'model' => $model, ]); } } */ }