vorst.ru - Пример работы расширения для загрузки фотографий
Статьи из рубрики root

Как написать unique валидатор

Пример валидатора для серверной и клиентской частей

Есть таблица цен на номера в пансионате. Цена зависит от различных параметров - номера, типа ценника, типа питания, варианта размещения, наличия или отсутствия лечения. Цена, для определенной комбинации значений этих параметров, может быть только одна.

Нужно записать правило проверки уникальности комбинации атрибутов как для обычной формы так и для ее модального варианта.


Интерфейс для полнотекстового поиска

Использование ElasticSearch во frontend

На создание ElasticSearch индекса понадобилось совсем не много усилий, как видно из предыдущей статьи. Чтобы сделать индекс доступным конечному пользователю, усилий понадобиться не многим больше.

Нам нужна форма ввода, нужно немного подправить действие контроллера для ее обработки и получения результатов и представление, чтобы отображать форму.


Как создать индекс ElasticSearch

Полнотекстовый поиск

Один парень написал: "Нужно сделать поиск слов в таблице "articles" по столбцу "content". В результатах поиска сначала выводить те, которые содержат наибольшее количество слов в статье и далее по мере уменьшения."

Мысль летит) Но ясно, что нужен полнотекстовый поиск.


Рефакторинг кода авторизации

Использование аккаунта социальной сети для авторизации

Авторизация с помощью социальной сети не должна зависеть от типа аккаунта. В предыдущем посте используется код, где в конструкторе классa common/components/SocialContact.php выполняется оператор switch. При добавлении обработчика для новой социальной сети, придется дописывать код, при этом меняя класс.

Перепишем конструктор так, чтобы класс не нужно было менять и он не зависел от типов социальных сетей.


Как подключить авторизацию через аккаунт

OAuth2 авторизация с использованием аккаунта

Допустим, что вы уже зарегистрированы в известной социальной сети. То есть вы уже сообщили о себе, все, что считали нужным. Очевидно вам не хочется проходить процедуру еще раз на другом ресурсе.


Модерация и вывод комментариев

Ответ на комментарии и рекурсивный вывод

На сайте оставили комментарий, вы ответили. Оппонент что-то еще уточнил, вы опять ответили. Цепочка из нескольких вопросов/ответов, которую нужно представить в виде лестницы.

Отступы можно выводить в обычном цикле, но если отступы формируются с помощью блочных элементов и css, то проще использовать рекурсию.


Модуль для управления блогом

Блог включает управление комментариями, пользователями, rbac

Новости, сообщения, описания - это все статьи, а статьи - это блог. Блог является важной составляющей любого сайта.

Блог настолько важен, что самая популярная CMS на планете WordPress - это блог.

Во фреймворке блог пишется самостоятельно или используется готовый модуль. Или сначала пишется самостоятельно, а потом переписывается как модуль.


Как написать виджет для WordPress

Пример виджета для WordPress

Иногда производители предоставляют возможность покупателю самостоятельно выбрать на сайте комплектацию товара. В этом случае, при разработке сайта, нужно предусмотреть возможность показа текущей цены на видном месте (demo).

В WordPress для подобных задач используется область виджетов. Как писать виджет в WordPress подробно написано в кодексе. Но всегда есть нюансы.


Как написать short-code для WordPress

Пример написания short-code для WordPress

На сайте магазина нужно, чтобы пользователь мог, выбирать комплектацию товара отвечая на вопросы. Вопросы должны сопровождаться наглядными картинками.

Должна быть возможность легко размещать такой вопросник в статье или на странице блога WordPress. Об этом была речь в предыдущем посте.


Как написать плагин для WordPress

Плагин для WordPress подсчета цены по компонентам

Любой товар состоит из элементов. Довольно часто производитель, поставив задачу написать электронный магазин, позволяет выбирать комплектацию заранее, до производства. Выбирая комплектующие есть возможность сэкономить или наоборот, согласиться с утверждением "Я этого достоин(а)" и заказать по полной.

Например можно представить пиццерию, где в меню указана стоимость составляющих - лепешка, сыр трех сортов, помидоры двух сортов, колбаса 5 видов. Комбинируете вы сами и постоянно видите, как ваш выбор отражается на цене.

Но это отвлеченный пример, а был конкретный - Demo, Plugin.


Как определить правило для RBAC

Выполнять действие или нет

В предыдущей статье были определены две роли - Админ и Автор, как в обычном блоге. А обычно блог используется при создании любого сайта. Для ролей Админ и Автор были определены разрешения.

Если вы Админ, то у вас есть общее разрешение create. Оно дает право добавлять данные к любым моделям. Если вы Автор, то такое разрешение давать не стоит. Автор не может, например, добавить новую рубрику.


Определение разрешений на доступ и ролей для пользователей

Задание доступа только к определенным действиям

