Единый форум поддержки

Информация о пользователе

Привет, Гость! Войдите или зарегистрируйтесь.


Вы здесь » Единый форум поддержки » Сделаем сервис лучше » Неглобальные доработки движка MyBB (с предложениями по PHP реализации)


Неглобальные доработки движка MyBB (с предложениями по PHP реализации)

Сообщений 1 страница 20 из 130

1

Доброго времени суток всем!
Давненько я не приходил на этот форум не по поводу проблем с форумами :D

Немного оффтопное вступление (много букв не по теме!)

Для тех, кто не знает, кто я такой и откуда взялся: я являюсь техническим администратором форумной ролевой игры, которой осенью исполнилось 7 лет, и которая на данный момент одна из немногих, кто продолжает работать в нашем фендоме, а в рейтинге форумов MyBB в своём разделе занимаем 8 место. Я не буду рекламить форум, не за этим я здесь. Сам я на MyBB уже 5 лет, за которые я вырос как программист в несколько десятков раз. Благодаря MyBB я стал хорошо разбираться в JavaScript, и сам начал писать сайты. Можно смело сказать, что эта платформа стала фундаментом моего роста, за что я благодарен Максиму и всем причастным данному движку.

Но наш форум растёт, появляются новые идеи, которым становится слишком откровенно тесно на MyBB. Ну слишком сильно ограничены мы в вопросе кастомизации форума. Менять вёрстку приходится через JS, которое либо в самом начале, когда ещё нечего изменять, либо в конце страницы, которое не всегда догружается быстро. Функционала полей профиля откровенно не хватает, так что часть информации мигрировала на отдельный сайт, рарабатываемый мной, и теперь подгружается через AJAX. А что ещё делать, если у лотам нужны комментарии, а к флажкам в полях профиля добавлять комментарии?

Сейчас примерно половина логики нашего форума не связана с платформой MyBB, из-за чего логика работы исказилась и стала путаться. Но отказаться от уже имеющихся решений мы не готовы, ибо это глупо. И старые вопрос четырёхлетней давности о переезде на собственный хостинг поднялся с новой актуальностью (раньше это было связано с DDoS, слава богу, это ушло), даже несмотря на откровенный упадок нашего фэндома.

За последние четыре года, на движке практически не произошло изменений, которые были бы полезны для моего основного форума здесь. Всё, что было полезно нам — это обновление jQuery, уведомление о ЛС и встроенный загрущик картинок без Flash. Ещё можно выделить мобильный стиль. Всё остальное — это хорошо, да, но... бли-ин. Последние обновления — визуальный редактор страниц и права доступа к ним. Хорошо, нам это не мешает, но и не помогает. Мобильный дизайн работает с нашим кастмным стилем работает слишком криво, а подправить его невозможно. Английская версия абсолютно бесполезна для русскоязычной FRPG.

В итоги, для нас MyBB перестал удовлетворять как движок, он отровенно устарел. Всё, что может нас удерживать здесь - это огромный объём данных и, что важнее, надежда на развитие сервиса. Но первый пункт и вовсе стал лишь вопросом "А захотим ли мы забрать все данные с MyBB при переезде, и в какое количество гемороя это может вылиться?". И теперь нас держит сейчас только надежда. Надежда, что движок перестанет быть мамонтом, эволюционирует и станет хоть чем-то, что можно будет администрировать без вечной головной боли. И эта надежда постепенно угасает, с каждым днём без действительно полезных для нас обновлений.

Предложения, которые я описал ниже, будут полезны не только для FRPG, но и для всех форумов на движке MyBB. Основано всё на реальных задачах, с которыми я сталкивался при работе над форумами и сопровождены предложениями по их реализации. Похожая тема — "Просилка", в которую я думал писать раньше, нынче скрывается за ошибкой "Ссылка, по которой Вы пришли неверная или устаревшая", и боле ничего о ней не слышно и не видно. Будем считать, что это "Просилка 2.0" :)

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

1. Тег [hide] (предложения по доработке)

Тег скрытого текста, на самом деле, — одна из самый недоработанных функций на форумах MyBB.
С одной стороны, его полезность и важность невозможно переоценить, но при этом очень довольно плохо ведёт себя для модераторов и старожил форума.


1.1. [hide] и модераторы.

Давайте разберёмся, зачем вообще нужен [hide]: скрыть какую-то информацию от гостей/новичков. При этом скрывать эту инфу от модераторов раздела и администраторов бессмысленно: они его всё равно могут посмотреть через редактор сообщения. Ну и, конечно, автору сообщения. Это логично.

А вот нужно ли показывать содержимое тем модераторам, что не могут редактировать чужие сообщения в данном разделе? Движок MyBB в данном случае отвечает однозначно: надо, они ж модераторы. Но вот не всегда это полезно.

Например, анонимные голосования через тег [hide]. Пользователи пишут, за кого они голосуют и скрывают это. Однако модераторы, которые в данном случае должны иметь права обычных пользователей, видят голоса и становятся необъетивными.
Или ещё пример: темы в "админке" (специальном разделе для АМС). Иногда админам может понадобиться скрыть информацию от модераторов, например, пароль от аккаунта главного администратора (с id 2).

Что делать?
Конечно, кардинально менять логику тега не стоит. Однако опция в настройках к разделу форума была бы весьма полезна. Сомневаюсь, что добавить одну галочку в настройки сложно.

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

