Как стать автором
Обновить

Open Source документация для MODX Revolution

Время на прочтение3 мин
Количество просмотров16K
Хочу представить вам новый проект по ведению открытой документации для MODX Revolution.

Зачем?

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

Официальная документация на русском не ведётся. Не знаю, как сейчас, но год назад у них просто не сохранялась кириллица.

Почему не сделать это на сайте n или z?

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

Например, я пробовал писать про свои дополнения на официальном сайте, а потом они его переделали, и мой логин пароль больше не подходит. Просто зарегистрироваться нельзя — нужно получать их через письмо в поддержку. Конечно, повторно это делать нет желания.

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

И что ты предлагаешь?

Очень просто — нужно вести документацию в GitHub, в общеизвестном формате Markdown.

Такая система гарантирует нам:
  • Сохранность всех текстов. Каждый человек может скопировать репозиторий и разместить у себя.
  • История изменений. Все правки как на ладони, видно кто и что написал.
  • Независимость. Вы можете писать о любой теме, касающейся MODX, на любом языке. И вам не нужно просить для этого доступ — достаточно иметь аккаунт на GitHub.


Идея не новая, и подсмотрел я её у проекта daux.io. Это PHP скрипт, который генерирует сайт по готовым файлам markdown.
Он очень простой, и позволяет запустить свой сайт с документацией, не обладая вообще никакими навыками, на любом хостинге. Однако, на мой взгляд, у него есть несколько недостатков (которые являются продолжением достоинств).

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

Так что, для показа нашей документации я использовал любимую систему — MODX.

Как работает?

Это обычный сайт на MODX, построенный с использованием стандартных дополнений, но все его страницы импортируются из файлов.

Это даёт:
  • Кэширование. Все документы будут загружаться из кэша, и не нужно каждый раз шерстить файлы на HDD.
  • Управление url документов — их можно перемещать, не теряя при этом переходы из поисковиков.
  • Возможность организовать поиск на сайте.
  • Удобная работа с языковыми версиями, их может быть сколько угодно.
  • Возможность, в будущем, включить на сайте авторизацию (HybridAuth) и комментарии (Tickets).


В дереве сайта находятся долько документы.


Я хочу сохранить возможность полного обновления дерева с предварительной очисткой таблицы, поэтому служебные страницы генерирую налету и не сохраняю в БД. Это новая придумка, посмотрим, как будет работать.

Например, карта сайта выдаётся вот так:
<?php
if ($modx->event->name != 'OnHandleRequest' || $modx->context->get('key') == 'mgr') {return;}

$alias = $modx->getOption('request_param_alias', null, 'alias');
$request = strtolower($_REQUEST[$alias]);

if ($request == 'sitemap.xml') {
	$output = $modx->runSnippet('pdoSitemap', array('context' => 'web,en'));
	exit($output);
}


А вот страницы поиска:
elseif ($request == 'search') {
	$doc = $modx->newObject('modResource');
	$doc->fromArray(array(
			'id' => 100000000,
			'context_key' => $modx->context->key,
			'pagetitle' => $modx->context->key == 'en' ? 'Search' : 'Поиск',
			'template' => 3,
			'content' => '
				[[!pdoPage@Search?context=`'.$modx->context->key.'`]]
				[[+page.nav]]
			'
		));
	$modx->resource = $doc;
	$response = $modx->getResponse();

	$output = $modx->response->outputContent();
	exit($output);
}

То есть, работа идёт через плагин на событие OnHandleRequest и зависит от контекста (языковой версии).

Вёрстку я набросал на Bootstrap 3, чтобы было комфортно читать с телефонов и планшетов. Для работы используются:
  • pdoTools — вывод соседних документов, всех меню и хлебных крошек.
  • mSearch2 — морфологический поиск.
  • DateAgo — приятное форматировние дат
  • yTranslit — генерация url страниц через переводы Яндекс.
  • MinifyX — склейка и сжатие скриптов и стилей, для быстрой загрузки страниц.
  • Markdown — новый сниппет для вывода текстов в этом формате. Написал специально для этого проекта.


Еще раз напоминаю, что эта документация никому не принадлежит. Я сделал свою версию сайта для её вывода, а вы можете склонировать репозиторий и запустить его на том же daux.io — структура директорий и файлов совместима.

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

Ссылки

Репозиторий документации на Gitub.
Сайт с выводом этой документации.

Планы на будущее: разработка простенького API для вывода текстов на других сайтах и (возможно) сокращалка url.

Обновлено 15.01.2014


В связи с недовольством доменным именем, перенесли документацию на docs.modx.pro.

Надеюсь, больше возражений не будет.
Теги:
Хабы:
Всего голосов 16: ↑10 и ↓6+4
Комментарии23

Публикации

Истории

Ближайшие события

15 – 16 ноября
IT-конференция Merge Skolkovo
Москва
22 – 24 ноября
Хакатон «AgroCode Hack Genetics'24»
Онлайн
28 ноября
Конференция «TechRec: ITHR CAMPUS»
МоскваОнлайн
25 – 26 апреля
IT-конференция Merge Tatarstan 2025
Казань