Разработка бекенда сайта часто подразумевает ограничение прав при редактировании контента.

Ролевая модель имеет иерархию. Сначала прав не много, потом чуть больше, наконец доступно все. Права (или разрешения) - это константы, которые связаны с конкретной ролью. Если за ролью закреплено разрешение, то действие может быть выполнено.


Как подключить RBAC

Подключение ролевого доступа

В большом количестве задач необходимо в backend-части приложения разрешать одним группам пользователей выполнять только определенные действия. Другим может быть разрешено чуть больше. И так далее, до админа.

Именно распределение прав для групп пользователей и будет рассмотрено в паре-тройке статей. В качестве примера будет использоваться всего две роли.


Как отсортировать картинки мышкой

Сортировка строк мышкой

Василий оставил комментарий в конце января: "Напишите, пожалуйста, статью, как массово загружать изображения через ajax с возможностью сортировки перетаскиванием."

Речь о расширении yii2-byone-uploader, которое может загружать, сжимать, обрезать картинки для любой модели. Я писал о нем уже пару раз.

На тот момент этой функциональности не было. Собирался я долго. Но вот, наконец добавил требуемое. Теперь спешу написать несколько слов о процессе. Демо (при редактировании).


Как подключить кеширование

Ускорение работы сайта с помощью кеширования

Содержание конкретной страницы, как правило, требует предварительной подготовки. Например, в посте присутствует сразу текст на русском и на английском языке, как было предложено ранее. В этом случае нужна предварительная обработка, чтобы на экране отображался только текст на текущем языке.

Если текст поста меняется редко, желательно выполнять работу по подготовке страниц в "первый" просмотр и затем выводить уже готовые страницы.


Пример написания WordPress плагина для недвижимости

WordPress плагин для агентств недвижимости

Привлекательность WordPress в большом количестве тем оформления. Иллюзия легкости, с которой можно поменять тему, не дает покоя разработчикам. Сейчас на WordPress работают даже магазины.

Чтобы разобраться, как это возможно, я решил написать плагин для агенств недвижимости. Расширять структуру данных не хотелось - это уже будет не WordPress. Решил сохранять JSON-определения объектов недвижимости в поле post_content и преобразовывать эти определения "на лету" - Demo, GitHub


Пример работы с amoCRM

Как получить данные из amoCRM

Заказчик попросил вывести данные о сделках в таблицу в формате CSV. Данные должны быть максимально полными.

В том числе, необходимо вывести все возможные этапы сделки и даты, когда сделка переходила с этапа на этап. В amoCRM предусмотрена возможность определять этапы для каждой воронки продаж. Необходимо было, чтобы учитывались все этапы, всех воронок.

Ну и прочее - кто, когда, с кем, контакты клиента и, наконец, все комментарии к сделке.


Как определить и вызвать событие

Пример события

События бывают разные. Например, привезли хлеб и все, у кого он закончился, потянулись в магазин. То есть выполнили одно и тоже ответное действие. Выдали зарплату и все, естественно, тратят ее по разному.

В первом случае обработчик события один, во-втором их несколько. Но принцип один - наступило событие, надо действовать.


Пример загрузки контента без перезагрузки страницы

Динамическая загрузка контента

Блог - это лента из заголовков статей и нескольких строчек из них. Пусть так и останется, когда посетитель решит прочитать содержимое выбранной статьи. То есть вся лента останется и добавится контент выбранной статьи.


Пример работы с сессией

Если читатель хочет вспомнить, что просмотрено и прочитано

В магазинах это давно норма. Все, что вы просмотрели, у вас перед глазами. Почему бы не сделать тоже самое для блога - вывести заголовки просмотренных постов и время, которое потрачено на листание и чтение каждого поста.



Поиск



Как сделать галерею фотографий "До и После"

Показ фотографий до и после момента времени

Представьте, что вы продаете курс похудания. Вам нужно наглядно представить результат вашего курса. Фото "До" и "После", что может быть лучшей иллюстрацией?

Как и в предыдущем примере примем, что участников ограниченное количество. Например 4. Забудем про похудающих - слишком скучно. Будем "работать" с кинозвездами. Для каждого можно загрузить только 4 фотографии. Таким образом всего 16 фото. Если загружены все 16 и кому-то захочется добавить "свои" фото, то придется что-то удалить. Демо.


    Поделиться

Опять будем использовать расширение yii-byone-uploader. Это расширение хранит все файлы в одной модели и модель имеет поле defs в котором могут храниться json определения любых переменных.

По умолчаниюю доступно поле description, но можно добавить любое другое. Например when со значениями - 0 ("До"), 1 ("После").

Модель

Подключение поведения такое же, как в предыдущем примере. Фото, однако, квадратное.

А отличие sample\models\Stout.php в том, что необходимо найти, среди фото, принадлежащих модели, фотографии "До" и "После".

