Задать вопрос
  • Как лучше организовать сущности в Doctrine?

    @Flying
    Если список типов у вас статический - замените EntryType на наследуемые entities через discriminator map, количество запосов это не снизит, но снизит количество join'ов и таблиц. Вот здесь можно подробнее почитать про него на русском.

    А вообще судя по задаче у вас основная работа идёт не на уровне строк таблиц, а на уровне их анализа, Doctrine в этом случае - не лучшее решение т.к. задача больше про построение запросов, а не про удобную работу с сильно связанными данными. Тот же Excel с этим справится гораздо лучше :)
    Ответ написан
  • Как в Symfony 4 перевести текст внутри entity?

    @Flying
    Поскольку entities по определению должны быть очень лёгкими объектами - здесь можно рассмотреть несколько вариантов решения:
    1. Наиболее корректным будет вариант использования Doctrine event listener'а который будет слушать событие postLoad и производить локализацию. Что именно и как локализовывать - можно решить несколькими путями:
      1. Дать entity самой решать как это сделать и позволить event listener'у просто передавать ей объект-переводчик (Translator в случае Symfony). Чтобы понять надо ли передавать переводчик - стоит определить отдельный интерфейс, какой-нибудь TranslatableEntityInterface
      2. Указать event listener'у что переводить, к примеру через кастомные аннотации, решение более сложное, но более гибкое

    2. Можно дать возможность entity дёргать какой-нибудь известный и доступный ей метод из которого она будет получать объект-переводчик, к примеру это может быть какой-нибудь StaticTranslatorProvider со статическим методом getTranslator(). В целом не очень хорошая идея, но работать будет
    3. Можно не трогать entities вообще, а запрашивать локализацию непосредственно во внешнем коде. В целом плохой вариант, но тоже возможный
    Ответ написан
    Комментировать
  • Как в Symfony 4 отобразить роуты для frontend разработчика?

    @Flying
    php -f bin/console -- debug:router
    Ответ написан
    Комментировать
  • Как сделать такой Range slider?

    @Flying
    Посмотрите на noUiSlider, он (как следует из названия) весьма хорошо кастомизируется, обладает богатым функционалом и не имеет ненужных зависимостей.
    Ответ написан
    Комментировать
  • Ноутбук для дизайнера в пределах 1500$?

    @Flying
    В своём описании вы не указали работаете ли вы только на ноутбуке или планируете использовать отдельный монитор, а ноутбук - в качестве второго экрана. Это важно т.к. в случае использования отдельного монитора (а для дизайнера это явно лучший выбор) существенно снижаются требования по качеству экрана самого ноутбука, а именно в нём в вашем случае будет основная загвоздка: для профессиональной работы с цветом вам необходим экран c покрытием sRGB максимально близким к 100% + возможность откалибровать экран ноутбука. Это решаемые задачи, но с отдельными мониторами эти задачи решаются существенно проще, да и работать с макетами (особенно широкоформатными) вам будет в этом случае намного комфортнее.

    Если же вы предпочитаете работать исключительно на ноутбуке - вы не указали предпочтения по диагонали экрана и критичности для вас наличия hi dpi экрана (т.е. достаточно ли для вас разрешения 1920x1080 или же необходимо иметь 2560x1440 / 3840x2160).

    В остальном я бы предложил вам обращать внимание на следующие моменты:
    • дискретная видеокарта т.к. тот же Photoshop в новых версиях весьма интенсивно использует для работы видеокарту, а в случае встроенной вы будете отдавать для этих задач общую память что снижает эффективность работы. Посмотрите вот эту статью Adobe на предмет требований и списка совместимых карт.
    • память - от 16Gb + возможность расширения (свободные слоты). Последние чипсеты поддерживают в некоторых моделях и до 64Gb, но такие модели стоят недёшево. До 32 Gb вполне поддерживают и чипсеты 3-4 летней давности
    • память + быстрый SSD в вашем случае скорее всего будет важнее чем топовый процессор т.к. вы не занимаетесь 3D рендером, так что обращайте внимание на количество / расширяемость памяти и объём / скорость SSD диска. По поводу скорости - стоит смотреть review предварительно отобранных вами кандидатов, например на notebookcheck. Не забывайте что если есть вариант взять подходящий вам по остальным параметрам ноутбук, но с HDD - можно взять его и поменять HDD на SSD


    Возможности расширяемости конфигурации обычно предоставляют "профессиональные" линейки ноутбуков (то что называют Mobile Workstations, к примеру Lenovo ThinkPad P series, Dell Precision и т.п.), но они как правило не соответствуют вашему требованию о "лаконичном дизайне" которому соответствуют лёгкие ноутбуки типа Dell XPS, но в них о расширяемости конфигурации речь уже не идёт, только если подбирать подходящий по параметрам. Поэтому вам стоит определиться какой из аспектов для вас важнее - это даст подсказку в каких линейках искать кандидатов. Затем выбираете shortlist по тому же Яндекс.Маркет и идёте читать обзоры по ним на Notebookcheck или другой подобный ресурс. Финально, если есть возможность, потом идёте в магазин чтобы пощупать выбранные варианты вживую и тогда принимаете решение.

    Успехов!
    Ответ написан
    8 комментариев
  • Как работает подход Unit of Work?

    @Flying
    Unit of Work - это паттерн определяющий логическую транзакцию т.е. атомарную синхронизацию изменений в объектах, помещённых в объект UoW с хранилищем (базой данных).

    Если обратиться к исходному описанию этого паттерна у Мартина Фаулера - то видно что объект, реализующий этот паттерн отвечает за накопление информации о том какие объекты входят в транзакцию и каковы их изменния относительно исходных значений в хранилище. Основная работа производится в методе commit() который отвечает за вычисление изменений в сохранённых в UoW объектах и синхронизацию этих изменений с хранилищем (базой данных).

    Паттерн Unit of Work как правило не является полностью самостоятельным, он обычно тесно связан с паттерном Identity Map, задача которого - сохранение карты созданных объектов, взятых из хранилища с тем чтобы гарантировать что одна единица информации из хранилища представлена ровно одним экземпляром объекта данных в приложении. Это позволяет избежать конфликтов изменений т.к. не допускает ситуации когда два объекта, представляющих один и тот же элемент данных в хранилище, изменены по-разному. Информация из Identity Map используется в методе commit() паттерна Unit of Work для вычисления разницы между исходными данными и накопленными изменениями.

    Поскольку для вычисления разницы (и, соответственно, определения того что и каким образом должно быть изменено в хранилище) необходимо знать какие данные и как именно хранятся в объектах - как правило необходима также реализация паттерна Metadata Mapping, описывающего связь между содержимым хранилища (к примеру таблицами и столбцами базы данных) и классами / свойствами объектов.

    Также, если данные в хранилище не являются независимыми (к примеру связи между таблицами в базе данных) - может потребоваться реализации ряда паттернов, отвечающих за сохранение информации о связях между данными (это паттерны раздела Object-Relational Structural Patterns в каталоге паттернов).

    Подводя итог: сам по себе Unit of Work довольно прост в своём внешнем интерфейсе, но реализация его корректной работы требует предоставления множества дополнительных данных, поэтому миниатюрных примеров привести не могу.

    Если говорить о PHP - то лучшей реализацией этих паттернов на PHP безусловно является Doctrine ORM. В частности в разделе Working with Objects документации Doctrine можно найти хорошее описание и множество примеров использования паттернов, описанных выше.
    Ответ написан
    6 комментариев
  • Пройтись по строке и если есть одинаковый символ, exit?

    @Flying
    К примеру эта задача вполне себе решается через регулярное выражение, можно проверить здесь.
    Ответ написан
    1 комментарий
  • Как укоротить регулярное выражение?

    @Flying
    $subject = "23456/10000";
    echo preg_replace('/^(\d{2})(\d{2})/','\1.\2',$subject);
    Ответ написан
  • Как в Doctrine сделать one-to-many с коллекцией?

    @Flying
    У вас потенциально две ошибки в приведённом коде:

    1. В качестве возвращаемоног типа вы указываете \Collection, тогда как коллекции Doctrine - это \Doctrine\Common\Collections\Collection
    2. Ваш код не создаёт эту коллекцию, соответственно если это не entity созданная самой Doctrine при загрузке данных из базы - значение $meta - null. Корректный подход - это либо инициализировать коллекции в конструкторе:
    public function __construct() {
      $this->meta = new ArrayCollection(); // где ArrayCollection это \Doctrine\Common\Collections\ArrayCollection
    }

    либо непосредственно в методе:
    public function getMeta() : Collection
    {
        if (!$this->meta) {
            $this->meta = new ArrayCollection();
        }
        return $this->meta;
    }
    Ответ написан
    Комментировать
  • Красивый lightbox для фото и видео?

    @Flying
    Если использование jQuery разрешено - могу рекомендовать Magnific Popup
    Ответ написан
    Комментировать
  • Асинхронные процессы PHP?

    @Flying
    По сути в данном сценарии можно обойтись гораздо более простым решением: по крону запускать скрипт который будет отправлять все запросы на внутренний сервер с передачей нужных параметров в get/post. Внутренний сервер - nginx + php-fpm которые в связке прекрасно умеют и асинхронность и менеджмент процессов и всё остальное. Дальше по необходимости возможно придётся подстроить параметры количества worker'ов.
    Ответ написан
    Комментировать
  • Запуск анимации только когда человек доскролил?

    @Flying
    В современных браузерах задача решается нативно через IntersectionObserver, для более старых есть polyfill.
    Ответ написан
    Комментировать
  • Какой стек для верстальщика более актуальный?

    @Flying
    Если соберётесь изучить sass - то для сеток там есть, например, susy, с её помощью можно ваять вообще произвольные сетки, в том числе нерегулярные, аналог сетки bootstrap'а там делается просто элементарно.

    Кроме того т.к. bootstrap 4 сам по себе написан на sass - то можно, банально, подгружать bootstrap как зависимость через npm и включать оттуда только модуль сетки без необходимости тащить в проект всё остальное.
    Ответ написан
    Комментировать
  • Есть ли способ определить что sticky элемент "активен"?

    @Flying
    Если вкратце - то средствами CSS возможности сделать это нет и не будет, по крайней мере в обозримом будущем.

    По поводу причин рекомендую почтитать вот этот ответ на SO, вот это обсуждение рабочей группы CSS и общую позицию CSS working group по этому и похожим функциям в CSS.

    Решение которое можно применить в современных браузерах - это IntersectionObserver. Поддерживается в Firefox и Chrome, для остальных есть polyfill. Здесь можно посмотреть демку, здесь - её описание.
    Ответ написан
    Комментировать
  • Как правильно собрать такую сетку через flex?

    @Flying
    Как вариант - просто использовать абсолютное позиционирование:
    .flex > .right {
      flex-basis: 32%;
      position: absolute;
      width: 32%;
      right: 0;
    }
    Ответ написан
  • Как получить удаленные из коллекции сущности Doctrine?

    @Flying
    Ответы на ваши вопросы, очевидно, кроются в исходниках Doctrine:
    Видно что поведение метода clear() зависит от того какую из сторон ассоциации вы очищаете. Также видно что если вы работаете с owner side ассоциации - то Doctrine создаёт новый snapshot.

    Из кода методов getInsertDiff и getDeleteDiff видно что вычисление разницы происходит через сравнение snapshot'а с текущим содержимым коллекци, так что очевидно что в случае создания нового snapshot'а разница будет пустым массивом.

    Проверить, вызывает ли сама Symfony метод clear() проще всего, поставив там точку останова.
    Ответ написан
    3 комментария
  • Инструмент для генерации css-селекторов из файла html?

    @Flying
    Сделать это несложно на самом деле, достаточно использовать любой HTML парсер, их много. Другое дело что полученный результат придётся разбирать, отфильтровывая то что вам в реальности не нужно (причём вручную) и этот процесс почти наверняка займёт больше времени чем написание нужных вам селекторов вручную.

    Также не забывайте что:
    1. CSS селекторы - это далеко не только id и class name, они намного гибче, а самые интересные варианты вы таким образом не автоматизируете
    2. Современные IDE, к примеру те же продукты JetBrains хорошо умеют, понимая контекст, давать хороший автокомплит для CSS селекторов по структуре HTML, поэтому ваша задача там уже решена, только намного эффективнее
    Ответ написан
    3 комментария