[pdoTools] Мета-теги и сниппет pdoTitle

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

Версия 1.10.2-pl

Представлю вам новую версию pdoTools, с исправлениями и улучшениями.

Самое интересное, пожалуй, это встроенные мета-теги у сниппета pdoPage, которые предложил Иван Климчук.
Делать ничего не нужно, просто обновитесь и на всех страницах с пагинацией появится что-то вроде

Усли у вас на странице несколько вызовов pdoPage, то нужно выбрать только один, который будет выставлять теги, а у остальных указать новый параметр &setMeta=`0`.

Второе важное изменение: теперь все сниппеты поставляются с пустым параметром &scheme, а это значит, что ссылки у них генерируются исходя из системной настройки link_tag_scheme. Конечно, вы можете указать и своё значение, как и раньше.

Сниппету pdoNeighbors добавлена возможность указания параметра &parents. То есть, теперь выводить ссылки на следующие-предыдущие страницы можно не взирая на реальное положение дел. При этом настоящие соседи документа всегда включаются в выборку.
Не знаю насколько это будет полезно, но предложение такое было.

Сниппет pdoMenu научился правильно показывать &selfClass и &hereClass для документов ссылок. Спасибо вот этому PR.

Ну и, наконец, если указан пустой параметр &titleOfLinks, то для плейсхолдера [[+title]] ссылок меню будет использовано поле pagetitle.

Версия 1.11.0-pl

По просьбам общественности был добавлен сниппет pdoTitle, который приятно формирует тег title страницы, включая в неё родителей, пагинацию и поисковые запросы, что приводит к такой индексации сайта поисковиками:

Первая версия сниппета находится здесь, а в pdoTools уже улучшенный вариант, с поддержкой лексиконов, чанков и &ajaxMode сниппета pdoPage.

Оценить работу можно во всех title этого сайта. А почитать документацию вот здесь.

Еще у сниппета pdoPage исправлено перезаписывание скриптов и стилей вызываемых сниппетов. Например, теперь нормально будут грузиться файлы ms2Gallery при вызове его в pdoPage.

Также при включенном &ajaxMode pdoPage вызывается событие pdopage_load, которое можно использовать для обработки навигации:
$(document).on('pdopage_load', function(e, config, response) {
	console.log(e, config, response);
});

Обновляемся, тестируем, пишем отзывы.
Василий Наумкин
30 марта 2015, 14:13
modx.pro
1
7 223
+11

Комментарии: 67