<?php
namespace sample\models;
use yii\helpers\Html;
use yii\base\Model;
use sergmoro1\uploader\FilePath;
use sergmoro1\uploader\models\OneFile;
class Stout extends Model
{
  const BEFORE = 0;
  const AFTER = 1;
  public $id;
  public $name;
  public $sizes = [
    'original' => ['width' => 600, 'height' => 600, 'catalog' => 'original'],
    'main' => ['width' => 240, 'height' => 240, 'catalog' => ''],
    'thumb' => ['width' => 90, 'height' => 90, 'catalog' => 'thumb'],
  ];
  public function behaviors()
  {
    return [
      'FilePath' => [
        'class' => FilePath::className(),
        'file_path' => '/files/stout/',
      ]
    ];
  }
  public function findOne($id)
  {
    return new Stout(['id' => $id]);
  }
  public function getFiles()
  {
    return OneFile::find()
      ->where('parent_id=:parent_id AND model=:model', [
        ':parent_id' => $this->id,
        ':model' => 'sample\models\Stout',
      ])
      ->all();
  }
  private function getMainImage($when)
  {
    $image = false;
    foreach($this->files as $i => $file)
      if($file->vars->when == $when)
      {
        $image = $this->getImage('', $i);
        break;
      }
      return $image;
  }
  public function getBefore()
  {
    return $this->getMainImage(self::BEFORE);
  }
  public function getAfter()
  {
    return $this->getMainImage(self::AFTER);
  }
}

Сделано это простым перебором среди всех, принадлежащих модели, файлов.

Контроллер

Действия всего два и они не отличаются от действий предыдущего примера. Несколько "странноватый" вид метода getModel обусловлен тем, что модель - это массив, а не объект, как обычно.

<?php
namespace sample\controllers;
use Yii;
use yii\web\Controller;
use yii\data\ArrayDataProvider;
use sample\models\Stout;
class StoutController extends Controller
{
  public $models = [
    ['id' => 1, 'name' => 'Jean-Paul Belmondo'],
    ['id' => 2, 'name' => 'Claudia Cardinale'],
    ['id' => 3, 'name' => 'Monica Bellucci'],
    ['id' => 4, 'name' => 'Adriano Celentano'],
  ];
  public $_model;
  public function actionIndex()
  {
    $dataProvider = new ArrayDataProvider([
      'models' => $this->models,
    ]);
    return $this->render('index', [
      'dataProvider' => $dataProvider,
    ]);
  }
  public function actionUpdate($id)
  {
    return $this->render('update', [
      'model' => $this->getModel($id),
    ]);
  }
  public function getModel($id)
  {
    if($this->_model === null)
    {
      $model = $this->models[$id - 1];
      $this->_model = new Stout([
        'id' => $model['id'], 
        'name' => $model['name'],
      ]);
    }
    return $this->_model;
  }
}

Представление

sample\views\stout\index.php проще не куда.

<?php
use yii\widgets\ListView;
?>
<?= ListView::widget([
  'dataProvider' => $dataProvider,
  'layout' => "{items}",
  'itemView' => '_stout',
]); ?>

Вся магия в sample\views\stout\_stout.php. Но эффекты не так важны и их описание мы опустим. Главное, как выводятся фотографии

<div class='col-sm-6'>
  <div class='photo-block'>
    <div class='photo-column pull-left'>
      <div class='mark'>before</div>
        <?= ($image = $model->getBefore())
          ? Html::img($image, ['class'=>'grow'])
          : '<i class="fa fa-3x fa-user"></i>'
        ?>
      </div>
      <div class='photo-column pull-left'>
        <div class='mark'>after</div>
          <?= ($image = $model->getAfter())
            ? Html::img($image, ['class'=>'grow'])
            : '<i class="fa fa-3x fa-user"></i>'
          ?>
      </div>
      <div class='footer'>
        <?= $model->name ?>
      </div>
  </div>
  <p class='text-center'>
    <?= Html::a(\Yii::t('app', 'Update'), ['update', 'id' => $model->id]) ?>
  </p>
</div>

и как вводятся sample\views\stout\update.php.

<?php
use sergmoro1\uploader\widgets\Byone;
?>
<?= Byone::widget([
  'model' => $model,
  'secure' => false,
  'minFileSize' => 0.02,
  'maxFiles' => 4,
  'appendixView' => '/stout/appendix',
  'cropAllowed' => true,
]) ?>

Все! Если предположить, что значение поля when определяется средствами расширения, то можно считать, что алгоритм вывода фотографий "До" и "После" ясен и пора посмотреть, что получилось. Демо.

Заключение

Использовать расширение yii-byone-uploader просто. Можно добавлять дополнительные поля данных, не меняя модели. Как было добавлено поле when можно узнать в следующей статье.

Leave a comment

Only authorized users can leave comments. Please log in or pass a registration.