Контакты

Наибольший вклад в теги

Все теги (6)

Лучшие ответы пользователя

Все ответы (7)
  • Как получить автоматически полный роут??

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

    Я вижу два варианта:
    Первое: Не показывать в роуте категорию.
    Например, роут для категории: /store/category/{$category-id}
    Роут для продукта: /store/product/{$product-id}
    Вместо id Вы можете вставлять транслитерацию названия продукта или категории. Или и id, и транслитерацию

    Второе: У каждого продукта должна быть главная связанная категория. Его и показывать в роуте. А другие категории будут просто дополнением внутри сайта и никак не отражаться в роуте
    Ответ написан
    Комментировать
  • Как получить все комбинации элементов массива размером не менее и не более К елементов?

    @u_elnur
    Веб разработчик, Начинающий предприниматель
    Для тренировки мозга попробовали сделать вот так:

    function process($input, $k, array $prefix = array())
    {
        $result = [];
    
        if ( $k === 1 )
        {
            foreach ($input as $item)
            {
                $result[] = array_merge($prefix, [$item]);
            }
        }
        else
        {
            $n = count($input);
            $m = $n - $k + 1;
    
            for ( $i = 1; $i <= $m; $i++ )
            {
                $subInput = array_slice($input, $i, $k);
                $subPrefix = array_merge($prefix, [$input[$i-1]]);
                $r = process($subInput, $k-1, $subPrefix);
                $result = array_merge($result, $r);
            }
        }
    
        return $result;
    }
    
    
    $input = [1, 2, 3, 4, 5];
    $k = 3;
    $result = process($input, $k);
    var_export($result);
    Ответ написан
    1 комментарий
  • Doctrine - структура БД для хранения документов, и участников документооборота?

    @u_elnur
    Веб разработчик, Начинающий предприниматель
    Приветствую! Мне в течение последнего года доводилось делать три похожих проекта документооборота. Хотелось бы поделиться со своим решением, как я организовал структуру таблиц (они же и сущности в доктрин).

    Первое:
    У моих проектов было несколько маршрутов согласования. Поэтому я хранил их отдельно. И называл их workflow (бизнес процесс)
    Workflow: (Маршрут согласования)
        id
        name (Название маршрута согласования)
    WorkflowPoint: (Точка согласования)
        id
        title (Название точки. Например "Согласование фин директора")
        workflow_id (Связанный маршрут)
        user_id (Пользователь, который рассматривает документ в этой точке согласования)
        order_id (Порядковый номер точки в маршруте)
        roles (Права пользователя, в данной точке согласования)


    Второе:
    В моих проектов в одном документе согласования могли храниться несколько файловых вложении. Поэтому Файл и Документ согласования хранились отдельно.

    Approval: (Документ согласования)
        id
        title (Название документа)
        author_id (Инициатор)
        state = 0 (Состояние документа. 0 - черновик. 1 - в процессе согласования. 2 - одобрено. 3 - отказано. 4 - архивировано)
        workflow_id (Маршрут, по которому движется данный документ. По умолчанию null, кроме того, когда состояние документа в процессе согласования)
        workflow_point_id (Текущая точка согласования в маршруте. При одобрении, указывается следующая точка)
        approval_user_id (Пользователь, который должен рассмотреть документ в текущий момент. Это поле чисто для удобства в поиске)
    Attachment: (Файл-вложение)
        id
        approval_id (Связанный документ)
        file_path (Путь к файлу)
        author_id (Пользователь, который вложил файл)


    Я значительно упростил структуру, чтобы просто дать Вам идею для размышления. В реальных проектах было гораздо сложнее
    Ответ написан
    3 комментария