Код:
$can_see_hide = 
    ($user["id"] == $post_author["id"]) || // показывать сообщение себе
    (($forum_settings["show_hide_tag_for_all_moderators"] == true) ? 
        ($user["groupid"] <= 2) : // Если галочка "Показывать [hide] всем модераторам" стоит, то просто проверяем группу
        ($user_allowed_to_edit_post)); // Если галочка не стоит, то смотрим, может ли пользователь редактировать сообщение

После чего отправляем это через global в парсер (или как-то иначе, я не знаю исходники) — и там уже на основе этой переменной и количества сообщений пользователя решаем, показывать ли содержимое или нет.


1.2. Лимит сообщений для открытого [hide].

Тут уже скорее вопрос удобства АМС и старожил форумов. Пользователи без прав просмотра отлично видят, сколько им надо сообщений для того, что бы открыть тег. Однако те, кто уже видит скрытие, не имеют возможности увидеть, какой лимит поставлен.

Что делать?
Если скрытый текст открывается, добавить в <cite> инфу о количестве сообщений, типа, "Скрытый текст (от 100 сообщений):..." Да, я знаю, что сейчас это связано с изменением языковых пакетов... Но разве добавить по 1 строчке в пакеты и добавить дополнительный тернарный оператор — это сложно?

2. Тег [align] (предложения по доработке)

Поведение этого тега — тоже та ещё задачка для пользователей, которые пытаются отформатировать сообщение. Все проблемы с ним тянутся от одного старого и, откровенно говоря, сомнительного решения парсить этот тег как строчный (в <span>), но отображать как блочный (с правилом display: block; text-align: something;). Из-за этого конфликта при разборе поведения тега пошли дичайшие неудобства, которые ощущаются до сих пор.


2.1. [align] и параграфы (предложения по доработке)

Самый заметный бред поведения тега — это его реакция на удвоенный перенос строки, воспринимаемый парсер как новый абзац. Из-за того, что [align] парсится в <span>, браузеры, увидев перекрёсный код типа:
<p>111<span>222</p><p>333</span>444</p>
поступают так, как им кажется правильным, и адаптируют невалидный HTML как
<p>111<span>222</span></p><p>333444</p>
В итоге, мы получаем сверхбредовое поведение: несмотря на то, что у нас тегом отмечены несколько параграфов, правильно отобразится только первый.

Что делать?
Собственно, главный способ решения этой проблемы — перестать парсить [align] как строковый тег. А во что парсить? Самое логичное — в блочный <p>. Конечно, это убьёт фичу, когда между двумя подряд идущими [align] нет отступа, но, откровенно говоря, это тоже смотрится как баг, пусть и более-менее юзабельный.
Сделать это можно примерно таким PHP кодом:

Код:
$code = "<p>111[align=center]222</p>".PHP_EOL."<p>333[/align]444</p>"; // Переменная, в которой хранится bb-код сообщения, который нужен для нас

$code = preg_replace_callback(
    "/\[align=(center|left|right|justify)\]([\s\S]*?)\[\/align\]/g", // Паттерн для тега align
    function($matches) {
        // $matches[1] - направление выравнивания, защищено от XSS
        // $matches[2] - код внутри, не жадный (до первого [/align])
        $tmp = explode("<p>", $matches[2]); // Разбиваем по параграфам...
        $tmp = implode("<p style=\"text-align: {$matches[1]}\">", $tmp); // И собираем параграфам с выравниванием!

        return "</p>".PHP_EOL."<p style=\"text-align: {$matches[1]}\">".$tmp."</p>".PHP_EOL."<p>";
    }, $code);

echo $code;
/*
<p>111</p>
<p style="text-align: center">222</p>
<p style="text-align: center">333</p>
<p>444</p>
*/

Что бы всё было красиво, остаётся только подставить вместо $code другую переменную, и вместо PHP_EOL — переменную с переносом строки и табуляциями (что б исходиники красивые были). Можно ещё и количество операторов снизить, избавившись от последовательного использования $tmp, но это как будет удобно программисту.