Сергей
29 марта 2015, 15:42
+1
Спасибо!
    Сергей
    29 марта 2015, 16:15
    0
    Если чанки $tplPagePrev и $tplPageNext пустые, мета-теги пагинации не выводятся?
      Василий Наумкин
      29 марта 2015, 16:21
      0
      Да, верно — проглядел.

      Думаю, это нужно исправить, потому что на странице могут быть только циферки.
        Сергей
        29 марта 2015, 16:27
        0
        Я тоже думаю, нужно :). Сейчас поставил твои по умолчанию (так обычно только циферки в пагинации), но [[+prev]] и [[+next]] в шаблоне не использую, мета-теги вывелись. Поэтому и не понял зачем зависимость от этих чанков.
          Василий Наумкин
          29 марта 2015, 16:36
          0
          Похоже, Иван просто скопипастил условия из кода выше.

          Поправил, можно обновляться.
            Іван Клімчук
            29 марта 2015, 17:22
            +1
            извиняюсь, не так понял суть в коммите сначала. Все ок
      Виктор
      29 марта 2015, 20:18
      +2
      Может есть смысл добавить в набор pdoTitle? Думаю многие используют его
        Сергей
        29 марта 2015, 20:26
        0
        Я тоже его так назвал в своих проектах :). Думаю Василий его не добавляет, т.к. он не вписывается в общую так сказать концепцию.
          Виктор
          29 марта 2015, 20:33
          +2
          Ну выносить в отдельный компонент глупо, а так приходится раз за разом перекопировать сниппет со старых сайтов.
          А так он же инструмент, который решает свою маленькую задачу, так что концепция не пострадает. Плюс для его полноценной работы нужен pdoCrumbs, т.е. по любому нужно ставить pdoTools.
          Даже коммит могу попробовать сделать, если эта бородатая идея приживется.
            Василий Наумкин
            29 марта 2015, 22:19
            +3
            Да, ты прав, стоит добавить этот сниппет в комплект.

            Постараюсь сделать на неделе.
          Дмитрий Иванов
          29 марта 2015, 21:33
          0
          только хотел начать изобретать велосипед, а тут уже готовое решение)
            Іван Клімчук
            29 марта 2015, 22:47
            0
            по той же причине и сделал PR с нормальным решением, так как мой «велосипед» не взлетел ) Хорошая практика — делать решение и делиться в виде PR. Рекомендую.
          Андрей
          Андрей
          30 марта 2015, 11:15
          0
          Коль пошла такая пьянка с «prev» и «next», то и rel=«canonical» нужно прикрутить, не находите, сеошники?
          P.S. видео гугла
            Василий Наумкин
            30 марта 2015, 11:35
            0
            А canonical-то каким образом относится к pdoTools?

            Или там тоже пагинация участвует? Кто может — проясните, а то я в этом вашем SEO не того.
              Андрей
              Андрей
              30 марта 2015, 12:23
              0
              Василий, вот пример.

              Есть страница, но разбитая на 3.

              example.com/page.html?p=1
              в коде:
              <link rel="next" href="/page.html?p=2"/>
              example.com/page.html?p=2
              в коде:
              <link rel="prev" href="/page.html?p=1"/>
              <link rel="next" href="/page.html?p=3"/>
              example.com/page.html?p=3
              в коде:
              <link rel="prev" href="/page.html?p=2"/>
              Но ситуация меняется, когда в параметры ссылки добавляется ещё что-то. Вот взгляни пример на этом сайте. В параметр ссылки передаётся (это только например) limit=20, но может быть и limit=40 и т.д. Вообще может передаваться всё, что угодно, в том числе и параметры всевозможных фильтров (в том числе от mSearch2). В коде HTML, само собой, rel=«next» и rel=«prev» указываются, включая эти параметры limit. Но это получается дублирование контента. Чтобы этого избежать, нужно добавить rel=canonical
              Код для моего примера будет такой:
              <link rel="canonical" href="/page.html?p=2"/>
              <link rel="prev" href="/page.html?p=1&limit=30"/>
              <link rel="next" href="/page.html?p=3&limit=30"/>
              На мой взгляд, всё это связано с pdoPage. К тому же, если уж добавлены rel=next и rel=prev, то логичнее было бы добавить и canonical))
                Андрей
                Андрей
                30 марта 2015, 12:29
                0
                В общем, суть в том, что при &setMetaCanonical=`1` в head страницы выводился канонический адрес данной страницы с отброшенными параметрами, кроме ?page=*
                Если не требуется канонический адрес, то &setMetaCanonical=`0`
                  Василий Наумкин
                  30 марта 2015, 12:34
                  0
                  Но это получается дублирование контента
                  Каким образом выходит дублирование контента, если по ссылкам выводятся разные страницы, с разным контентом?
                  На Яндексе говорят, что canonical нужно использовать, если одна страница доступна по двум адресам.

                  Что-то мне кажется, что автоматически выставлять canonical — плохая идея. Только автор сайта знает, какие у него там могут быть параметры и зачем. И какое именно сочетание этих параметров делает страницу уникальной.

                  Так что, от canonical пока предлагаю воздержаться. Кто знает, зачем ему это нужно — сделает сам.
                    Андрей
                    Андрей
                    30 марта 2015, 12:40
                    0
                    Неее, чуть выше я же написал, что не автоматически, а с параметром.

                    И у Гугла на этот счёт более подробно расписано, чем у Яши.
                      Василий Наумкин
                      30 марта 2015, 12:43
                      +1
                      Еще раз: я не считаю, что этим должен заниматься pdoPage.

                      Мета-теги для страниц еще куда ни шло, в конце концов, он эти страницы и делает. Но каноничные url настраивайте себе самостоятельно.
                        Андрей
                        Андрей
                        30 марта 2015, 12:48
                        0
                        Василий, pdoPage и канонический адрес страницы делает, так что здесь я с тобой не соглашусь, что canonical не имеет отношения к компоненту. Плясок с бубном было бы куда меньше.
                          Андрей
                          Андрей
                          30 марта 2015, 13:00
                          -1
                          К тому же, если следовать твоей логике, то зачем было вводить rel=«prev» и rel=«next» — пусть бы сами делали, кому нужно!
                            Іван Клімчук
                            30 марта 2015, 22:39
                            +1
                            делать самому не очень удобно, так как нужно вызывать 2 раза pdoPage, а это дублирование кода со всеми вытекающими, да и запросов больше в 2 раза (учитывая, что pdoPage нужно вызывать не кешированным). Была попытка использовать плейсхолдеры выше на странице, но это работает через раз, так что данное улучшение было оправданно. С prex/next все понятно, с cannonical, к сожалению нет.
                            По вашему же примеру, как быть с ссылками? /page.html?p=1&brand=LG и /page.html?p=1&brand=Sony
                            И таких примеров выше. Василий прав, с prex/next все однозначно, вперед и назад. Вариантов с cannonical в разы выше, а перебрать все комбинации, да еще чтобы и правильно, не реально.
                            Если готовы предложить рабочий реальный алгоритм 100% определения таких ссылок, ради бога, шлите пулреквест :) Вам только спасибо скажут.
                              Андрей
                              Андрей
                              31 марта 2015, 00:37
                              0
                              Вариантов с cannonical в разы выше
                              В самом распространённом случае, следуя рекомендациям всё тех же ПС, вариантов использования rel=canonical всего 3.
                              * на страницу «Показать всё»
                              * на первую страницу категории
                              * на эту же страницу за вычетом всех параметров из URL, кроме номера страницы.

                              Вот и весь алгоритм самый ходовый в 99% случаях. Прикрутить эти вызовы через параметры вызова pdoPage для Василия 10-15 минут, зато пользы уйма!

                              По вашему же примеру, как быть с ссылками? /page.html?p=1&brand=LG и /page.html?p=1&brand=Sony
                              Никак, это фильтры по производителю и априори дубли /page.html
                              Фильтры и поиск — это те страницы, которые ПС не рекомендуют к индексации ими же.

                              К тому же, если быть до конца откровенными, то rel=prev и rel=next Яндекс вообще не учитывает. А rel=canonical учитывает и Гугл и Яндекс.
                                Іван Клімчук
                                31 марта 2015, 00:47
                                0
                                Василий prev/next не писал, поэтому не 10-15 минут. Добавить cannonical не проблема, но мы тут не сниппет на коленке пишем, чтобы пихать все подряд и абы как.
                                Не исключено, что данная возможность в будущем появится, но пока не до конца понятно, как правильно должен работать cannonical. Даже в комментах (ваших и нет) к этоq заметке нет однозначного ответа.
                                Андрей
                                Андрей
                                31 марта 2015, 00:53
                                0
                                Возможно, для кого-то и не попадёт ни один из предложенных мной 3-х вариантов, но это будет единичный случай.
                                Ведь алгоритм корзины miniShop2 тоже не написан с целью охватить все случаи её использования.

                                И здесь точно так же. &setMeta=`0` отключает использование для prev/next, а, скажем, &setMetaCanonical=`0` — отключает rel=canonical и установлен по дефолту.

                                В случае такого подхода не нужно будет также лепить лишний сниппет в шапке, определяющий текущую страницу или страницу «Показать всё». Экономия на запросах тоже есть.
                              japuzixe
                              02 марта 2019, 13:24
                              -2
                              Ну и что?! В итоге сделал, и всё равно криво — принудительно впихиваешь этот canonical! Спорщик, блин, хренов!
                                Василий Наумкин
                                02 марта 2019, 13:56
                                0
                                Сделай лучше.
                                  Павел Гвоздь
                                  02 марта 2019, 14:06
                                  0
                                  Ты не понимаешь, это новый вид благодарности за то, что он пользуется твоим компонентом.
                                    japuzixe
                                    02 марта 2019, 14:55
                                    -1
                                    Тебе предлагали выше по отдельному параметру выставлять canonical. А теперь получилось так, что у кого setMeta был включен, массово пропали из выдачи страницы пагинации. Не находишь противоречивыми собственные же доводы?
                                      Василий Наумкин
                                      02 марта 2019, 15:28
                                      +2
                                      У меня нет никакого желания обсуждать новости 2015 года.

                                      Сделай как надо и пришли PR в репозиторий. Ты же для этого сегодня зарегистрировался здесь — чтобы исправить проблему?
                        Виктор
                        30 марта 2015, 11:39
                        0
                        Сомневаюсь, что тут много сеошников) Про каноникал Алексей писал недавно совсем. Вроде пришли к такому варианту.
                          Андрей
                          Андрей
                          30 марта 2015, 12:39
                          0
                          Если фичу с prev/next ввели, то сеошников хватает)
                          А вот последний вариант по твоей ссылке не катит для пагинации, т.к. все страницы выкинуться, кроме первой из выдачи.
                            Виктор
                            30 марта 2015, 12:54
                            +2
                            Скорей всего просто сеошники пинают разработчиков, которым надоедает каждый раз писать свой костыль и это вливается и идею)

                            А вообще все так странно с этим каноникалом. Ведь, каталог статей это сборник дублей кусков статей. Не редко встречаются закрытые от индексации пути со знаком вопроса, потому что по сути это дубли, которые нужны людям, а не роботам (у роботов сайтмап). И по логике из выдачи пользователь должен попадать на товар, а не на 15-ую страницу категории товаров(статей), где возможно был во время индексации этот товар(статей).
                            Сам очень часто напарываюсь при поиске, перехожу на страницу, а там нет того контента, который нашел там яндекс, ибо добавились еще статьи(товары) и нужная статья(товар) уехала в неизвестном направлении. Да с точки зрения владельца сайта к нему пришел посетитель, другое дело что дальше рулетка, я либо воспользуюсь поиском по сайту, чтоб уже найти то, что мне нужно, либо сразу закрою страницу, расстроюсь и скажу что все казлы.
                            Вообще я всегда думал, что каноникал должен вести именно на основную страницу без ?, потому что все остальные страницы являются его дублем.

                            Рассмотрим категорию товаров.
                            У нее есть: Заголовок, Текст описывающий категорию, 100 товаров.
                            На странице мы выводим 10 товаров.
                            При твоем подходе в выдачу мы отправляем 10 страниц с одним заголовком и одним текстом, не думаю что это то, чего добивался гугл.

                            На мой взгляд, самый лучший вариант это закрывать от индексации всю часть после знака вопроса.
                              Андрей
                              Андрей
                              30 марта 2015, 13:04
                              0
                              Вообще я всегда думал, что каноникал должен вести именно на основную страницу без ?, потому что все остальные страницы являются его дублем.
                              Это неверно. Вы видео по ссылке выше смотрели? У Гугла на этот счёт (как в прочем и у Яндекса) совсем иная точка зрения.

                              Не редко встречаются закрытые от индексации пути со знаком вопроса, потому что по сути это дубли, которые нужны людям, а не роботам (у роботов сайтмап).
                              Тоже неверно, т.к. пустые (мусорные) страницы будут в выдаче с пометкой в сниппете «индексация документа запрещена в файле robots.txt». А если ввести rel=canonical, то всё логично — в выдаче будет только основная страница, а остальные «сольются» с ней.

                              Сам очень часто напарываюсь при поиске, перехожу на страницу, а там нет того контента, который нашел там яндекс
                              вот поэтому и нужны все те инструменты, о которых мы здесь ведём речь — чтобы не было разочарования от перехода на сайт))
                                Андрей
                                Андрей
                                30 марта 2015, 13:10
                                0
                                Ты не правильно понял насчёт:
                                При твоем подходе в выдачу мы отправляем 10 страниц с одним заголовком и одним текстом, не думаю что это то, чего добивался гугл.
                                Посмотри видео от гугла и поймёшь, что я имел ввиду.
                                  Виктор
                                  30 марта 2015, 13:28
                                  0
                                  Вообще да, вот нагуглилось.
                                  Гугл видит это так.
                                  <link rel="canonical" href="http://www.example.com/article?story=abc&page=2"/>
                                  <link rel="prev" href="http://www.example.com/article?story=abc&page=1&sessionid=123" />
                                  <link rel="next" href="http://www.example.com/article?story=abc&page=3&sessionid=123" />
                                  Но странно все это. Цитата с Яндекса
                                  Также если на странице расположен атрибут rel=«canonical», с указанием непосредственного адреса этой страницы, робот посчитает ее канонической. Данная страница будет индексироваться и появится в поисковой выдаче Яндекса.
                                  Все равно получается мы имеет 10 страниц с одним заголовком и одним текстом, но другим набором товаров.
                                  И получается если мы добавляем 101 товар в начало, то бывший 10-ый товар у нас уже на второй странице, но пока индекс не обновится мы будем приходить к нему на первую и теряться.
                                    Андрей
                                    Андрей
                                    30 марта 2015, 13:45
                                    0
                                    Виктор, просто когда они в связке используются (prev/next/canonical), то canonical должен вести на ЭТУ же страницу, но без лишних параметров в URL.

                                    А если использовать только один canonical (без prev/next), то его можно ставить двумя способами:
                                    * для страницы со всеми товарами на одной (без разбивки, т.е. limit=кол-во товаров), но это хорошо, если товаров до 30-50 в категории. Если больше, то не вариант.
                                    * для основной страницы категории (т.е. как раз как ты говорил — без ?...) — это допустимо, но с точки зрения того же гугла неверно. Лучше использовать сразу три тега: prev/next/canonical
                                      Андрей
                                      Андрей
                                      30 марта 2015, 13:56
                                      0
                                      Про апдейт индекса всё верно — такое поведение будет при любом раскладе — хоть с каноникал, хоть без него, а равно и с prev/next и без них тоже.
                                      Но в этом случае canonical всё же может помочь, если у нас есть страница «Показать всё» (т.е. с limit=кол-во товаров). Тогда все товары будут на ней и в выдаче как раз будет она. Но если товаров немного, конечно. В остальных случаях от ожидания переиндексации ПС никто не застрахован и никакие пляски с бубном в этом не помогут))
                                  Іван Клімчук
                                  30 марта 2015, 22:40
                                  0
                                  выше уже написал, почему выгоднее было добавить код в сниппет, чем городить велосипед.
                              Дмитрий Иванов
                              30 марта 2015, 21:14
                              0
                              Василий, а можно выводить инфу в титл не по наличию переменной в гет, а, например, по какому-нибудь плейсхолдеру установленному pdoPage?
                              типа:
                              if($modx->getPlaceholder('page.nav')) { ... }
                              А то стоит добавить к любой странице ?page=2 и видим в титле что попало. Понятно, что это ерунда, но как-то некрасиво)
                                Василий Наумкин
                                31 марта 2015, 06:26
                                0
                                Там можно указать свой чанк для вывода пагинации, можно убрать или заменить регирование на ?page.

                                Настраивай.
                                Павел Левин
                                30 марта 2015, 23:57
                                0
                                pdoTitle странно работает:
                                  Василий Наумкин
                                  31 марта 2015, 06:27
                                  0
                                  Скорее, это у тебя в дефолтных параметрах pdoCrumbs что-то прописано, недефолтное.

                                  pdoCrumbs вызывается для вывода родителей документа внутри pdoTitle.
                                    Василий Наумкин
                                    31 марта 2015, 07:20
                                    0
                                    Поправил кое-что, попробуй обновить pdoTools.
                                      Сергей
                                      31 марта 2015, 17:43
                                      +1
                                      Василий, добрый день!
                                      Нельзя сделать &registerJs по умолчанию 0? Чтобы его включали кому это нужно, сейчас на всех сайтах вывелся скрипт. И site_name сделать параметром с дефолтным значением системной настройки, включив его в вывод, чтобы осталось только
                                      <title>[[!pdoTitle]]</title>
                                        Павел Левин
                                        04 апреля 2015, 23:20
                                        0
                                        Обновился.
                                        Все отлично работает.
                                        Спасибо!

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

                                        Мне пришлось сделать так:
                                        [[[[*id:isnot=`[[++site_start]]`:then=`!pdoTitle?limit=`5` &cache=`1` &registerJs=`0``:else=`++translate_site_name`]]]]
                                        т.е. сайт мультиязычный, вывожу translate_site_name из контекста.
                                      Саша Туманов
                                      07 апреля 2015, 19:43
                                      0
                                      pdoResources перестал реагировать на
                                      &scheme=`abs`
                                      Создает ссылки, без учета контекста, после обновления pdoTools.
                                        Василий Наумкин
                                        07 апреля 2015, 22:57
                                        0
                                        [[!pdoResources?
                                        	&parents=`0`
                                        	&scheme=`abs`
                                        	&useWeblinkUrl=`1`
                                        	&context=`[[*context_key]]`
                                        	&tpl=`@INLINE <p>{{+id}} - {{+link}}</p>`
                                        ]]
                                          Саша Туманов
                                          08 апреля 2015, 08:27
                                          0
                                          Уфф…
                                          Прошу прощения, что то у меня тут, видимо
                                        Сuriosity
                                        21 апреля 2015, 20:31
                                        0
                                        PdoTools — отличная коллекция сниппетов. Благодарности за них вам скажут еще тысячи пользователей!
                                        Я только начинаю осваивать ваши расширения, в том числе и PdoTools. Вопросов много, но стараюсь находить ответы через гугл и рытье статей на ваших сайтах.
                                        Возник вопрос, на который, скорей всего, для вас выеденного яйца не стоит, а вот я так пока и не нашел простого готового решения. Решить этот вопрос, как мне видится, можно с помощью сниппета pdoUsers, но я пока не понял, как правильно его для этого вызвать.
                                        Василий, собственно сам вопрос:
                                        Если установленны: Tickets и PdoTools.
                                        Как вывести список всех пользователей группы users по шаблону:
                                        • Имя, логин;
                                        • количество тикетов, которые оставил этот пользователь;
                                        • количество просмотров его тикетов;
                                        • общая сумма балов (лайков), оставленных на его тикеты;
                                        • количество оставленных комментариев на его тикеты;
                                        • количество комментариев, которые оставил этот пользователь;
                                        • общая сумма балов (лайков), оставленных на комментарии текущего пользователя.

                                        Василий, очень надеюсь на ваш подробный ответ. Уверен, что он будет полезен и для большинства других пользователей, ставших на путь освоения MODX и ваших замечательных решений…
                                          Сuriosity
                                          21 апреля 2015, 21:03
                                          0
                                          *Решить этот вопрос, как мне видится, можно с помощью сниппетов PdoTools и сниппета pdoUsers в частности, но я пока не понял, как их правильно для этого вызвать.
                                            Пашок
                                            Пашок
                                            21 апреля 2015, 21:08
                                            0
                                            Что-т я сомневаюсь, что Василий будет отвечать Вам на это. :) По крайней мере «подробно». :) Хотя, кто его знает.

                                            А вообще главный момент в освоении MODX — это тщательное изучение документации. Сам этим иногда принебрегаю выбрав вариант «методом тыка», однако впоследствии всё-же приходится обращаться к докам. Собственно сами доки — docs.modx.pro/
                                              Сuriosity
                                              21 апреля 2015, 21:42
                                              0
                                              Да это мой самый посещаемый сайт за последнее время… Но так или иначе мне еще не одну неделю все изучать и выводить на практику. А учитывая, что Tickets и PdoTools — это детища Василия, то, уверен, что он, как никто другой, может без труда и по существу, ответить на вышестоящий вопрос. Да и, судя по другим постам, обычно он отвечает, если и не подробно, но, все же отвечает… За что ему и дополнительное уважение…
                                              Володя
                                              21 апреля 2015, 21:51
                                              0
                                              На большинство ваших вопросов есть ответы либо в документации, либо тут в сообществе.
                                              Поледовательность действий такая — читаете внимательно доки, ставите на тестовом сайте компонент, пробуете сделать то что необходимо, снова читаете, снова пробуете… И вот если пройдя эту цепочку у вас останутся вопросы, на которые вы не нашли ответы — стоит задать их тут.
                                              ps. ну это конечно просто мое мнение и я не Василий… Но если вам лень или некогда прочесть то на что человек потратил время и силы, то хз стоит ли тут вообще отвечать.
                                                Сuriosity
                                                21 апреля 2015, 22:11
                                                0
                                                Собственно так и поступаю… Скачиваю компонент, роюсь в документации на docs.modx.pro, ищу ответы в статьях сообщества… Собственно я уже об этом писал. Устанавливать что-либо на тестовом сайте у меня пока нет нужды, потому как и на своем локальном всем нормально работает.
                                                Вы скажете, так в чем же проблема?! Так вот, Володя, на docs.modx.pro информация достаточно сжато подана, мало примеров. А потому то, что касается вызовов сниппетов с выборками из таблиц баз данных понятно, в основном, только программистам. К сожалению, я еще не программист, впрочем, как и большинство других вебмастеров (как новичков так и мастеров своего дела). Такие как я (а таких большинство) как раз и приходят на подобные сообщества за готовыми решениями, а уже после начинают вникать в самую глубину и суть. Именно благодаря готовым решения появляется желание вникать дальше, развиваться и изучать.
                                                Если же я сейчас начну изучать языки программирования, айтишные дела и т.д., то, получается, только через минимум год я могу вернуться сюда и начать идти по пути сайтостроения на modx. Но правильно ли это, если хочется творить уже сейчас?
                                                Василий Наумкин
                                                22 апреля 2015, 05:35
                                                +1
                                                Имя и логин выводятся через pdoUsers, а всё остальное нужно выбирать из БД самостоятельно. Можно вызывать свой сниппет в чанке, который доберёт эти данные, можно написать joins.

                                                А можно подождать недельку новую версию Tickets, где все эти данные будут сразу собираться в одну таблицу.
                                                  Сuriosity
                                                  23 апреля 2015, 15:57
                                                  0
                                                  Василий, спасибо! Так все себе и представлял, но надеялся, что уже есть возможность получить эти данные через pdotools, не прибегая к написанию своего сниппета.
                                                  P.S.
                                                  Новую версию жду с нетерпением! И не я один!
                                                    Василий Наумкин
                                                    23 апреля 2015, 16:30
                                                    0
                                                    Я тебе последний раз намекаю, что не нужно использовать наш домен в качестве своего имени на сайте.

                                                    Это может ввести кого-то в заблуждение.
                                                      Сuriosity
                                                      23 апреля 2015, 20:50
                                                      0
                                                      Василий, я намек понял еще в первый раз, но вернул имя на модкс.про потому как не был уверен, что мой посыл до дошел пункта назначения. Теперь я уверен, что мое послание ты увидел)
                                                      Я это к чему… а к тому, что может есть смысл вам создать такого юзереа, чтоб никому подно не было… или просто как-то запретить использовать такое имя…
                                                      мелочь, но все же…
                                                      Или, как вариант, вообще запретить смену логина…
                                                        Василий Наумкин
                                                        23 апреля 2015, 21:37
                                                        0
                                                        Или я просто продолжу отключать пользователей, который считают, что у меня без них забот не хватает.
                                                Jury
                                                18 мая 2015, 16:42
                                                +1
                                                pdoTitle Бомба! спасибо
                                                  Максим Кузнецов
                                                  18 июня 2015, 15:58
                                                  0
                                                  Подскажите, пожалуйста, можно ли вызывать pdoTitle для конкретной страницы (аналог переменной resource)?

                                                  Необходимо, преимущественно, для реализации своих аякс-страниц, возвращающих новый заголовок.
                                                    Василий Наумкин
                                                    18 июня 2015, 17:34
                                                    0
                                                    Да, там можно указать &id.
                                                      Максим Кузнецов
                                                      18 июня 2015, 17:36
                                                      0
                                                      Я пробовал вызывать сниппет с данной опцией:
                                                      [[!pdoTitle? &id=`3`]]
                                                      — но тогда он возвращает пустой результат при любом ответе, кроме тех случаев, когда id=текущему.
                                                  nekto
                                                  17 августа 2017, 23:20
                                                  0
                                                  Здравствуйте,
                                                  у меня почему-то не работает setMeta, а точнее не работает
                                                  $modx->regClientStartupHTMLBlock('');
                                                  Если вызывает
                                                  $modx->regClientStartupHTMLBlock('<link rel="prev" href="d"/>');
                                                  , то ничего не вставляет в head
                                                  А вот так уже вставляет
                                                  $modx->regClientStartupHTMLBlock('<link rel="prev" />');
                                                  , если убрать href.
                                                  В чем фокус, никто не сталкивался?
                                                    Dakascos
                                                    22 февраля 2018, 00:20
                                                    0
                                                    Привет всем!
                                                    Нужна помощь сообщества и в частности Василия Наумкина, так как перерыл всё и вся — ответа не нашел.
                                                    Стоит задача: переопределить вывод Canonical из PdoPage.
                                                    Подробнее: есть несколько материалов с одним содержимым, но разными URL, Title и т.п. вещами. Нужно сделать возможным в теле материала (ресурса) при его создании указывать адрес ресурса, который будет основным — Canonical. А если это поле не заполнено, то все продолжает работать, как и раньше — каждый сам себе Каноникал. То есть Канонизировать страницу по требованию, но без ущерба чистоте кода — обновляться в штатном режиме не боясь «затирания» костылей.
                                                    Возможна материальная компенсация затрат времени на разработку решения, если таковые будут иметь место.
                                                      Авторизуйтесь или зарегистрируйтесь, чтобы оставлять комментарии.
                                                      67