コード例 #1
0
 public function run()
 {
     $id = null;
     $modelClass = $this->modelClass;
     /** @var yii\db\BaseActiveRecord $model */
     $model = new $modelClass(['scenario' => $this->scenario]);
     if ($this->checkAccess) {
         call_user_func($this->checkAccess, $this->id, null, ['newModel' => $model]);
     }
     $session = Yii::$app->getSession();
     $successMessage = $session->getFlash('success');
     $errorMessage = $session->getFlash('error');
     $request = Yii::$app->getRequest();
     if ($request->getIsPost()) {
         $model->load($request->getBodyParams());
         // validation
         if ($request->getIsAjax() && $request->getQueryParam('validation')) {
             Yii::$app->getResponse()->format = Response::FORMAT_JSON;
             return ActiveForm::validate($model);
         }
         // processing
         $saved = $model->validate() && $model->save();
         if ($saved) {
             $id = ModelHelper::getPrimaryKey($model);
             $successMessage = Yii::t('mozayka', 'Record "{record}" has been successfully saved.', ['record' => ModelHelper::getDisplayField($model)]);
             if (!$request->getIsAjax()) {
                 $session->setFlash('success', $successMessage);
                 if (ModelHelper::canUpdate($model)) {
                     $url = ['update-form', 'id' => $id];
                 } elseif (ModelHelper::canRead($model)) {
                     $url = ['read-form', 'id' => $id];
                 } elseif (ModelHelper::canList($modelClass)) {
                     $url = ['list'];
                 } else {
                     $url = Yii::$app->getHomeUrl();
                 }
                 return $this->controller->redirect($url);
             }
         } else {
             ModelHelper::log($model);
             $errorMessage = Yii::t('mozayka', 'Record "{record}" has not been saved.', ['record' => ModelHelper::getDisplayField($model)]);
         }
         if ($request->getIsAjax()) {
             Yii::$app->getResponse()->format = Response::FORMAT_JSON;
             return ['ok' => $saved, 'message' => $saved ? $successMessage : $errorMessage, 'id' => $saved ? $id : false];
         }
     }
     // rendering
     $viewParams = ['canList' => ModelHelper::canList($modelClass), 'pluralHumanName' => ModelHelper::pluralHumanName($modelClass), 'successMessage' => $successMessage, 'errorMessage' => $errorMessage, 'model' => $model, 'fields' => $this->prepareFields($model), 'formClass' => $this->formClass, 'formConfig' => array_merge($this->formConfig, ['validationUrl' => [$this->id, 'validation' => 1]])];
     if ($request->getIsAjax()) {
         return $this->controller->renderPartial($this->view, $viewParams);
     } else {
         return $this->controller->render($this->view, $viewParams);
     }
 }
コード例 #2
0
 protected function renderDataCellContent($model, $key, $index)
 {
     $dropdownId = $this->grid->getId() . '-dropdown2-menu-' . $index;
     $this->template = implode(' ', array_keys(array_filter(['<li>{view}</li>' => ModelHelper::canRead($model), '<li>{update}</li>' => ModelHelper::canUpdate($model), '<li>{delete}</li>' => ModelHelper::canDelete($model)])));
     $fix = ['~(glyphicon\\-eye\\-open"\\>\\</span\\>)(\\</a\\>)~i' => '$1 ' . Yii::t('mozayka', 'View') . '$2', '~(glyphicon\\-pencil"\\>\\</span\\>)(\\</a\\>)~i' => '$1 ' . Yii::t('mozayka', 'Update') . '$2', '~(glyphicon\\-trash"\\>\\</span\\>)(\\</a\\>)~i' => '$1 ' . Yii::t('mozayka', 'Delete') . '$2', '~\\s+title\\="[^"]*"~i' => '', '~\\s+data\\-confirm\\="[^"]*"~i' => '', '~\\s+data\\-method\\="[^"]*"~i' => ''];
     $cellContent = preg_replace(array_keys($fix), array_values($fix), parent::renderDataCellContent($model, $key, $index));
     // dropdown2-menu
     if ($cellContent && $cellContent != $this->grid->emptyCell) {
         $cellContent = Html::button('<span class="glyphicon glyphicon-cog"></span>', ['title' => Yii::t('mozayka', 'Actions'), 'class' => 'btn btn-default btn-xs', 'data-dropdown2' => '#' . $dropdownId]) . Html::tag('div', Html::tag('ul', $cellContent, ['class' => 'dropdown2-menu']), ['id' => $dropdownId, 'class' => 'dropdown2 dropdown2-tip' . (array_search($this, $this->grid->columns) + 1 > count($this->grid->columns) / 2 ? ' dropdown2-anchor-right' : '')]);
     }
     return $cellContent;
 }
コード例 #3
0
 public function checkAccess($action, $model = null, $params = [])
 {
     $newModel = null;
     if (array_key_exists('newModel', $params)) {
         $newModel = $params['newModel'];
         unset($params['newModel']);
     }
     $query = null;
     if (array_key_exists('query', $params)) {
         $query = $params['query'];
         unset($params['query']);
     }
     switch ($action) {
         case 'create':
         case 'create-form':
             $allowed = ModelHelper::canCreate($this->modelClass, $params, $newModel);
             break;
         case 'view':
         case 'read-form':
             $allowed = ModelHelper::canRead($model);
             break;
         case 'update':
         case 'update-form':
             $allowed = ModelHelper::canUpdate($model);
             break;
         case 'delete':
         case 'delete-form':
             $allowed = ModelHelper::canDelete($model);
             break;
         case 'index':
         case 'list':
             $allowed = ModelHelper::canList($this->modelClass, $params, $query);
             break;
         case 'change-position':
             $allowed = ModelHelper::canChangePosition($model);
             break;
         default:
             $allowed = false;
     }
     if (!$allowed) {
         $user = Yii::$app->getUser();
         throw new ForbiddenHttpException(Yii::t('mozayka', 'Permission denied for user "{user}" to perform action "{action}".', ['user' => $user->getIsGuest() ? Yii::t('mozayka', 'Guest') : $user->getIdentity()->username, 'action' => $this->id . '/' . $action]));
     }
 }