Можно заранее предположить, что где-то после внедрения этого поведения начнутся баги. В частности, сломается многострадальная часть парсера, избавляющаяся от "висячих" <br> и пустых <p>. Однако это решается просто: во всех паттернах, которые содержат в себе <p> нужно будет подравить под что-то типа <p(?: style=\"text\-align\: (center|left|right|justify)\")?> или <p(?:.*?)?>, если у нас на <p> будет вешаться что-то ещё (превентивный фикс поведения для предложния 3., что ниже).

Для тех, кто не знает, поведаю: паттерн (?:something)? можно использовать, что ообозначить показать, что тут может быть текст, удовлетворяющий этому паттерну something, но его может и не быть, при этом, несмотря на скобочки, он не будет запомнинаться.


2.2. [align] и переносы строк.

Эта проблема возникнит, если мы откажемся от решения проблемы методом из пункта 2.1., и примем, что тег [align] работает только в рамках одного параграфа. Но тут обнаружится, что тег всё равно ведёт себя странно, если рядом с ним окаывается переност строки.
Так как [align] ведёт себя как строковый тег, парсер не воспринимает наличие рядом с ним <br> как что-то неправильное. С его точки зрения всё довольно логично, так как
<p><span>111</span><br>222</p>
это абсолютно нормальный код для действительно строковых тегов, типа [b]. Однако <span> форматируется как блоковый элемент, из-за чего у нас возникает ломающий логику <br>:

111

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus viverra eget mauris vel hendrerit. Integer lobortis hendrerit lacus a aliquet. Integer porttitor fermentum augue, quis fermentum augue lacinia eget.

В итоге, что бы такого разрыва не возникало, приходится писать текст в той же строке, что и [align]. Стоит ли говорить, что это мешает воспринимать сообщение в редакторе?

Что делать?
В этом варианте в паттерн тега [align] надо добавить проверку на то, что рядом есть переносы строк, в итоге паттерн тега станет примерно таким (центральная часть взята из 1 варианта):
/(?:<br>)?\[align=(center|left|right|justify)\]([\s\S]*?)\[\/align\](?:<br>)?/g - если разбор [align] идёт после преобразования \r\n в <br>;
/\s*\[align=(center|left|right|justify)\]([\s\S]*?)\[\/align\]\s*/g - если до.

3. Пользовательские BB-теги (новый функционал)

На MyBB много ролевых форумов, которым нужно, что бы в сообщениях что-то дополнительно показывалось. И на ЕТП довольно много скриптов, которые реализуют BB-коды. Но у всех этих реализаций есть один капитальный минус: если JavaScript не работает или очень тормозит, то пользователь видит неотформатированный текст. Сказать, что это хорошо опредённо нельзя, хотя жить с этим можно.

Тем не менее, некоторые BB-теги не требуют значительных усилий для реализации: лишь самым навороченным из них нужно что-то кроме банальных паттернов. А вот решительное большинство пользовательских BB-тегов можно реализовать довольно безболезнено. Да, конечно, потребуется доработка базы данных, однако доработка заключается в добавлении одной таблицы, что явно не намного сложнее уже древнего обновления с новыми типами пользовательских полей от апреля 2011.


3.1. Настройка пользовательских BB-кодов

Тут, всё очень просто. То, что админка форумов более-менее настраиваема, мы знаем из июньского обновления со скриптами в админке. Поэтому, для пользовательских BB-кодов просто добавляем 2 страницы в админку.

(Придумано после описания и добавлено так, что бы не удалять нормальный текст) В теории, весь раздел можно сделать на основе /admin_pages.php.

3.1.1. Список пользовательских BB-кодов
Во-первых, поле создания BB-кода. Тут можно сделать поле и кнопку "Создать", как на странице /admin_categories.php. После нажатия на кнопку должна открываться страница настройки нового bb-кода (см. 3.1.2.).

Во-вторых, список уже созданных BB-кодов. Не думаю, что кому-то нужно его сортировать, так что можно отображать в алфавитном порядке. Рядом с каждым нужна кнопочка "редактировать", как на /admin_forums.php.

3.1.2. Редактирование BB-кода
Эта страница так же не содержит откровенно нового.

1. Название bb-кода. Именно то, что будет в парсится из квадратных скобкок. Разрешаем тут только английские символы. Цифры, дефис, подчёркивание — можно, но не обязательно. А вот русские буквы, пробелы, плюсики и прочую пунктуация посылаем нафиг. Хотя на некоторых движках используется [*] как разделитель элементов списков <ul>...
2. Видимость в редакторе: Да/Нет. Отображать ли кнопку над полем редактирования сообщения с данным bb-кодом.
3. Иконка bb-кода. Сюда нужна только ссылка. Если это поле не пустое, будем показывать bb-код как кнопку. Если пустое, то спрячем под кнопку "Дополнительно". Размер картинки не важен, всё равно в CSS-е мы ограничивать будем. Заливать картинки можно через "Файлы", на uploads или ещё как-нибудь.
4. Тип: Без параметра/С параметром. Определить, как будет вести себя bb-код: как [i] или как [font]. Можно, конечно, сделать комбинированный вариант (как [hide]) и с несколькими параметрами (как [table])... Но это, на самом деле, уже откровенный избыток функционала. Нафиг, нафиг, нафиг.
5. Замещающий текст. Собственно, второй параметр для preg_replace. Можно, для удобства пользователей, использовать не {0} и {1}, а, например, {param} и {content}, так как так ясно, что где.
6. Комментарий к параметру (только, если у нас тип "С параметром" и видимость в редакторе включена). То, что будет отображаться при нажатии на кнопку тега в prompt-диалоге.

Так как код редактирует админ, защищаться от XSS нам не особо нужно: есть много более простых способов сломать форум будучи админом, а в область PHP мы всё равно никого не пустим (жаль, но да ладно). Аналогичный вывод следует для проблемы потенциальной сломанной вёрстки.

Собственно, на основе этих полей легко можно понять, что нужно в SQL-таблице: 5 полей (может быть 6, если не делать ключевым полем название тега).


3.2. Парсинг пользовательских BB-кодов

Тут, на самом деле, всё довольно просто. Перед парсингом постов, подгружаем из БД (или кеша) название (будем называть это поле name), тип (type) и замещающий текст (replacer) всех BB-кодов в массив, скажем, $userbbs. Через global пропихиваем перменную в функцию парсера, и ближе к концу, после обработки всех тегов, но перед отчитской пустых тегов (что бы у нас не остались висеть пустые параграфы), добавляем что-то типа такого:

Код:
$code; // тут у нас BB-код

foreach($userbbs as $userbb) {
    if ($userbb['type'] == 0) {
        // Без параметров
        $pattern = "/\[{$userbb['name']}\]([\s\S]*?)\[\/{$userbb['name']}\]/g";
        $replacer = str_replace('{content}', '{0}'), $userbb['replacer']); // Тут одинарные кавычки, что б PHP не начал воспринимать {content} как попытку подставить переменную
    }
    else if ($userbb['type'] == 1) {
        // С 1 параметром
        $pattern = "/\[{$userbb['name']}=\"?([\s\S]*?)\"?\]([\s\S]*?)\[\/{$userbb['name']}\]/g";
        $replacer = str_replace(array('{param}', '{content}'), array('{0}', '{1}'), $userbb['replacer']);
    }
    else {} // Если есть желание делать ещё типы

    $code = preg_replace($pattern, $replacer, $code);
}

