Роман Воропаев (Volk)
С нами с 03 декабря 2015; Место в рейтинге пользователей: #8039 минут назад
ну тогда groupby и having«query» принимает все параметры pdoFetch и в нем есть и groupby и having. Пример навскидку:
"query":{
&quo...
Кейс gtsAPI. CRUD пользователей на фронте 2
1 час назад
тут в статье бОльшая часть притензий к vue и к тому как всё работает, мне кажется, изза того, что вещи какие требуется сделать используются не через т...
Плюсы и минусы Vue и gtsAPI 7
Вчера в 20:31
Правильный вариант из текущей документации такой:
{set $condition = 1}
{switch $condition}
{case 0, 1, 2}
сработае...
Конструкция switch case без break в Fenom 6
Вчера в 13:39
Моя кофейная гуща говорит о том, что это код html и там есть смайлики, а кодировка бд не utf8mb4.
Modx Revo режет код HTML 2
23 ноября 2024, 11:51
Отличное дополнение, спасибо!
Подскажите, как организовать файл если стоит msOptionsPrice2 привязан к опции size там может быть много позиций с разн...
[YandexMarket2] интеграция с msOptionsPrice2 1
23 ноября 2024, 00:42
Еще снова вернулась проблемка, после выбора способа доставки почтой РФ — появляется стоимость доставки, но она «прилипает» и не исчезает после переклю...
Расчет стоимости доставки msRussianPost 11
22 ноября 2024, 21:57
Лучше деинсталировать и установить новую версию. Там полностью переписан JS.
ms_CDEK2 пропал? 5
22 ноября 2024, 20:33
Фильтрация как правило предполагает точное совпадения значений, а тебе нужен поиск.
mFilter2 фильтрация tv 1
22 ноября 2024, 19:55
Все исправилось, после замены на 'parents' => $_modx->resource.id
Помогите найти ошибку в шаблоне, теги 13
22 ноября 2024, 09:31
А кто подскажет, как в форму Создания/Редактирования ресурса, через ms2Form, добавить возможность выбирать несоклько параметров в одном TV?
Ну то-ест...
Создание ресурсов из фронтенда сайта, зарегистрированными пользователями. 4
Тут еще недавно узнал, что ветка evolution тоже решила шаг вперед сделать, и начали делать её на компонентах laravel, считаю, что они правильным путем пошли по многим причинам, посмотрим что из этого выйдет и смогут ли это довести до ума. Вот если бы Revo тоже решили сделать на компонентах Laravel с обратной совместимостью, то я думаю в этом случае можно было бы привлечь опытных разработчиков из laravel сообщества решилось бы сразу полно проблем в т.ч. и безопасностью, а также стали бы сразу доступны все библиотеки, которые есть для laravel и дело бы реально пошло большими шагами, т.к., если даже небольшое сообщество evo ветки смогли это сделать, то и наше более активное сообщество добились бы успехов. В этом случае MODX бы стала хорошим конкурентом OctoberCMS, а при сохранении возможности легко делать сайты новичкам без знания php, MODX стала бы лидером.
Я все еще пилю сайты-визитки, корпоративные сайты и небольшие интернет-магазины на MODX, потому-что это стало намного удобнее с 2013 года, т.к. полно готовых компонентов, которые иногда необходимо допилить для нужд заказчика и на это уходит мало времени.
По поводу скорости MODX, тут все же для больших проектов необходимо поработать ручками и тогда это всё будет работать достаточно быстро (делал магазин, который с 1С обменивался каждые 10 минут новыми товарами и остатками, в бд было добавлено больше 100 тыс. позиций, на сайте опубликовано в среднем от 30 до 60 тыс., конечно, если просто взять и запустить как есть, то фильтры по опциям отрабатывали по несколько секунд, но в итоге, после много часов поиска решения удалось сделать так, чтобы в каталоге, где выводятся все 30 — 60 тыс товаров, с пагинацией по 50 товаров на странице, фильтры отрабатывали меньше, чем за секунду (и это без использования ElasticSearch или Sphinx, хотя проще наверно было бы использовать один из этих поисковых движков и вообще не париться по поводу роста количества товаров в бд и фильтрации по ним), с пиковой посещаемостью 15 тыс. уников в сутки, конечно без индивидуальной настройки выделенного сервера тоже не обошлось. Я думаю, что если больше углубиться в это, то можно было сделать еще быстрее, главное чтобы самому это было интересно и не в напряг, тогда возможно всё.
Но последние полтора года я все чаще начинаю использовать для разработки больших проектов на Laravel и, возможно, когда-то я соберу все свои наработки и буду на них быстро клепать простые проекты, но не факт. Laravel мне кажется для разработки именно с нуля намного удобнее, там полно библиотек, хорошая документация, не только на англ, но и на русском, одна работа с кэшем чего стоит, на сколько она простая и понятная, в то же время гибкая, особенно если использовать теги, которые единственное не поддерживаются стандартным файловым кэшем, а только Memcached, Redis и т.д., но можно ведь самому написать драйвер и реализовать это (для 4 версии даже готовое решение находил на ГИТе).
Конечно Laravel подойдет только для тех, кто уже давно не боится влезть в код готового дополнения и дописать его, либо расширить стандартный класс, если это предусмотрено разработчиком.
Опять же, благодаря сообществу MODX и магазину modstore, даже начинающий программист может заработать денег, написав своё дополнение и это большой плюс для привлечения в сообщество новичков. У меня у самого еще с 2016 года выложены 2 дополнения, с которых хоть немного, но почти каждый месяц есть доход, а если постараться и выложить что-то еще, то можно неплохую прибавку к основному доходу иметь, но чем сложнее дополнение, тем больше совсем глупых вопросов в тех. поддержке от тех, кому лень немного подумать или слишком мало опыта работы с MODX и разработкой сайтов в целом, на которые приходится полно времени тратить, которого и так мало, но это уже другая тема. У меня за это время накопилось полно различных решений для MODX, но нет времени и мотивации, чтобы их оформить в пакет, т.к. мотивация в доходе в последствии отнимет много времени тем, о чем я говорил выше, а просто потратить время на сбор пакета и написании инструкции, которое не окупится при текущей загруженности не могу, т.к. помимо зарабатывания денег еще есть семья, другие дела, ну и в свободное время стараюсь изучать что-то новое, чтобы в дальнейшем это использовать. Кстати, недавно освоил разработку в Docker контейнерах, очень удобная вещь, теперь не представляю, как раньше обходился OpenServer и в совсем далеком прошлом AppServ)
По моему мнению проблема в том, что MODX на данный момент интересен больше именно новичкам, поэтому очень мало опытных разработчиков, которые способны делать свой вклад в MODX, и еще меньше тех, у кого на это есть время и желание, я сам несколько раз только обращался к авторам дополнений с найденными ошибками и своими исправлениями, я мог и хотел бы сделать свой вклад в MODX 3, но времени хватило только чтобы написать этот большой коммент)). Я думаю, если все пойдет стремительно дальше, и MODX 3 увидит свет, то придут больше опытных разработчиков, а также начинающие разработчики повысят свой уровень и начнут тоже делать свой вклад, поэтому будущее у MODX есть, пока разработчики делают хоть небольшой вклад. Помню про Laravel 3 в начале 2013 года тоже говорили, что фреймворк загнется и не ровня он YII2 и возможно большие проекты совсем не для него, а потом вышла 4 и 5 и на данный момент у Laravel большое сообщество и крупные проекты на нем можно делать, конечно, если не думать при разработке, то и на Laravel можно написать г.., которое будет работать медленно.
Я считаю, что каждый для себя делает выбор того, что ему больше кажется удобным, т.к. все разные, и если человеку нравится работать с какой-то определенной системой, это не значит, что человек не развивается и не хочет двигаться дальше, это значит, что он чувствует себя в своей тарелке и ему это интересно, а интерес это главное, т.к. только в этом случае он может развиваться, внести полезный вклад в эту систему и делать качественные проекты, а еще лучше, когда такой человек приносит новшество в эту систему, которые в итоге как раз и дают прогресс системе. (например как fenom и файловые чанки, которые, думаю, многих новичков вывели на новый уровень в разработке, заставив разобраться, что такое среда разработки, и что сайты можно делать удобнее, чем просто из админки).
Последняя версия MODX и пакета
Что бы не забивало место на диске самого сервера хостинга я сделал в качестве типа хранилища яндекс диск на первое время, но потом заказал у того же хостинг провайдера, у которого арендую vds, отдельный диск (предоставляется фтп доступ к их серверу, на котором выделено нужное мне количество дискового пространства, которое к слову можно при необходимости увеличить), он находится в той же сети, что и мой vds, этим самым минимальный пинг и максимальная скорость передачи.
Конечно при резервном копировании теневая копия хранится на том же сервере, где и установлен веб-сервер, но после копирования её в другое хранилище эта копия удаляется. В итоге имеем на веб сервере только сами сайты и их файлы, а ночью необходимо немного места для создания теневой копии, а все бекапы на другом сервере.
Так же в этом случае можно еще найти вдс с минимум озу и 1 ядром, но с большим диском и поднять там ftp, либо пользоваться dropbox и прочими сервисами, но это обходится дороже, чем свой слабый вдс с большим диском и поднятым на нем фтп.
В моём как минимум есть ККТ, виджеты, полная интеграция с minishop2 без необходимости лезть в код и что-то там писать, все настраивается в настройках из админки и всё это собрано в пакет + техподдержка + обновление функционала иногда. А есть ли там такое? И кстати, у официального так называемого модуля, который был установлен у одного моего клиента, была проблема со сменой статуса заказа, с которой техподдержка паймастера не могла помочь, т.к. модуль делал сторонний программист, но еще раз повторюсь, это было 2 года назад, изменилось что-то там или нет я не отслеживаю.
Но опять же у меня есть и другие сайты, которые все еще отправляют письма через smtp яндекса, но меньшее количество в сутки и никаких проблем не было.
Вот пример на докладе MODX Meetup Minsk 2015 Илья Ершов рассказывал про проекты на 15000+ товаров в полной интеграции с 1С. И вот один из его проектов https://www.domfarfora.ru/. Много интересного можно отметить для себя из этого видео для разработки крупных интернет-магазинов.
Кстати все возможные ключи для массива и их значения, чтоб было понятно, что можно получить, можете глянуть, добавив в чанк следующий код:
Теперь компонент работает и на новой версии minishop2 2.4, поддержка старых осталась. Обновил компонент в modstore, осталось дождаться модерации.
То в версии 2.4, судя документации кастомный класс должен просто реализовывать интерфейс msDeliveryInterface следующим образом:
Но в таком случае в бэкенде в редактировании способов доставки ошибка, что отсутствует в файле кастомного класса интерфейс msDeliveryInterface, а во фронденде на странице оформления заказа вся логика работает без ошибок, при этом в настройках ms2_services всё прописано.
Если мы добавим в код кастомного класса то тогда в бэкенде кастомный класс для вариантов доставок выставляется без проблем и никаких ошибок, но во фронтенде на странице оформления заказа ошибка, что имя интерфейса msDeliveryInterface уже используется в файле кастомного класса.
Подскажи как получить тогда интерфейс msDeliveryInterface в кастомном классе?
Скоро доделаю и обновлю компонент.
В общем для тех, кто пока не планирует обновляться до последней версии минишопа этот компонент вполне подойдет, потом появится время разберусь с последней версией минишопа и сделаю уже под неё.
Да и у последних выложенных новых компонента доставки совместимость только с новой версией минишопа, видимо не удастся сделать так, чтоб кастомный класс и на старых версиях работал и на новых, тогда напишу отдельный компонент для нового, т.к. пока еще много народу используют версию 2.2
VPS могу посоветовать от Linode.
А так, если у вас все сайты хранятся на одной учетке хостинга, то просто если один сайт достигнет своего лимита, то проблемы с доступом и производительностью будут и у других сайтов, лежащих на этой учетке. А так, если хостинг не достигает лимитов своих выделенных ресурсов, то хоть сколько сайтов на нем можете размещать, но правильно разные хорошо посещаемые сайты раскидывать на разные учетки на своём VPS с индивидуальными ограничениями, чтоб работа одного сайта не влияла на работу другого сайта.
Используя панели управления хостингом удобно, что можно создать настройки по умолчанию для новых учеток, поэтому при загрузке нового проекта достаточно только создать новую учетку, базу и залить туда сайт.
В то время эта система на форуме хорошо прижилась.
У Victor библиотека jquery была подключена в конце страницы, а не как положено в head.
Просьба всем: вопросы по работе этого компонента, если вы его купили в modstore.pro, писать через поддержку в личном кабинете. Сюда писать предложения по компоненту или общие вопросы.
У каждого пользователя в личном кабинете будет отображаться кто, когда и за какой тикет или комментарий поставил ему плюс или минус. Так же можно сделать к примеру, если ставишь минус, то должен написать комментарий к нему (типа за что минус), который потом у пользователя отобразится в списке.