$connection = Yii::$app->getDb(); $command = $connection->createCommand("SELECT * FROM (SELECT @r AS _id, (SELECT @r := id_parent FROM `categories` WHERE id_category = _id) AS id_parent, @l := @l + 1 AS lvl FROM (SELECT @r := $id_parent, @l := 0) vars, `categories` a WHERE @r <> 0) T1 JOIN `categories` T2 ON T1._id = T2.id_category ORDER BY T1.lvl DESC"); $result = $command->queryAll(); if (isSet($result)) { foreach ($result as $row) { $array[] = $row["id_category"]; } return $array; } else { return false; } } public static function lista($id_parent, $debug = false) {
if (isSet($result)) { foreach ($result as $row) { $array[] = $row["id_category"]; } return $array; } else { return false; } }
$request = Yii::$app->request; $pattern = ["category1", "category2", "category3", "category4"]; $values = [$category1, $category2, $category3, $category4]; $data["Routes"] = SystemRoutes::info($values, $pattern, 'categories'); $data["ID_Category"] = $data["Routes"]->record_id; $data["Levels"] = Categories::levels($data["ID_Category"]); $data["Category"] = Categories::info($data["ID_Category"]); $data["price_assortment"] = false; ProductsTechnicalData::emptyValue($request->get('price')); $data["filter_predefined"] = ProductsFilterPredefined::find()->where(['id_category' => $data["ID_Category"]])->all();
$args = $this->controller->bindActionParams($this, $params); Yii::debug('Running action: ' . get_class($this->controller) . '::' . $this->actionMethod . '()', __METHOD__); if (Yii::$app->requestedParams === null) { Yii::$app->requestedParams = $args; } return call_user_func_array([$this->controller, $this->actionMethod], $args); } }
} $result = null; if ($runAction && $this->beforeAction($action)) { // run the action $result = $action->runWithParams($params); $result = $this->afterAction($action, $result); // call afterAction on modules foreach ($modules as $module) { /* @var $module Module */
$parts = $this->createController($route); if (is_array($parts)) { /* @var $controller Controller */ list($controller, $actionID) = $parts; $oldController = Yii::$app->controller; Yii::$app->controller = $controller; $result = $controller->runAction($actionID, $params); if ($oldController !== null) { Yii::$app->controller = $oldController; } return $result; }
$params = $this->catchAll; unset($params[0]); } try { Yii::debug("Route requested: '$route'", __METHOD__); $this->requestedRoute = $route; $result = $this->runAction($route, $params); if ($result instanceof Response) { return $result; } $response = $this->getResponse(); if ($result !== null) {
{ try { $this->state = self::STATE_BEFORE_REQUEST; $this->trigger(self::EVENT_BEFORE_REQUEST); $this->state = self::STATE_HANDLING_REQUEST; $response = $this->handleRequest($this->getRequest()); $this->state = self::STATE_AFTER_REQUEST; $this->trigger(self::EVENT_AFTER_REQUEST); $this->state = self::STATE_SENDING_RESPONSE; $response->send();
require(__DIR__ . '/../../common/config/main.php'), require(__DIR__ . '/../../common/config/main-local.php'), require(__DIR__ . '/../config/main.php'), require(__DIR__ . '/../config/main-local.php') ); (new yii\web\Application($config))->run();
$_GET = [ 'category1' => 'klimatyzatory-przenosne', ]; $_SESSION = [ '__flash' => [], ];