echo $code;

3.3. Добавление кодов в редактор

Тут тоже не сказать, что какой-то сложный код.

В конце <head> инициализируем дополнительные кнопки (в JSON добавляем только видимые теги, см. 3.1.2.2.):

Код:
<style id="userbbs-style"></style>
(function(userbbs) {
    var css = "";
    for(var i = 0; i < userbbs.length; i++) {
        var bb = userbbs[i], obj = { name: bb.title };
        if (bb.param) {
            obj.onclick = function() { bbcode('[' + bb.name + '="' + prompt(bb.prompt_text, '') + '"]','[/' + bb.name + ']'); }
        }
        else {
            obj.onclick = function() { bbcode('[' + bb.name + ']','[/' + bb.name + ']'); }
        }
        if (bb.icon != '') {
            FORUM.set('editor.' + bb.name, obj);
            css += "td#button-font {background:url(" + bb.icon + ") no-repeat center center; background-size: 26px 26px}\r\n"
        }
        else {
            FORUM.set('editor.addition.tags.' + bb.name, obj);
        }
    }
    $("#userbbs-style").html(css);
})(
[ // Начало JSON с инфой о тегах
    {"name":"mytag", "title":"Мой bb-код", "icon": "http://.../icon.png", "param": true, "prompt_text": "Параметр к моему bb-коду"}
] // Конец JSON с инфой о тегах
)

Можно генерить JS для FORUM.editor и CSS через PHP — вообще не принципиально, суть ясна.

В итоге, на форумах появится довольно удобная и функциональная система для работы с BB-кодами. Можно придумывать на неё навороты, но зачем? Если нужно будет редактировать что-то, то можно будет корректировать этот код через JS (предварительно, сгенерив через рандом уникальный ID)... Окошко при редактировании сообщений тоже добавляется достаточно просто: переопределением функции FORUM.editor.mytag.onclick. И 99.9% задач с BB-кодами решены!

4. JavaScript (jQuery?) Hooks (новый функционал)

Ещё одна большая проблема MyBB, с которой сталкивается любой разработчик скриптов для MyBB — проблема со скриптами, обрабатывающими страницу, которая выражается в том, что скрипт из HTML-низа, обрабатывающий страницу, не запустится, пока не загрузится вся страница и не выполнятся скрипты перед ним.
Например, на нашем форуме есть очень важный скрипт, который обрабатывает поля профиля в специальное окошко с информацией о персонаже (весьма востребованная штука на ролевых форумах, стоит отметить: скрипт Deff'а, реализующий нечто подобное, используют многие). Однако в больших темах (где играют "бешенные" игроки, пишущие по 10-20 тысяч символов) и/или при не особо быстром интернете, этот скрипт не может подготовить "столбик автора" весьма значительное время, и пользователи видят необработанные поля. Опять-таки, жить можно, но как-то не особо удобно. Да и HTML-низ на многих форумах превращается в грандиозную свалку во многом по этой причине.

На одном из движков, которые я рассматривал как альтернативу MyBB (а точнее, на mybb.com), была система плагинов, основанная на использовании т.н. "крючков" (hooks), которые вызывали функции плагинов, когда это было нужно. Там она относилась к серверной составляющей, однако эту удобную систему можно перенести на наш MyBB как помощь разработчикам JavaScript.

Тут, в принципе, есть 2 способа, как это сделать: при помощи jQuery или при помощи простого JavaScript и объекта FORUM, которые отличаются только кодом.


4.1. Общие детали

По факту, здесь можно реализовать пользовательские события. То есть схема примерно такая:
1. Администратор в html-верху регистрирует функции (handlers), которые должны быть применены после загрузки какого-либо элемента.
2. Когда пользователь грузит тему, после каждого сообщения вызываются функции, привязанные к данному событию.

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


4.2. JavaScript

В принципе, ничего сверхестественного тут выдумывать не надо:

Код:
FORUM.hooks = {
    _events: {},
    register: function(name, callback) {
         if('undefined' == typeof(FORUM.hooks._events[name]))
             FORUM.hooks._events[name] = [];
         FORUM.hooks._events[name].push(callback);
    },
    call: function(name, arguments) {
        if('undefined' != typeof(FORUM.hooks._events[name]))
            for(var i = 0; i < FORUM.hooks._events[name].length; i++)
                FORUM.hooks._events.apply(null, arguments || []);
    }
}

Просто, коротко и, что самое главное, действенно.

Далее, в коде странице, например, после загрузки каждого сообщения, вставляем вставить примерно такой код:

Код:
<script>FORUM.hooks.call('post', [ 12345 ]);</script>

где 12345 - это id сообщения.

Теперь всё, что нужно сделать администратору - это зарегистрировать событие:

Код:
FORUM.hooks.register('post', function(pid) {
    console.log("Только что загрузилось сообщение #" + pid);
});

И, вуаля, в консоле покажется все сообщения, что есть на странице.


4.3. jQuery

В jQuery этот код получается несколько проще. Всё делается через функции on и trigger:

Код:
// Регистрация события админом
$(document).on('FORUM-post', function(e, pid) {
    console.log("Только что загрузилось сообщение #" + pid);
});

// Вызов
$(document).trigger('FORUM-post', [ 12345 ]);

4.4. На что надо развесить "крючки"?

Сообщения, в том числе в ЛС, при поиске и предпросмотре в редакторе;
Редактирование профиля (в первую очередь, в графе "Дополнительно");
Форума, точнее, строки с форумами на главной странице (для скрипта аватарок);
Темы, на страница поиска и списка тем форума (для скрипта аватарок);
• после генерации кнопок редактора, что бы можно было изменять их порядок сразу же после генерации;
• после пользовательского BB-кода (не уверен, <script> можно запихнуть и в сам bb-код).

В принципе, чем больше будет мест, к которым можно будет прицепиться "крючком", тем лучше, но, ясное дело, что документирвоать это всё будет заморочно.

5. Поле профиля с настройками отображения скриптов (новый функционал) Уже в планах

Ещё один гигантский пласт скриптов - это скрипты, которые добавляют различные украшательства на форум: снежинки, уведомления о ЛС, переключалки стилей и т.д.

Я не случайно назвал как пример эти 3 скрипта. У них есть одна общая черта — они настраиваются. И тут случается тотальный геморой для всех скриптёров: на сервисе тупо нет никакой системы хранения настроек для скриптов на сервере.
Откровенно говоря, это очень странно. Скриптёрам приходится использовать cookie, LocalStorage для хранения настроек отображения... Но это едва ли не апофеоз костыльности скриптов для MyBB. Мало того, что cookie и LocalStorage позволяют хранить отображение только в одном месте (тогда как у некоторых людей аж по 5 мест, откуда они пользуются форумом: планшет, телефон да 3 компьютера: дома, на работе и походный ноут), так ещё эти штуки у многих очищаются после определённого времени! В итоге у пользотелей начинют сбрасываться стили, включатся снежинки и начинают орать уведомления, что явно не вызывает хорошего настроения от пользования форумом.

Правильное решение для этой проблемы — просто дать каждому пользователю бесплатное поле профиля, в котором будет хранится JSON с настройками. Этот JSON можно тупо вставить в <head>, где перечисляются различные переменные типа UserName. И тогда каждый скрипт сможет прочесть оттуда нуждную информацию: включены ли снежинки, какая громкость уведомления, какой стиль включён.


5.1. Ограничения

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

Ограничения, вообще говоря, уместны. Во-первых, администратор должен сам прописывать, какие ключи может иметь объект с настройками. Во-вторых, возить трафик через это поле — затея скверная с любой стороны, поэтому каждое значение можно ограничить, скажем, 100 символами. Если скрипту понадобится много настроек, то скриптёр может использовать несколько ключей или как-то сжимать данные. В-третьих, можно ограничить количество ключей, которые можно использовать. В-четвёртых, это поле нельзя будет редактировать напрямую.

Эти ограничения позволят не забивать это поле спамом. При этом полезность поля будет запредельная.


5.2. Как это можно реализовать

В JavaScript переменные форума (что в <head>), можно добавить переменную UserViewSettings с объектом, который извлекается из этого поля. Скрипты могут спокойно воспользоваться ими.

Список разрешённых ключей можно редактировать через админку. Любой способ отображения и редактирования массива строк подойдёт: одно текстовое поле с правилом "1 строка - 1 элемент" или же что-то интерактивное, как, напирмер, работа с элементами поля профиля типов "Флажок" или "Переключатель". Это не принципиально. Хранить массив тоже несложно: либо как JSON, либо просто через символ-разделитель (перенос строки или запятую).

Интереснее будет с сохранением этого поля. Тут есть 2 варианта реализации... И реализовать можно оба сразу, хуже не будет.

5.2.1. GUI через профиль
На какую-нибудь страницу редактирования профиля (либо /profile.php?section=display, либо на какую-то новую) добавляем несколько полей ввода, которые будут обозначать пары ключ-значение из скрипта. Через JS это поле можно будет сделать невидимым и сделать настройки красивыми.
Если предложение 4 с крючками реализовано, то сюда тоже можно приделать точку "зацепа".

5.2.2. API
Многострадальное API MyBB изначально имела огромный потенциал, но уже долгое время простаивает без изменений. А жаль, так как идея очень хороша...
Данное поле — отличный кандидат на то, что бы стать первым местом, где появится метод POST. Тут стоит отметить, что если мы делаем вызов со страницы сайта, то через AJAX будут переданы все cookie и данные сессии. А значит проверить пользователя не составит никаого труда.

Итак, мы запускаем через JS такой код:
$.post("/api.php?method=viewsettings.set&key=mykey", [ data: 'mydata' ], function(data) { if (data.success) { UserViewSettings = data.data; myscript_use_settings(); } else { console.log(data.error); }});

На сервере мы проверяем, залогинен ли пользователь и разрешено ли использовать ключ mykey. Если всё хорошо, мы сохраняем данные и возвращаем объект типа

Код:
{
"success": true,
"data": {"mykey":"mydata","another":"something"}
}

Если же что-то пошло не так, то пишем

Код:
{
"success": false,
"error": "Запрещённый ключ/Неавторизован и т.д."
}

Кстати, тут тоже можно использовать "крючки" из предложения 4 :D

6. Профиль пользователя (предложения по доработке)

На данный момент, самая тяжёлая для разработки страница — это страница просмотра профиля. Если говорить откровенно, она реализована так плохо, что её практически невозможно настроить. В добавок, если вы сидите с аккаунта главного администратора, то вы просто никогда не увидите эту страницу, и будете вспоминать о ней только когда начнут возмущаться пользователи. И то, для работы с ней потребуется либо выйти с аккаунта, либо открыть ещё один браузер. Мягко говоря, это неудобно.


6.1. Просмотр профиля для всех

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

Собственно, что можно сделать? Да всё просто.
/profile.php?id=123 — просмотр профиля профиль
/profile.php?id=123&section=view — тоже просмотр профия
/profile.php?id=123&section=essentials — редактирование профиля

При таком варианте надо менять минимальное количество вещей. Просто значение $_GET["section"] принимать по умолчанию (при пустой строке) не essentials, а view. Соответственно, в ветку if ($_GET['section'] == 'view') {} перенести код просмотра профиля. Ну и, соответственно, добавить ссылку "Просмотр/View" в начале менюшки пользователя.
Само боковое меню с ссылками можно и оставить, профиль практически всегда будет умещаться.

В итоге все страницы останутся доступны по старым ссылкам с section, но у админов хотя бы появится возможность просто посмотреть профиль.


6.2. Вёрстка полей профиля

Тут, в принципе, менять надо довольно много.

6.2.1. Вёрстка "столбца автора"
В первую очередь, обратимся к этому полю. Почему нельзя сделать так, что бы название поля и значение хоть как-то различались??! Это редактировать реально не долго: всего-лишь изменить вёрстку
<li id="pa-{field_id}">{field-name}: {field-value}</li>
на
<li id="pa-{field_id}"><span>{field-name}:</span> <strong>{field-value}</strong></li>
Другими словами, вёрстку внутри поля взять со страницы просмотра профиля.

Такой код можно нормально отформатировать без использования скриптов — так, как и должен работать дизайн. Добавление нескольких span вообще не ломает вёрстку, но зато этот код можно отформатировать, например, в табличку (как сейчас при просмотре профиля). Или сделать названия полужирными. Или значения полужирными. Отдельно друг от друга. И перечислять все плюсы тут можно крайне долго.

В добавок, скриптёрам, которые обрабатывают поля профиля, станет намного проще редактировать поля профиля

6.2.2. Табличная вёрстка страницы просмотра
САБЖ. Я, конечно, всё понимаю, но этого я не понимаю. Почему нельзя сделать здесь сделать вёрстку такую же, как у сообщений на форуме: простым float?! Да, вёрстка
<ul><div><li>...</div><div><li>...</div></ul>
это не очень хорошо, но то, что есть сейчас — ещё хуже!

6.2.3. ID полей на странице просмотра
Тут всё просто: их нет. Ладно, они есть у имени и у статуса — хоть что-то. Но почему Ни у одного поля нет этого важного аттрибута? Из-за этого кастомизировать эту страницу очень сложно. При этом редактировать эти поля хочется: на ролевых формуах пользовательские поля стилизуются под свои нужды, и тут это тоже нужно.

6.2.4. Аватарка
Совсем незначительная правка, но раз уж начал... Здесь можно, и нужно обойтись без <div>. В темах же обходимся.

Это далеко не всё, что можно сделать. Есть даже мысли о том, как сделать PHP-плагины, однако это долго, сложно и с негарантированной защитой от бекдора, а значит дальше мыслей может банально не уйти.

P.S. Приношу извинения, если кто-то засхлебнулся кровью из глаз из-за моей орфографии. Писался сей опус как поток мыслей, и я не особо редактировал. Прастити (>__<)
И пните меня, если где-то капитально накосячил.

Отредактировано kozhilya (Чт, 9 Фев 2017 23:30:56)

+8

2

kozhilya написал(а):

на сервисе тупо нет никакой системы хранения настроек для скриптов на сервере.
Откровенно говоря, это очень странно. Скриптёрам приходится использовать cookie, LocalStorage для хранения настроек отображения... Но это едва ли не апофеоз костыльности скриптов для MyBB. Мало того, что cookie и LocalStorage позволяют хранить отображение только в одном месте (тогда как у некоторых людей аж по 5 мест, откуда они пользуются форумом: планшет, телефон да 3 компьютера: дома, на работе и походный ноут), так ещё эти штуки у многих очищаются после определённого времени! В итоге у пользотелей начинют сбрасываться стили, включатся снежинки и начинают орать уведомления

для этого планируется параметр app_id в методе storage api - http://mybb.ru/forumapi/#method-storage
только когда он будет включён, одному Максу известно

+3

3

Romych
Однако, я не видел этой ссылочки... Много же я пропустил, однако :D

0

4

kozhilya
Большое спасибо за ваш пост!
Постараемся что-то со временем реализовать.

+5

5

kozhilya написал(а):

4. JavaScript (jQuery?) Hooks (новый функционал)

Ну вот это сомнительно, т.к. кода(вызов этих самых крючков) добавится много(несколько кб на каждую страницу, особенно в топике, где постов много), а это трафик, за который оплачивается анти-DDoS защита... Так-то удобно это, но не уверен, что будет столь часто использоваться (сейчас хватает двух подобных фич  - $.fn.pun_mainReady() и $.fn.pun_aboutReady()

kozhilya написал(а):

Ещё один гигантский пласт скриптов - это скрипты, которые добавляют различные украшательства на форум: снежинки, уведомления о ЛС, переключалки стилей и т.д.

Ну уже сейчас можно записывать настройки для каждого юзера в API storage (Romych выше дал ссылку), собственно уже реализованы Закладки, Уведомления о новом ЛС(с возможностью их отключения).. Если надо сохранить Настройки общие для всех юзеров - есть костыльный вариант с записью на гостевой ключ (user_id: 1)

kozhilya написал(а):

6.2.1. Вёрстка "столбца автора"
В первую очередь, обратимся к этому полю. Почему нельзя сделать так, что бы название поля и значение хоть как-то различались??! Это редактировать реально не долго: всего-лишь изменить вёрстку

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

kozhilya написал(а):

Тут всё просто: их нет. Ладно, они есть у имени и у статуса — хоть что-то. Но почему Ни у одного поля нет этого важного аттрибута? Из-за этого кастомизировать эту страницу очень сложно. При этом редактировать эти поля хочется: на ролевых формуах пользовательские поля стилизуются под свои нужды, и тут это тоже нужно.

+++

По первым 3 пунктам согласен, неплохо было бы сделать(правда пару скриптов переделать придется под другой формат тега [align](типа BB-цитирование), но это мелочи, думаю
Особенно со скрытым текстом - плюсую +++ :cool:

Отредактировано Alex_63 (Вс, 12 Фев 2017 16:00:26)

+1

6

На почве начавшегося недавно движа на сервисе (определённо в лучшую сторону, надо отметить), а также с небольшой подсказки Romych об их причине, апаю тему :) Проблемы эти всё ещё есть, и они существуют со дня создания движка...
А ещё я не могу править сообщение, поэтому дополню так.

7. Meta-теги

На дворе 2020 год, и форумы давно перестали быть движущей силой интернета. Не знаю, как у других, а у нас на форуме флудилка практически полностью потеряла всякую популярность. Все давно сидят по мессенджерам. Когда-то это был Skype, а сейчас это ВК, Telegram, WhatsApp, Viber, Discord и я уверен, что существуют и иные способы, которые я даже не знаю... Но не в этом суть.

Вот отправляете вы ссылку в, например, Telegram'е. И мессенджер выдаёт не просто ссылку, но ещё и некоторое превью:

https://i.imgur.com/CpZnE4N.png

Круто, красиво, классно.
А теперь попробуйте отправить ссылку на форум MyBB...

https://i.imgur.com/zz8vRDU.png

Ой. Это просто ссылка. И прикол в том, что это плохо работает и для социальных сетей, в которых сейчас тоже значительная часть продвижения форумов. И если ВКонтакте может более-менее хорошо обработать тему форума, то вот профили...

Картинка

https://i.imgur.com/PhOqylw.png

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

Ну, так и делаем.

Итак, самым основным проколом передачи информации для превью ныне является The Open Graph protocol (русский перевод), его поддерживают все основные социальные сети и мессенджеры.
В нём описано довольно много мета-тегов, которые можно использовать для кастомизации взаимодействия с социальными сетями, однако основными являются: заголовок (og:title), ссылка (og:url)  и картинка (og:image). Дополнительно можно отметить свойства описание (og:description), название сайта (og:site_name), локализация (og:locale) и тип страницы (og:type).

Формат meta-тега довольно простой:

Код:
<meta property="og:{{name}}" content="{{value}}" />

Так что, если собрать все основные данные о странице в массив такого вида:

Код:
Array (
  "title" => "Шайена",
  "url" => "http://tlkthebeginning.ru/profile.php?id=3",
  "image" => "http://forumavatars.ru/img/avatars/000a/f9/fe/3-1561842430.png",
  "type" => "website", // Это по умолчанию
  "site_name" => "Король Лев. Начало", // Это тянется из настроек
  "locale" => "ru_RU", // Тоже из настроек
)

то информацию довольно просто оформить как полноценный код:

Код:
function generateMetatags($meta) {
    $result = [];
    
    foreach($meta as $id => $value) {
        switch($id) {
            case 'title': 
            case 'description': 
                $result[] = '<meta name="'.$id.'" content="'.htmlentities($value).'" />';
                $result[] = '<meta property="og:'.$id.'" content="'.htmlentities($value).'" />';
                break;

            case 'type': 
            case 'site_name':
            case 'url':
            case 'locale':
                $result[] = '<meta property="og:'.$id.'" content="'.htmlentities($value).'" />';
                break;

            case 'image': 
                $data = getimagesize($value);
                $result[] = '<meta property="og:'.$id.'" content="'.htmlentities($value).'" />';
                $result[] = '<meta property="og:'.$id.':type" content="'.htmlentities($data['mime']).'" />';
                $result[] = '<meta property="og:'.$id.':width" content="'.htmlentities($data[0]).'" />';
                $result[] = '<meta property="og:'.$id.':height" content="'.htmlentities($data[1]).'" />';
                break;
        }
    }
    
    return $result;
}

Отредактировано kozhilya (Вс, 26 Июл 2020 15:20:07)

+1

7

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

0

8

А если действительно есть желание с кодом php поработать, то нужно подумать. Наверное, могу сделать доступ к git репозиторию и при push накатывание на тестовый форум.

+3

9

kernel
сделайте отображение полного профиля от сервиса,а то скриптом задержка большая (там фрейм)

0

10

tartar1 написал(а):

kernel
сделайте отображение полного профиля от сервиса,а то скриптом задержка большая (там фрейм)

Нужно больше информации, не понимаю что за полный профиль, что за скрипт.

0

11

kernel
Это про пункт 6.1. предложек, про то, что страницу с просмотром профиля пользователей форума невозможно посмотреть, если у тебя есть права на его редактирование. В итоге приходится либо забивать, либо подгружать её через фрейм.

kernel написал(а):

А если действительно есть желание с кодом php поработать, то нужно подумать. Наверное, могу сделать доступ к git репозиторию и при push накатывание на тестовый форум.

Well, why not?

Отредактировано kozhilya (Вс, 26 Июл 2020 20:00:54)

0

12

kernel
Скрипты от пользователей 3

у многих стоит

0

13

kernel

kernel написал(а):

Нужно больше информации, не понимаю что за полный профиль, что за скрипт.

вот  такой скрипт от алекса пользуется повсеместной популярностью: http://forumd.ru/viewtopic.php?id=5833

думаю, суть ясна. нужен просмотр своего профиля - отдельно, редактирование - отдельно.

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

еще важный момент - у него очень неудобно расположена кнопка редактирования:

Код:
<h1>
    <span>Профиль: Герда</span>
    <span style="float:right;background:none;font-size:1em">
        <a href="http://forumd.ru/profile.php?id=2&amp;section=essentials" style="color:rgb(28, 128, 172)">Редактировать профиль</a>
    </span>
</h1>

заголовки типа h1 на большинстве форума имеют дизайн заголовка с большим шрифтом, на ролевых - обязательно фоновой картинкой, встраиваются всякие рюшечки и display:block не просто на заголовок, а именно на span внутри заголовка. в итоге такую кнопку редактирования настроить - целая история по отключению миллиона унаследованных от заголовков свойств.
я считаю, что "редактировать профиль" надо пихать в profile-left - там только имя, статус, ава и онлайн, место под кнопку есть. можно пихнуть, чтоб юзер ее не потерял НАД ником:

<td id="profile-left">
<li id="edit"><a href="http://forumd.ru/profile.php?id=2&amp;section=essentials" style="color:rgb(28, 128, 172)">Редактировать профиль</a></span></li>
<li id="profile-name"><strong>Герда</strong></li>
....

Отредактировано Герда (Вс, 26 Июл 2020 20:39:28)

+1

14

Герда написал(а):

я считаю, что "редактировать профиль" надо пихать в profile-left - там только имя, статус, ава и онлайн, место под кнопку есть. можно пихнуть, чтоб юзер ее не потерял НАД ником:

А зачем, если для этого есть боковое навигационное меню? На этом форуме оно, например, здесь как раз сверху:
https://i.imgur.com/4Jl80Ds.png

0

15

kozhilya написал(а):

6.2. Вёрстка полей профиля

и еще в посте по профилю - хочу попросить селекторов.
сейчас их там вообще нет.
есть только profile-name и profile-title

если добавить в <li> разных классов под разные поля - будет супер и никаких скриптов не поломается (ибо там селекторов изначально не было) - зато простор для творчества космический.

0

16

kozhilya написал(а):

А зачем, если для этого есть боковое навигационное меню? На этом форуме оно, например, здесь как раз сверху:
https://i.imgur.com/4Jl80Ds.png

я говорю о кнопке перехода в редактирование со страницы полного профиля.
см. скрипт от алекса.

или ты предлагаешь всё меню редактирования показывать на странице полного профиля?
вариант, конечно, но как-то теряется эффект просмотра своего профиля в таком же виде, как его видят пользователи.

Отредактировано Герда (Вс, 26 Июл 2020 20:57:56)

0

17

Герда написал(а):
kozhilya написал(а):

А зачем, если для этого есть боковое навигационное меню? На этом форуме оно, например, здесь как раз сверху:
https://i.imgur.com/4Jl80Ds.png

я говорю о кнопке перехода в редактирование со страницы полного профиля.
см. скрипт от алекса.

или ты предлагаешь всё меню редактирования показывать на странице полного профиля?
вариант, конечно, но как-то теряется эффект просмотра своего профиля в таком же виде, как его видят пользователи.

Да, я именно про это... Прочти ещё раз 6-й пункт :)

0

18

kozhilya написал(а):

Да, я именно про это... Прочти ещё раз 6-й пункт :)

ну... вообще так даже лучше.
решается проблема:

Герда написал(а):

когда массово редактируешь кучу профилей (например, нужно переместить человек 20 в отдельную группу), приходится открывать лишнюю страницу - сначала открыть профиль юзера, потом открыть редактирование, потом открыть нужную вкладку и т.д.

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

0

19

Итак, по поводу профиля. Сейчас, кстати, можно зайти в группу, нажать на кнопку "Посмотреть" у группы, которая не имеет права редактировать и смотреть профили. Но это костыль в некотором роде.

• /profile.php?id=123 — просмотр профиля профиль
• /profile.php?id=123&section=view — тоже просмотр профия
• /profile.php?id=123&section=essentials — редактирование профиля

Менять поведение по-умолчанию не кажется очень хорошей идеей. Параметр section вероятно добавлю.
По вёрстке в профиле, насколько понимаю, большая часть уже не актуальна.

0

20

kernel написал(а):

По вёрстке в профиле, насколько понимаю, большая часть уже не актуальна.

Была какая-то проблема, что страница лс (страница именно сообщений) и профиля как-то неудачно по селекторам пересекались. Если ничего не путаю (углубленно сейчас не рылся), то обе страницы имеют ID profile, что периодически создавало сложности.

0


Вы здесь » Единый форум поддержки » Сделаем сервис лучше » Неглобальные доработки движка MyBB (с предложениями по PHP реализации)