NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript==
// @name Joyreactor advanced script for GM4
// @namespace http://joyreactor.cc/tag/jras
// @description save settings does not work
// @author AntiUser
// @license MIT
// @copyright 2016+, AntiUser (http://joyreactor.cc/user/AntiUser)
// @homepage http://joyreactor.cc/tag/jras
// @homepageURL http://joyreactor.cc/tag/jras
// @supportURL https://github.com/mrAntiUser/JRAS/issues
// @include *reactor.cc*
// @include *joyreactor.cc*
// @include *jr-proxy.com*
// @require http://ajax.googleapis.com/ajax/libs/jquery/2.2.0/jquery.min.js
// @require https://code.jquery.com/ui/1.11.4/jquery-ui.min.js
// @version 1.9.0 for GM4
// @grant GM.getValue
// @grant GM.setValue
// @grant GM.listValues
// @grant GM.deleteValue
// @grant GM.xmlHttpRequest
// @grant unsafeWindow
// @run-at document-end
// ==/UserScript==
const JRAS_CurrVersion = '1.9.0';
/* RELEASE NOTES
1.9.0
* кнопки перехода в начало и конец поста (Issue-48)
1.8.9
* перенос длинных ников в тултипе
1.8.8
* Центрование контента (изображения, гифки, фреймы) (Issue-46)
* поправлена ширина коментов с новыми стилями на не черном олде
+ Опция Центровать контент [true]
1.8.7
* Размер страницы (динамический стиль) теперь считается нормально при разворачивании разных эледементов (Issue-43)
* В свете длинных тегов поправлены стили. Не в скрипте, а в JRAS styles
1.8.5
* Мелкие фиксы
1.8.4
+ Опция: мне нужны только динамические эффекты нового стиля [false]
+ Опции по поведению правого меню (Issue-39)
+ Устанавливать высоту страницы по высоте правого меню [true]
+ Показывать правое меню когда контент вышел за границы [true]
1.8.0 - http://reactor.cc/post/3249308
* Фикс определения цвета темы (Issue-13)
+ Опция скрывать шарные кнопки в БУП [false] (Issue-18.1)
* Корректировка даты поста (Issue-33)
+ Возможность скрыть правое меню и/или настроить ширину контентта (Issue-36)
Опции
+ Корректировать дизайн и стиль сайта [false]
+ Скрывать правое меню [true]
+ Растягивать контент по границам экрана [true]
+ Растягивать контент на (%) [90]
1.7.16
* Исправлен баг даты комментария, которая пропадала или вообще не появлялась (Issue-29)
1.7.15 - http://old.reactor.cc/post/3247143
* Исправлен баг сохранения настроек (спасибо Silent John за тесты и терпение) (Issue-25)
* Исправлен баг добавления в избранное на новом дизайне (Issue-27)
+ Разная иконка для постов, которые уже в избранном и которые еще можно добавить (Issue-20)
+ Вывод даты комментария. Только в старом дизайне и только при включенной опции аватаров для старого дизайна (Issue-17)
+ Опция - "Показывать в коменте его дату" [true] в "Комментарии" > "Создавать аватары для старого дизайна"
+ Опции теперь чекаются при клике по label'у (Issue-11)
+ Опция - Анимировать перемещения блока' [true] (Issue-19)
+ Опция - Скорость перемещения при анимации (1-9) [2]
1.7.2
* Переделал иконки кнопок шары в блоке управления постом (Issue-12)
1.7.1
+ Тултип на юзере в блоке управления постом (Issue-7)
+ Опция показывать тултип на юзере в блоке управления [true]
1.7.0 - http://old.reactor.cc/post/3243856
+ Блок управления постом доступный в любом месте самого поста
+ Информация (автор, дата)
+ шары (все что было плюс добавил телеграм)
+ рейтинг
+ ссылки
Опции
+ Блок управления постом [true] (Issue-1)
+ Только в полном посте [false]
+ Скрывать блок шарных кнопок поста [false]
+ Скрывать блок рейтинга поста [false]
+ Верхний стопор для блока внутри поста (px) [10]
+ Нижний стопор для блока внутри поста (px) [10]
+ Верхняя позиция на экране (px) [30]
1.6.7 - http://old.reactor.cc/post/3235468
+ Показывать в правом баре для лучших коментов [true]
+ Загружать данные тега для Tooltip'а [true]
+ Показывать в ленте [true]
+ Показывать в полном посте [true]
+ Показывать в правом баре для трендов [true]
+ Показывать в правом баре для любимых тегов [true]
+ Показывать в правом баре для интересного [true]
1.6.0 - http://old.reactor.cc/post/3233487
+ Tooltip'ы для тегов
1.5.23
* fix таблиц с гифками на олде
+ версия скрипта в заголовке окна скрипта
1.5.21 - http://old.reactor.cc/post/3151778
+ fix таблиц на олде
* поправлено определение цветовой гаммы страницы
1.5.19
+ user tooltip на лучшем комменте
1.5.18
* исправлен регексп определения стиля страницы
1.5.17
* поддержка сайта old.jr-proxy.com
1.5.16
* опечатки
1.5.15 - http://old.reactor.cc/post/3079550
+ Скрывать комментарий без возможности просмотра [false]
+ Показывать в заблокированном комментрарии ник юзера [true]
+ Удалять пост из ленты полностью [false]
+ Скрывать пост без возможности просмотра [false]
+ Показывать в заблокированном посте ник юзера [true]
1.5.12
+ Определение логина юзера по ссылке, а не по тексту (в свете Soldat AntiUser)
1.5.11 - http://old.reactor.cc/post/2832945
+ В Tooltip'е юзера отметка о том Online ли он или нет (красный - нет, зеленый - да)
1.5.10
* Анимация показа/скрытия верхней панели
+ Опция удаление Share buttons [false]
1.5.8
+ Теперь работает на странице "Обсуждаемое"
1.5.7 - http://old.reactor.cc/post/2760618
+ Показывать аватары пользователей в комментариях [true] (ТОЛЬКО СТАРЫЙ ДИЗАЙН)
+ Показывать аватары только в полном посте [false] (ТОЛЬКО СТАРЫЙ ДИЗАЙН)
+ Размер показываемых аватаров в пикселях [35] (ТОЛЬКО СТАРЫЙ ДИЗАЙН)
+ Опция показывать сразу скрытые заминусованные коменты [false]
+ Опция отмечать раскрытые заминусованные коменты [true]
* Поменял жирноту в Tooltip'е юзера
* Вернул на гифки линк "Ссылка на гифку" в старом дизайне
* мелкие исправления
1.5.0 - http://old.reactor.cc/post/2611233
+ В Tooltip'е юзера информация модератор ли
+ В Tooltip'е юзера информация из блока "Профиль"
1.4.11
* разрешил уменьшение комментариев для хрома
* обработка редиректных ссылок везде, а не только в посте
1.4.10
* при сворачивании к паренту (collapseToParent) не учитывалось текущее состояние ветвей и
некотрые ветви разворачивались если были свернуты
1.4.9 - http://old.reactor.cc/post/2536817
+ добавлен новый адрес на котором работает скрипт - jr-proxy.com
+ свернуть/развернуть все комментарии
+ раскрытие редиректных ссылок. опция - [true]
+ опция уменьшать комментарии только в полном посте [false]
1.4.3
+ Уменьшение комментариев при раскрытии их в ленте (кроме хрома)
* мелкие исправления
1.4.0 - http://old.reactor.cc/post/2527831
+ Уменьшение больших комментариев (опционально)
+ Новые опции
- Уменьшать большие комментарии [true]
- Уменьшать если размер больше (px) [110]
- Уменьшать до (px) [72]
1.3.18
+ Диалог настроек закрывается при нажатии "сохранить"
1.3.17 - http://old.reactor.cc/post/2524192
+ опция "Убирать цветовую отметку донатера" в тултипах [false]
+ опция при каком количестве медальки скрывать [60] (0 - показывать все)
* опция сколько показывать, если скрывать [40]
* добавлены кнопки в GUI настроек
- Отправить мне персональное сообщение
- Удалить все сохраненные данные
- Настройки по умолчанию
* поправлены медальки в тултипе
+ дерево комментариев теперь строится также и в старом дизайне при разворачивании коментов в ленте
+ для комментариев маленькая кнопка collapseToParent при отсутствии большой collapseNode рисуется выше
* поправлена высота ника в тултипе
* мелкие исправления
1.3.6 - http://old.reactor.cc/post/2514832
+ сворачивание комментариев наверх к паренту
* не блокировался юзер в комментариях при раскрытии их в ленте в новом дизайне
1.3.2 - http://old.reactor.cc/post/2513114
+ отправка сообщения пользователю из tooltip'а
+ возможность ограничить количество сразу выводимых в tooltip'е медалек
+ плавающая верхняя панель в новой дизайне
+ автоматическая отметка комментариев как прочитанных при сворачивании ветки
+ настройки сохраняются для каждого пользователя реактора отдельно
+ добавлены опции для настройки работы скрипта
- создавать ли дерево комментариев [true]
- дерево комментариев только для полного поста (в ленте при раскрытии не будет создаваться) [false]
- когда ветка комментариев сворачивается все дочерние коменты помечаются прочитанными [true]
- загружать ли данные пользователя для Tooltip'а [true]
- сколько медалек показывать при загрузке [40] (0 - все)
- зафиксировать верхнюю панель наверху окна (только новый дизайн) [true]
- скрывать зафиксированную верхнюю панель (только новый дизайн) [true]
- показывать Tooltip'ы в ленте [true]
- показывать Tooltip'ы в комментариях [true]
- показывать Tooltip'ы на странице ПМ [true]
- показывать Tooltip'ы на странице Люди [true]
- показывать Tooltip'ы в правом баре для юзеров топа [true]
- показывать Tooltip'ы в правом баре для аватарок [true]
* мелкие исправления
1.2.3
- некоторый фунционал был удален
Если вы обнаружили его недостачу и он вам нужен - пишите ПМ
1.2.2
* добавиил tooltip'ы на:
- страница личных сообщений
- страница люди
- топы в правой колонке
- на авах в правой колонке
* мелкие исправления
1.2.0 - http://old.reactor.cc/post/2504300
+ просмотр информации по пользователю при наведении мыши на его ник
+ возможность добавить в друзья, заблокировать пользователя из tooltip'а
* мелкие исправления
1.1.3
* в хроме на новом дизайне не строилось дерево комментариев при раскрытии их в ленте
* по той же причине не блокировались комментарии пользователей
1.1.0 - http://old.reactor.cc/post/2497823
+ GUI для настройки JRAS
* не блокировались теги на новом дизайне
1.0.6
* в список заблокированных тегов, котрый выводится при блокировке поста
могло попасть содержимое поста, а не только теги
1.0.5
* в случае нахождения блокированного юзера в коментах, мог быть заблокирован пост
1.0.2
* Не работал в хроме из-за неверного определения адреса документа
1.0.0 - http://old.reactor.cc/post/2485300
+ release
*/
(function(win){
'use strict';
win.console.log(' ================ start JRAS');
if (location.host == 'json.joyreactor.cc'){
win.console.log(' ================ end JRAS - page is sexy runetki');
return;
}
const MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver;
const defLoadTooltipSize = 212;
const defUserTooltipSize = 212;
const defTagTooltipSize = 270;
const lng = new LanguageData();
const page = new PageData();
const userOptions = initOptions();
userOptions.loadUserData(page.currentUser);
try{
correctStyle();
correctPostDate();
addNewCSSClasses();
themeDependentCSS();
makePropElements();
makeAllUserTooltip();
makeAllTagTooltip();
makePostControls();
procTopbar();
removeRedirectLink();
removeShareButtons();
if (page.pageIs('post') || page.pageIs('discussion')){
showHiddenComments();
correctCommentSize();
makeTreeComments();
makeAvatarOnOldDesign();
}
userRemove(userOptions.data.BlockUsers);
tagRemove(userOptions.data.BlockTags, true);
subscribeShowComment();
dynamicStyle();
}catch(err){
win.console.log("~~JRAS_ERROR: " + err + ' (line ' + (err.lineNumber || '') + ')')
}
win.console.log(' ================ end JRAS');
//=====================================================================================================
function initOptions(){
const retVal = {
data: {
currentLng: {
dt: null,
def: 'ru',
type: 'combobox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SELECTLANGUAGE')},
values: function(){return lng.getLangs()}
},
correctRedirectLink: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_CORRECTREDIRECTLINK')}
},
removeShareButtons: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_REMOVESHAREBUTTONS')}
},
makeAvatarOnOldDesign: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_MAKEAVATARONOLDDESIGN')}
},
makeAvatarOnlyFullPost: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){ return lng.getVal('JRAS_GUI_MAKEAVATARONLYFULLPOST')}
},
avatarHeight: {
dt: null,
def: 35,
type: 'number',
min: 5,
max: 300,
init: function(){this.dt = this.def},
validator: function(val){return $.isNumeric(val) && val >= this.min && val <= this.max},
guiDesc: function(){return lng.getVal('JRAS_GUI_AVATARHEIGHT')}
},
makeTreeComments: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_MAKETREECOMMENTS')}
},
treeCommentsOnlyFullPost: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_TREECOMMENTSONLYFULLPOST')}
},
whenCollapseMakeRead: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_WHENCOLLAPSEMAKEREAD')}
},
isToBeLoadingUserData: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_ISTOBELOADINGUSERDATA')}
},
hideUserAwardsWhen: {
dt: null,
def: 60,
type: 'combobox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_HIDEUSERAWARDSWHEN')},
values: function(){
const retVal = {};
for(let i = 0; i < 101; i += 5){
if (i != 0 && i < 20){continue}
retVal[i] = i;
}
return retVal;
}
},
minShowUserAwards: {
dt: null,
def: 40,
type: 'combobox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_MINSHOWUSERAWARDS')},
values: function(){
const retVal = {};
for(let i = 10; i < 101; i += 10){ retVal[i] = i }
return retVal;
}
},
fixedTopbar: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_FIXEDTOPBAR')}
},
hideFixedTopbar: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_HIDEFIXEDTOPBAR')}
},
showUTOnLine: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUTONLINE')}
},
showUTOnComment: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUTONCOMMENT')}
},
showUTOnPrivateMess: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUTONPRIVATEMESS')}
},
showUTOnPeople: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUTONPEOPLE')}
},
showUTOnSidebarTopUsers: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUTONSIDEBARTOPUSERS')}
},
showUTOnTopComments: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUTONTOPCOMMENTS')}
},
showUTOnSidebarOnline: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUTONSIDEBARONLINE')}
},
showUTOnPostControl: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUTONPOSTCONTROL')}
},
showHiddenComments: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWHIDDENCOMMENTS')}
},
showHiddenCommentsMark: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWHIDDENCOMMENTSMARK')}
},
isToBeLoadingTagData: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_ISTOBELOADINGTAGDATA')}
},
showTTOnTrends: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWTTONTRENDS')}
},
showTTOnLikeTags: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWTTONLIKETAGS')}
},
showTTOnInteresting: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWTTONINTERESTING')}
},
showTTOnLine: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWTTONLINE')}
},
showTTFullPost: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWTTFULLPOST')}
},
delUserComment: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_DELUSERCOMMENT')}
},
showUserNameDelComment: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUSERNAMEDELCOMMENT')}
},
fullDelUserPost: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_FULLDELUSERPOST')}
},
delUserPost: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_DELUSERPOST')}
},
showUserNameDelPost: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWUSERNAMEDELPOST')}
},
chatlaneToPacaki: { // Убирать цветовую отметку донатера
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_CHATLANETOPACAKI')}
},
collapseComments: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_COLLAPSECOMMENTS')}
},
collapseCommentsOnlyFullPost: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_COLLAPSECOMMENTSONLYFULLPOST')}
},
collapseCommentWhenSize: {
dt: null,
def: 110,
type: 'number',
min: 20,
max: 10000,
init: function(){this.dt = this.def},
validator: function(val){return $.isNumeric(val) && val >= this.min && val <= this.max},
guiDesc: function(){return lng.getVal('JRAS_GUI_COLLAPSECOMMENTWHENSIZE')}
},
collapseCommentToSize: {
dt: null,
def: 72,
type: 'number',
min: 20,
max: 10000,
init: function(){this.dt = this.def},
validator: function(val){return $.isNumeric(val) && val >= this.min && val <= this.max},
guiDesc: function(){return lng.getVal('JRAS_GUI_COLLAPSECOMMENTTOSIZE')}
},
pcbShowPostControl: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBSHOWPOSTCONTROL')}
},
pcbShowInFullPost: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBSHOWINFULLPOST')}
},
pcbHideJRShareBlock: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBHIDEJRSHAREBLOCK')}
},
pcbHideJRRatingBlock: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBHIDEJRRATINGBLOCK')}
},
pcbTopBorder: {
dt: null,
def: 10,
type: 'number',
min: 0,
max: 200,
init: function(){this.dt = this.def},
validator: function(val){return $.isNumeric(val) && val >= this.min && val <= this.max},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBTOPBORDER')}
},
pcbBottomBorder: {
dt: null,
def: 10,
type: 'number',
min: 0,
max: 200,
init: function(){this.dt = this.def},
validator: function(val){return $.isNumeric(val) && val >= this.min && val <= this.max},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBBOTTOMBORDER')}
},
pcbTopScreenPos: {
dt: null,
def: 30,
type: 'number',
min: 0,
max: 200,
init: function(){this.dt = this.def},
validator: function(val){return $.isNumeric(val) && val >= this.min && val <= this.max},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBTOPSCREENPOS')}
},
showCommentDate: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_SHOWCOMMENTDATE')}
},
pcbAnimateMove: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBANIMATEMOVE')}
},
pcbAnimateMoveSpeed: {
dt: null,
def: 2,
type: 'number',
min: 1,
max: 9,
init: function(){this.dt = this.def},
validator: function(val){return $.isNumeric(val) && val >= this.min && val <= this.max},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBANIMATEMOVESPEED')}
},
pcbHideShareButoons: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_PCBHIDESHAREBUTOONS')}
},
stCorrectStyle: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_STCORRECTSTYLE')}
},
stHideSideBar: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_STHIDESIDEBAR')}
},
stStretchContent: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_STSTRETCHCONTENT')}
},
stStretchSize: {
dt: null,
def: 90,
type: 'number',
min: 60,
max: 100,
init: function(){this.dt = this.def},
validator: function(val){return $.isNumeric(val) && val >= this.min && val <= this.max},
guiDesc: function(){return lng.getVal('JRAS_GUI_STSTRETCHSIZE')}
},
stSideBarSizeToPage: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_STSIDEBARSIZETOPAGE')}
},
stShowSideBarOnHideContent: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_STSHOWSIDEBARONHIDECONTENT')}
},
stUseDynStyleChanges: {
dt: null,
def: false,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_STUSEDYNSTYLECHANGES')}
},
stCenterContent: {
dt: null,
def: true,
type: 'checkbox',
init: function(){this.dt = this.def},
guiDesc: function(){return lng.getVal('JRAS_GUI_STCENTERCONTENT')}
},
BlockUsers: [],
BlockTags: []
},
each: function(func){
if (func === undefined){return}
for(let dItm in this.data){
if((dItm == undefined) || (dItm == 'BlockUsers') || (dItm == 'BlockTags')){continue}
func(dItm, this.data[dItm]);
}
},
val: function(option, value){
if(this.data[option]){
if(value === undefined){
return this.data[option].dt
}else{
if (this.data[option]['validator']){
if (this.data[option].validator(value)){
this.data[option].dt = value;
}else{
this.data[option].init();
}
}else{
this.data[option].dt = value;
}
}
}
},
getGuiDesc: function(option){
return (this.data[option]) ? this.data[option].guiDesc() : option;
},
setDef: function(){
this.each(function(optName, opt){ opt.init() });
this.data.BlockUsers = [];
this.data.BlockTags = [];
},
removeAllSavedData: function(){
this.removeSavedUserData();
},
correctForRegexp: function(str){
return str.replace(/[.*\W[\]\\]/g, '_');
},
removeSavedUserData: function(user){
user = this.correctForRegexp(user);
let pref = (user === undefined) ? '' : user + '_';
let keys = GM.listValues();
for(let i = 0; i < keys.length; i++){
let key = keys[i];
if(key.match(new RegExp(pref + '.*'))){
GM.deleteValue(key);
}
}
},
saveUserData: function(forUser){
forUser = this.correctForRegexp(forUser);
this.removeSavedUserData(forUser);
const pref = forUser + '_';
this.each(function(optName, opt){
GM.setValue(pref + optName, opt.dt);
});
for(let i = 0; i < this.data.BlockUsers.length; i++){
GM.setValue(pref + 'BlockUsers_name_' + i, this.data.BlockUsers[i]);
}
for(let i = 0; i < this.data.BlockTags.length; i++){
GM.setValue(pref + 'BlockTags_name_' + i, this.data.BlockTags[i]);
}
},
loadUserDataFrom: function(prefix){
prefix = this.correctForRegexp(prefix);
let retVal = false;
const posf = '.*';
let keys = GM.listValues();
this.data.BlockUsers = [];
this.data.BlockTags = [];
for(let i = 0; i < keys.length; i++){
let key = keys[i];
if(!key.match(new RegExp(prefix + posf))){
continue
}
if(key.match(new RegExp(prefix + 'BlockUsers_name_' + posf))){
this.data.BlockUsers.push(GM.getValue(key, ''));
}else{
if(key.match(new RegExp(prefix + 'BlockTags_name_' + posf))){
this.data.BlockTags.push(GM.getValue(key, ''));
}else{
const rkey = key.replace(prefix, '');
if(this.data[rkey] === undefined){
continue
}
this.data[rkey].dt = GM.getValue(key, this.data[rkey]);
retVal = true;
}
}
}
this.data.BlockUsers.sort();
this.data.BlockTags.sort();
return retVal;
},
loadUserData: function(forUser){
if(this.loadUserDataFrom(forUser + '_')){
return
}
if(this.loadUserDataFrom(forUser)){
this.saveUserData(forUser);
}
}
};
retVal.setDef();
return retVal;
}
function removeRedirectLink($inElm){
if(!userOptions.val('correctRedirectLink')){
return;
}
let $selElmts;
if ($inElm === undefined){
$selElmts = $(('a[href*="redirect?"]'));
} else{
$selElmts = $inElm.find('a[href*="redirect?"]');
}
$selElmts.each(function(){
const $currA = $(this);
const matches = /(?:\?|\&)([\w]+)(?:\=|\&?)([^&#]*)/g.exec($currA.attr('href'));
$.each(matches, function(index){
if (matches[index] == 'url'){
$currA.attr('href', decodeURIComponent(matches[index + 1]));
return false;
}
});
});
}
function removeShareButtons(){
if(!userOptions.val('removeShareButtons')){
return;
}
removeElementsByClass('a', ['share_vk', 'share_fb', 'share_twitter', 'share_mail']);
}
function makeAllTagTooltip(){
if(!userOptions.val('isToBeLoadingTagData')){
return;
}
let sel = [];
if(userOptions.val('showTTOnLine')){
sel.push('div.postContainer h2.taglist a');
}
if(userOptions.val('showTTFullPost')){
sel.push('div.postContainer strong.taglist a');
}
if(userOptions.val('showTTOnTrends')){
sel.push('div.sidebar_block.trends_wr > div.sidebarContent > div.blogs > table > tbody > tr > td:nth-child(2) > a');
}
if(userOptions.val('showTTOnLikeTags')){
sel.push('div.sidebarContent > div.blogs#blogs_alltime_content > table > tbody > tr > td:nth-child(2) > a');
sel.push('div.sidebarContent > div.blogs#blogs_week_content > table > tbody > tr > td:nth-child(2) > a');
sel.push('div.sidebarContent > div.blogs#blogs_2days_content > table > tbody > tr > td:nth-child(2) > a');
}
if(userOptions.val('showTTOnInteresting')){ //интересное
sel.push('div.sidebar_block.blogs_wr > div.sidebarContent > div.blogs > table > tbody > tr > td:nth-child(2) > a');
}
if(sel.length != 0){
makeTagTooltips(sel.join(', '));
}
}
function makeAllUserTooltip(){
if(!userOptions.val('isToBeLoadingUserData')){
return;
}
let sel = [];
sel.push('div.comments_bottom > span >a.comment_username');
if(userOptions.val('showUTOnLine')){
sel.push('div.uhead_nick > a');
}
if(userOptions.val('showUTOnComment')){
sel.push('span.reply-link > a:first-child');
}
if(userOptions.val('showUTOnPrivateMess')){
sel.push('div.mess_from > a');
}
if(userOptions.val('showUTOnPeople')){
sel.push('div.user > div.userblock > a');
}
if(userOptions.val('showUTOnSidebarTopUsers')){
sel.push('div.user.week_top > a');
}
if(userOptions.val('showUTOnSidebarOnline')){
sel.push('div.avatar_holder > a');
}
if(userOptions.val('showUTOnTopComments')){
sel.push('div.topComments small > a');
}
if(sel.length != 0){
makeUserTooltips(sel.join(', '));
}
}
function removeElementsByClass(elm, removeClassArr){
if(removeClassArr == null){
return
}
for(let i = 0; i < removeClassArr.length; i++){
$(elm + '.' + removeClassArr[i]).each(function(){
$(this).remove();
})
}
}
function procTopbar(){
if (!page.isNewDesign){return}
if(userOptions.val('fixedTopbar')){
$('#topbar.topbar_wr').css({
'position': 'fixed',
'background': 'rgba(57, 47, 30, 0.85) none repeat scroll 0% 0%',
'box-shadow': '0px -6px 10px 9px rgb(0, 0, 0)'});
if(userOptions.val('hideFixedTopbar')){
const checkPos = function(){
let $topbar = $('#topbar.topbar_wr');
$topbar.find('.topbar_inner').css({'transition': 'top .4s cubic-bezier(.45,.05,.55,.95)', 'top': '-40px'});
$topbar.css({'transition': 'height .4s cubic-bezier(.45,.05,.55,.95)', 'height': '10px'});
$topbar.hover(function(e) {
let a = $(win).scrollTop() < 38 ? -$(window).scrollTop() : '-40px';
$(this).find('.topbar_inner').css('top', e.type === 'mouseenter' ? '0' : a);
a = $(win).scrollTop() < 38 ? 45 - $(window).scrollTop() : '10px';
$(this).css('height', e.type === 'mouseenter' ? '45px' : a);
});
if ($(win).scrollTop() < 38){
$topbar.mouseenter();
$topbar.mouseleave();
}
};
checkPos();
$(window).on('scroll', function(){
// $(win).scroll(function(){
checkPos();
});
}
}
}
function userRemove(userNameArr){
let currentUser;
const blockUsersAsFindStr = 'a:contains(' + userOptions.data.BlockUsers.join('), a:contains(') + ')';
$(blockUsersAsFindStr).parent('div.uhead_nick').closest('div.article').each(function(idx, elm){
currentUser = $(this).find(blockUsersAsFindStr).text();
if(userNameArr.indexOf(currentUser) != -1){
if (userOptions.val('fullDelUserPost')){
$(this).remove();
return;
}
elm.parentElement.style.paddingBottom = '40px';
makeBlockPostElements(elm, elm.parentElement.id, lng.getVal('JRAS_POSTBLOCKBYUSER'), currentUser, '', false);
// win.console.info(' user - ' + currentUser + ' : hide post - ' + elm.parentElement.id);
$(this).hide();
}
});
$(blockUsersAsFindStr).parent('span.reply-link').closest('div[id^=comment_txt_].txt').each(function(idx, elm){
currentUser = $(this).find(blockUsersAsFindStr).text();
if(userNameArr.indexOf(currentUser) != -1){
// $(this).remove(); // для просто удаления. Будет пустой комент
// return;
makeBlockCommElements(elm, elm.parentElement.id, lng.getVal('JRAS_COMMBLOCKBYUSER'), currentUser);
// win.console.info(' user - ' + currentUser + ' : hide comment - ' + elm.parentElement.id);
$(this).hide();
}
})
}
function tagRemove(tagNameArr, strictComp){
const findStr = 'a:contains(' + tagNameArr.join('), a:contains(') + ')';
// findStr = ':contains(Anime):not(:contains(Anime Coub))'; // тест варианта условной блокировки
$('.taglist ' + findStr).closest('div.article').each(function(idx, elm){
let foundTagStr = '';
let validTag = strictComp !== true;
$(this).find('.taglist').find(findStr).text(function(index, text){
if(strictComp === true){
validTag = validTag || tagNameArr.indexOf(text) != -1;
}
foundTagStr += ' "' + text + '"';
});
if(validTag){
// $(this).remove();
// return;
elm.parentElement.style.paddingBottom = '40px';
makeBlockPostElements(elm, elm.parentElement.id, lng.getVal('JRAS_POSTBLOCKBYTAG'), foundTagStr, '', true);
// win.console.info('hide post by tag - ' + foundTagStr);
$(this).hide();
}
})
}
function showHiddenComments($inElm){
if (!userOptions.val('showHiddenComments')){
return;
}
const $selElmts = ($inElm === undefined)
? $('div[id^=comment].comment.hidden a.comment_show')
: $inElm.find('a.comment_show')
;
$selElmts.each(function(idx, elm){
elm.click();
if (userOptions.val('showHiddenCommentsMark')){
let $parElm = $(elm).parent('div[id^=comment].txt');
if (page.isNewDesign && userOptions.val('collapseComments')){
$parElm = $(elm).parent().parent('div[id^=comment].txt');
if (userOptions.val('collapseCommentsOnlyFullPost') && !page.pageIs('post')){
$parElm = $(elm).parent('div[id^=comment].txt');
}
}
$parElm.css({'color': 'rgb(255, 57, 57)'});
}
})
}
function correctCommentSize(){
if (!userOptions.val('collapseComments')){
return;
}
$('div[id^=comment].comment>div[id^=comment_txt_].txt').each(function(idx, elm){
makeCommentSizer(elm);
})
}
function makeCommentSizer(elm){
const makeBody = function($newCommBoy){
const origHeight = parseInt($newCommBoy.height());
if (origHeight < userOptions.val('collapseCommentWhenSize')){
return
}
$newCommBoy.attr('origheight', origHeight)
.after('<div id="jras-commSizer-sizer-all" title="' + lng.getVal('JRAS_COMMENTS_EXPANDCOLL_ALL') + '" class="jras-comment-expand-all jras-comment-expand-all-img"></div><div id="jras-commSizer-sizer" class="jras-comment-sizer"></div><br>')
.css({
'height': userOptions.val('collapseCommentToSize') + 'px',
'overflow': 'hidden'
});
$(elm).find('#jras-commSizer-sizer').click(function(e, option){
let opt = option;
if (!opt){
opt = {action:'', correctPos:true}
}
const $commBody = $(this).parent().find('#jras-commSizer-newBody');
let h = $commBody.attr('origheight');
const op = userOptions.val('collapseCommentToSize');
switch (opt.action) {
case 'open':
break;
case 'close':
h = op;
break;
default:
h = parseInt($commBody.height()) == h ? op : h ;
break;
}
$commBody.animate({ 'height': h }, {
duration: 300,
complete: function(){
correctPageHeight();
if (!opt.correctPos) {return}
const tmp = $(this).closest('div[id^=comment].comment').offset().top;
if(tmp < win.pageYOffset){
$('html, body')
.animate({
scrollTop: tmp - 20
}, 'slow');
}
}
});
});
$(elm).find('#jras-commSizer-sizer-all').click(function(){
const h = parseInt($(this).parent().find('#jras-commSizer-newBody').css('height'));
const action = (userOptions.val('collapseCommentToSize') == h) ? 'open' : 'close' ;
$('div#jras-commSizer-sizer.jras-comment-sizer').each(function(){
$(this).trigger('click', [{action: action, correctPos: false}]);
});
})
};
let selector;
if (page.isNewDesign){
selector = ':not(.comments_bottom)';
} else{
if (parseInt($(elm).height()) < userOptions.val('collapseCommentWhenSize')){
return;
}
selector = ':not(.reply-link)';
}
const $newDiv = $(elm).prepend('<div id="jras-commSizer-newBody" style="overflow: hidden;"></div>')
.find('#jras-commSizer-newBody');
let $child = $(elm).find(' > :first-child').next();
while($child.is(selector)){
$newDiv.append($child);
$child = $(elm).find(' > :first-child').next();
}
makeBody($newDiv);
}
function subscribeShowComment(){
const observer = new MutationObserver(function(mutations){
mutations.forEach(function(mutation){
if (mutation.type === 'childList'){
setTimeout(function(){
if (userOptions.val('showUTOnComment')){
makeUserTooltips($(mutation.addedNodes).find('span.reply-link > a:first-child'), 'a');
}
for (let i = 0; i < mutation.addedNodes.length; i++){
const itm = mutation.addedNodes[i];
removeRedirectLink($(itm));
showHiddenComments($(itm));
if (userOptions.val('collapseComments')
&& !userOptions.val('collapseCommentsOnlyFullPost')
//&& !page.isChrome // в хроме не работает. Не хочу разбираться возвращает хз какой height
){
$(itm).find('div[id^=comment].comment>div[id^=comment_txt_].txt').each(function(idx, elm){
makeCommentSizer(elm);
})
}
if ($(itm).is('div[id^=comment_list_post].comment_list_post')){
$(itm).find('div[id^=comment].comment').each(function(idx, elm){
if (userOptions.val('makeTreeComments') && !userOptions.val('treeCommentsOnlyFullPost')){
makeTreeCommentNode(elm, elm.id.replace('comment', ''));
}
if (userOptions.val('makeAvatarOnOldDesign') && !userOptions.val('makeAvatarOnlyFullPost')){
makeAvatarOnOldDesign(elm);
}
})
}
const blockUsersAsFindStr = 'a:contains(' + userOptions.data.BlockUsers.join('), a:contains(') + ')';
$(itm).find(blockUsersAsFindStr).closest('div[id^=comment_txt_].txt').each(function(idx, elm){
const currUser = $.trim($(this).find(blockUsersAsFindStr).text());
if (userOptions.data.BlockUsers.indexOf(currUser) != -1){
makeBlockCommElements(elm, elm.parentElement.id, lng.getVal('JRAS_COMMBLOCKBYUSER'), currUser);
$(this).hide();
}
})
}
correctPageHeight();
}, 10
);
}
});
});
$('div.post_comment_list').each(function(idx, elm){
observer.observe(elm, {
characterData: true,
childList: true,
subtree: true
});
})
}
function makeTreeComments(){
if(userOptions.val('makeTreeComments')){
setTimeout(function(){
$('div[id^=comment].comment').each(function(idx, elm){
makeTreeCommentNode(elm, elm.id.replace('comment', ''));
})
}, 10
);
}
}
function blinkElement($element, count){
for(let i = 0; i < count; i++){
$element.fadeTo('fast', 0.3).fadeTo('fast', 1.0);
}
}
function makeTreeCommentNode(elm, commentID){
if($(elm).find('span#treeColl' + commentID)[0]){
return
}
const collapseToParent = function(design){
let retVal = null;
const $parentElm = $(elm).parent();
if($parentElm.prev().is('div[id^=comment].comment') && $(elm).is(':not(:first-child)')){
// если парент elm - div#comment???.comment и elm не первый чилд
const parentNodeID = $parentElm.prop('id');
const $newElm = $(elm).prepend(design.replace('##parentNodeID##', parentNodeID))
.find('div#jras-colltoparent-' + commentID);
$newElm.click(function(){
const $par = $('div#' + $(this).attr('parentNodeID'));
$par.prev().find('>div[id^=comment_txt_].txt>div#jras-commSizer-sizer').trigger('click', [{action: 'close', correctPos: false}]);
const currID = $(this).parent().prop('id');
let $child = $par.find('>:first-child');
while($child.prop('id') != currID){
// Сворачиваем ноды
$child.find('>div[id^=jras-treecomm]:first-child').trigger('click', [{action: 'close'}]);
// Сворачиваем большие коменты
$child.find('>div[id^=comment_txt_].txt>div#jras-commSizer-sizer').trigger('click', [{action: 'close', correctPos: false}]);
$child = $child.next();
}
// далее происходит следующее
// сдвигаем все вверх, так чтобы парент был на четверть экрана ниже верхней границы
// когда анимация закончится проверим виден ли основной комент
// если он находится ниже видимой области экрана,
// то сдвинем парент на самый верх экрана
// и помигаем :)
$('html, body')
.animate({
scrollTop: $par.prev().offset().top - (win.innerHeight / 4)
}, {
complete: function(){
if($(elm).offset().top > win.pageYOffset + win.innerHeight){
$('html, body')
.animate({
scrollTop: $(elm).parent().prev().offset().top - 20
}, 'slow');
}
for(let i = 0; i < 3; i++){
$(elm).parent().prev().fadeTo('fast', 0.3).fadeTo('fast', 1.0);
$(elm).fadeTo('fast', 0.3).fadeTo('fast', 1.0);
}
}
});
correctPageHeight();
});
retVal = $newElm;
}
return retVal;
};
let colTreeCSSForPlus;
let colTreeCSSForMinus;
const collapseTreeClick = function(e, option){
if (!option){
option = {action: ''};
}
const setPlus = function(elm){
elm.text('+');
elm.css(colTreeCSSForPlus);
if(userOptions.val('whenCollapseMakeRead')){
$toggleContainer.find('div.new').removeClass('new');
}
};
const setMinus = function(elm){
elm.text('-');
elm.css(colTreeCSSForMinus);
};
const slide = function(slideCont, act){
switch (act) {
case 'open':
setMinus($treeColl);
slideCont.slideDown('display');
break;
case 'close':
setPlus($treeColl);
slideCont.slideUp('display');
break;
default:
if(slideCont.css('display') == 'none'){
setMinus($treeColl);
}else{
setPlus($treeColl);
}
slideCont.slideToggle('display');
break;
}
};
const $toggleContainer = $('#comment_list_comment_' + commentID);
const $treeColl = $('span#treeColl' + commentID);
slide($toggleContainer, option.action);
};
let $collToPar;
const needCollTree = $(elm).next().children().length != 0;
if(page.isNewDesign){
$collToPar = collapseToParent(`<div id="jras-colltoparent-${commentID}" parentNodeID="##parentNodeID##" class="treeCross-new treeCross-new-toparent">
<t style="position: absolute;margin-left: 3px;margin-top: -5px;font-size: 11px;font-weight: bold;">^</t></div>`);
if(needCollTree){
colTreeCSSForPlus = {'margin-left': '-1px'};
colTreeCSSForMinus = {'margin-left': '1px'};
$(elm).prepend(`<div id="jras-treecomm-${commentID}" class="treeCross-new">
<span id="treeColl${commentID}" style="margin-left: 1px; margin-top: -10px;">-</span></div>
`).find('div#jras-treecomm-' + commentID)
.click(collapseTreeClick);
}
if($collToPar !== null || needCollTree){
$(elm).find('>div.txt').css('padding-left', '15px');
if($collToPar !== null && !needCollTree){
$collToPar.css('margin-top', '-3px')
}
}
}else{
$collToPar = collapseToParent(`<div id="jras-colltoparent-${commentID}" parentNodeID="##parentNodeID##" class="comment treeCross-old treeCross-old-toparent">
<t style="margin-left: -4px;margin-top: -3px;position: absolute;font-size: 8px;">^</t></div>`);
if(needCollTree){
colTreeCSSForPlus = {'margin-left': '-2px'};
colTreeCSSForMinus = {'margin-left': '0px'};
$(elm).prepend(`<div id="jras-treecomm-${commentID}" class="comment treeCross-old">
<span id="treeColl${commentID}" style="margin-left: 0;">-</span></div>
`).find('div#jras-treecomm-' + commentID)
.click(collapseTreeClick);
$(elm).find('>div.avatar')
.addClass('avatarCorrect')
.css('left', '-10px');
}
if($collToPar !== null || needCollTree){
$(elm).find('>div.avatar').addClass('avatarCorrect').css('left', '-10px');
if($collToPar !== null && !needCollTree){
$collToPar.css({'margin-top': '-3px', 'margin-left': '-36px'})
}
}
}
}
function makeAvatarOnOldDesign(elm){
if (page.isNewDesign){
return
}
if (elm === undefined){
if (!userOptions.val('makeAvatarOnOldDesign')){
return
}
$('div[id^=comment].comment').each(function(idx, elm){
makeAvatarOnOldDesign(elm, elm.id.replace('comment', ''));
})
}else{
const $elm = $(elm);
const $avaOldElm = $elm.find('>div.avatar');
let commDate = $avaOldElm.attr('title');
$avaOldElm.before(`<img class="avatarForOldDesign" src="/pics/avatar/user/${$elm.attr('userid')}" title="${commDate}">`);
const $avaNewElm = $elm.find('>img.avatarForOldDesign');
$avaNewElm.css({'height': userOptions.val('avatarHeight') + 'px'});
//if(!userOptions.val('makeTreeComments')){
// $avaNewElm.css({'margin-left': '-16px'});
//}
$elm.find('>div[id^=comment_txt_].txt>span:not([class]):first').after('<br>');
$avaOldElm.remove();
if (userOptions.val('showCommentDate')){
$(`<span style="font-size: 75%;opacity: 0.5;">${commDate} — </span>`).insertBefore($elm.find('span.reply-link'));
}
}
}
function correctPostDate(){
const $spanDate = $('body').find('div#contentinner div.article.post-normal div.ufoot span.date');
const reconnect = function($th, observe){
observe.observe($th.get(0), {subtree: true, attributes: true, childList: true});
};
let obs = [];
$spanDate.each(function(idx){
const corrDate = function($th, observe){
if (observe != null){observe.disconnect()}
const $spanDateCurr = $($th).find('>span:first');
$spanDateCurr.children().remove();
$spanDateCurr.append(`<span style="margin-right: 20px;">${new Date(+$spanDateCurr.attr('data-time') * 1000).toLocaleString('ru', { weekday: 'short', year: 'numeric', month: 'long', day: 'numeric', hour: 'numeric', minute: 'numeric', second: 'numeric'})}</span>`);
};
const $th = $(this);
corrDate($th, obs[idx]);
obs[idx] = new MutationObserver(function(){corrDate($th, obs[idx])});
reconnect($th, obs[idx]);
});
}
function getPostID(strPostID){
const ret = /[0-9]+(\d?\.\d+)?/g.exec(strPostID);
return (ret == undefined) ? '' : ret[0];
}
function makePostControls(){
if (!userOptions.val('pcbShowPostControl')) {return}
const step = 25;
const itmHeight = (page.isNewDesign) ? 24 : 16;
const itmContentPos = itmHeight + 5;
let st = (page.isNewDesign) ? 'new' : 'old';
if (st == 'old' && !page.isSchemeLight()){
st = st + '-dark';
}
const getFavData = function($container){
let ret = {};
if ($container.find('div.uhead_share span.favorite_link.favorite')[0]){
ret.Img = 'jras-pcShareFAV-exists-img';
ret.Title = lng.getVal('JRAS_REMOVEFAVORITE');
}else{
ret.Img = 'jras-pcShareFAV-img' ;
ret.Title = lng.getVal('JRAS_ADDFAVORITE');
}
return ret;
};
const makePostCtrl = function($th){
const $postContainer = $th;
const postID = getPostID($postContainer.attr('id'));
if (postID == ''){return}
$postContainer.find('div#jras-PostControlBlock').remove();
if (userOptions.val('pcbHideJRShareBlock')) {$postContainer.find('div.uhead_share').css('display', 'none')}
if (userOptions.val('pcbHideJRRatingBlock')) {$postContainer.find('div.ufoot span.post_rating').css('display', 'none')}
const favData = getFavData($postContainer);
setTimeout(function(){
const postUrl = location.protocol + '//' + location.hostname + '/post/' + postID;
const postUrlShare = postUrl + '?social=1';
const pcbShareButtons = (!userOptions.val('pcbHideShareButoons'))
? `<a href="https://t.me/share/url?url=${postUrlShare}" title="Telegram" class="jras-pcShareTEL-img" rel="nofollow" target="_blank"></a>
<a href="http://vkontakte.ru/share.php?url=${postUrlShare}" title="Vkontakte" class="jras-pcShareVK-img" rel="nofollow" target="_blank"></a>
<a href="http://connect.mail.ru/share?url=${postUrlShare}" title="Mail.ru" class="jras-pcShareMAIL-img" rel="nofollow" target="_blank"></a>
<a href="http://twitter.com/home?status=${postUrlShare}" title="Twitter" class="jras-pcShareTWIT-img" rel="nofollow" target="_blank"></a>
<a href="http://www.facebook.com/sharer.php?u=${postUrlShare}" title="Facebook" class="jras-pcShareFACE-img" rel="nofollow" target="_blank"></a>`
: '';
$postContainer.find('div.article').each(function(){
$(this).css({'overflow':'hidden'});
$(this).prepend(`
<div id="jras-PostControlBlock" postID="${postID}" class="jras-PostControlBlock-${st}" style="white-space: nowrap; height: ${step * 4}px;">
<sitm id="jras-PostControlInfo" class="jras-pcInfo-img" style="top:0; height: ${itmHeight}px; ${(page.isNewDesign)?'padding: 2px;':''}">
<a id="jras-pcInfoUser" href="#" style="margin-left: ${itmContentPos}px;"></a>
</sitm>
<sitm id="jras-PostControlShare" class="jras-pcShare-img" style="top:${step}px; height: ${itmHeight}px;">
<a id="jras-pcbShareFAV" href="#" title="${favData.Title}" class="${favData.Img}" style="margin-left: ${itmContentPos + 5}px;"></a>
${pcbShareButtons}
</sitm>
<sitm id="jras-PostControlRating" class="jras-pcRating-img" style="top:${step * 2}px; height: ${itmHeight}px; ${(page.isNewDesign)?'padding: 4px;':''}">
<span style="margin-left: ${itmContentPos}px;">
</sitm>
<sitm id="jras-PostControlLinks" class="jras-pcLinks-img" style="top:${step * 3}px; height: ${itmHeight}px; ${(page.isNewDesign)?'padding: 2px;':''}"></sitm>
</div>
`);
});
const $postBlock = $postContainer.find('div#jras-PostControlBlock');
if (userOptions.val('pcbAnimateMove')){
$postBlock.css('transition', `0.${10 - +userOptions.val('pcbAnimateMoveSpeed')}s cubic-bezier(0.76, -0.48, 0.27, 1.42)`);
}
const $infoUserA = $postContainer.find('div.uhead div.uhead_nick a');
const $infoUserDate = $postContainer.find('div.ufoot span.date > span');
const $pcInfoUser = $postContainer.find('sitm#jras-PostControlInfo');
$pcInfoUser.find('a#jras-pcInfoUser').attr('href', $infoUserA.attr('href')).text($infoUserA.text());
$pcInfoUser.append('<span> — </span>');
$pcInfoUser.append($infoUserDate.clone());
if (userOptions.val('showUTOnPostControl')){makeUserTooltips($pcInfoUser.find('a#jras-pcInfoUser'))}
postControlSlider($pcInfoUser, itmHeight + $infoUserA.width() + $infoUserDate.width(), itmHeight);
const $favA = $postBlock.find('a#jras-pcbShareFAV');
new MutationObserver(function(){
const favData = getFavData($postContainer);
$favA.removeClass();
$favA.addClass(favData.Img);
$favA.attr('title', favData.Title);
}).observe($postContainer.find('div.uhead_share span.favorite_link').get(0), {attributes: true});
postControlSlider($postContainer.find('sitm#jras-PostControlShare'), (pcbShareButtons == '') ? 40 : 132, itmHeight);
$favA.click(function(){ $postContainer.find('span.favorite_link').get(0).click(); return false; });
const $Rating = $postContainer.find('div.ufoot span.post_rating');
$Rating.find('div.vote-plus, div.vote-minus').removeClass('abyss');
const ratingStyle = function(){
const $pcRating = $postContainer.find('sitm#jras-PostControlRating');
$pcRating.children().remove();
$pcRating.append(`<span style="margin-left: ${itmContentPos}px;">`);
$pcRating.append($Rating.clone(true));
const $pcRatingPost = $pcRating.find('span.post_rating');
$pcRatingPost.css('display', '');
$pcRatingPost.css('right', 'unset');
const $pcRatingPostPlus = $pcRatingPost.find('div.vote-plus');
$pcRatingPostPlus.removeClass('vote-plus').addClass('jras-PostControlRatingVote').click(function(){
$Rating.find('div.vote-plus').get(0).click()});
const $pcRatingPostMinus =$pcRatingPost.find('div.vote-minus');
$pcRatingPostMinus.removeClass('vote-minus').addClass('jras-PostControlRatingVote').click(function(){
$Rating.find('div.vote-minus').get(0).click()});
if (page.isNewDesign){
$pcRatingPost.find('span:first').css({'font-size': '18px', 'top': '-9px', 'display': 'initial','position': 'relative'});
$pcRatingPostPlus.addClass('jras-PostControlRatingVote-new').css({'background-position-y': '1px'});
$pcRatingPostMinus.addClass('jras-PostControlRatingVote-new').css({'background-position': '-22px 1px', 'margin': '7px 0 0'});
}else{
$pcRatingPostPlus.addClass('jras-pcVotePlus-img').css({'top': '5px', 'position': 'relative'});
$pcRatingPostMinus.addClass('jras-pcVoteMinus-img').css({'top': '5px', 'position': 'relative'});
}
postControlSlider($pcRating, itmHeight + 130, itmHeight);
};
ratingStyle();
new MutationObserver(function(){ ratingStyle()})
.observe($Rating.get(0), {subtree: true, attributes: true, childList: true});
let $Links = $postContainer.find('div.ufoot span.manage');
const makeLinks = function(){
let itemW = 0;
const $pcLinks = $postContainer.find('sitm#jras-PostControlLinks');
$pcLinks.children().remove();
$pcLinks.append(`<span style="margin-left: ${itmContentPos}px;">`);
$pcLinks.append(`<s><div class="jras-pcToTop" ${(page.isNewDesign)?'style="margin-top: 2px;"':''}></div></s>`);
$pcLinks.find('div.jras-pcToTop').click(function(){
$('html, body').animate({ scrollTop: $postContainer.offset().top - 50}, 500);
});
$pcLinks.append(`<s><div class="jras-pcToDown" ${(page.isNewDesign)?'style="margin-top: 2px;"':''}></div></s>`);
$pcLinks.find('div.jras-pcToDown').click(function(){
$('html, body').animate({ scrollTop: $postContainer.offset().top + $postContainer.height() - win.innerHeight + 50}, 500);
});
if (page.isNewDesign){
$pcLinks.append($postContainer.find('div.ufoot span.link_wr').clone());
$pcLinks.append($postContainer.find('div.ufoot span.hidden_link').clone());
$Links.children().each(function(){
$pcLinks.append($(this).clone().css('display', $(this).css('display')));
});
$pcLinks.find('>span:gt(1):not(:last)').addClass('jras-pcLinksSepAfter');
$pcLinks.find('>span.hidden_link').addClass('jras-pcLinksSepBefore');
itemW = ($pcLinks.children().find(':visible').length > 3) ? 85: 95;
itemW += itmHeight + $Links.outerWidth();
}else{
$pcLinks.append($Links.children().clone());
$pcLinks.find('>span:not(:first):not(:last)').addClass('jras-pcLinksSepAfter');
$pcLinks.find('>span.hidden_link').addClass('jras-pcLinksSepBefore');
itemW = itmHeight + $Links.width() + $Links.children().find(':visible').length * 7;
}
itemW += 60;
$pcLinks.find('span.setTag a.link.setTagLink').click(function(){
const $tagEdit = $postContainer.find('div.ufoot span.post_add_tag');
const hidden = $tagEdit.css('display') == 'none';
$postContainer.find('div.ufoot span.setTag a.link.setTagLink').get(0).click();
if (hidden){
$('html, body').animate({ scrollTop: $tagEdit.offset().top - 150}, 500);
blinkElement($tagEdit, 5);
}
});
$pcLinks.find('span.setTag a.setHeaderLink').click(function(){
const $captionEdit = $postContainer.find('div.ufoot span.post_set_header');
const hidden = $captionEdit.css('display') == 'none';
$postContainer.find('div.ufoot a.setHeaderLink').get(0).click();
if (hidden){
$('html, body').animate({ scrollTop: $captionEdit.offset().top - 150}, 500);
blinkElement($captionEdit, 5);
}
});
postControlSlider($pcLinks, itemW, itmHeight);
};
makeLinks();
new MutationObserver(function(){ makeLinks()})
.observe($Links.get(0), {subtree: true, attributes: true, childList: true});
checkPostControlPos($th);
},10);
};
let selector = 'div[id^=postContainer].postContainer';
if (userOptions.val('pcbShowInFullPost')) {selector = 'div#pageinner div#contentinner > ' + selector}
$(selector).each(function(){
const $post = $(this);
makePostCtrl($post);
new MutationObserver(function(){ makePostCtrl($post) })
.observe($(this).get(0), {childList: true});
});
$(window).on('scroll', function(){
$('div[id^=postContainer].postContainer').each(function(){
checkPostControlPos($(this));
});
});
}
function postControlSlider($postContainerItem, itmWidth, itmHeight){
return $postContainerItem.css({'width': itmWidth + itmHeight + 'px', 'right': -itmWidth + 'px'})
.mouseenter(function(){$(this).css('right', '-4px')})
.mouseleave(function(){$(this).css('right', -itmWidth + 'px')});
}
function checkPostControlPos($PostContainer){
const pco = $PostContainer.offset();
const pch = $PostContainer.height();
const pcbp = pco.top + pch;
if (pco.top > win.pageYOffset + win.innerHeight){ return }
if (pcbp < win.pageYOffset){ return }
const $PostCrtlsBlock = $PostContainer.find('div#jras-PostControlBlock');
const pbh = $PostCrtlsBlock.height();
let newTop = win.pageYOffset - pco.top + +userOptions.val('pcbTopScreenPos');
const pcbTopStop = +userOptions.val('pcbTopBorder');
if (newTop + pbh + pcbTopStop > pch){
newTop = pch - pbh - +userOptions.val('pcbBottomBorder');
}
newTop = (newTop < pcbTopStop) ? pcbTopStop : newTop;
$PostCrtlsBlock.css({'top': newTop});
}
function actionTooltipButton($button, link, buttonTxtID){
$button.click({clickLink: link, updateContainer: $button}, function(eventObject){
const t = eventObject.data.updateContainer.find('#' + buttonTxtID);
const ct = t.text();
t.text(ct + ' : wait');
GM.xmlHttpRequest({
method: 'GET', url: eventObject.data.clickLink,
onload: function(response){
if(response.status != 200){
t.text(ct + ' : error: ' + response.status);
}else{
t.text(ct + ' : ok');
}
eventObject.data.updateContainer
.css('cursor', '')
.removeClass('jras-tooltip-button')
.unbind(eventObject);
}
});
});
}
function makeTooltips(selector, openCallBack){
$(selector).tooltip({
items: 'a',
content: function(){
return '<div id="jras-tooltipcontainer"' +
' style="height: 30px; line-height: 30px; margin: 8px; color: rgb(120, 120, 120); text-align: center;">' +
lng.getVal('JRAS_LOADINGUSERDATA') + '</div>';
},
show: {effect: "fade", duration: 400},
track: true,
open: function(event, ui){
openCallBack(event, ui)
},
close: function(event, ui){
ui.tooltip.hover(function(){
$(this).stop(true).fadeTo(400, 1);
}, function(){
$(this).fadeOut('400', function(){
$(this).remove();
});
});
}
});
}
function clearContainer(container){
container.find('*').remove();
container.empty();
container.css({
'line-height': '',
'text-align': '',
'height': ''
});
}
function setTooltipBounds($tooltip, {left, width}){
if (width !== undefined){
$tooltip.width(width + 'px');
}
if (left !== undefined){
$tooltip.offset({ left: left});
}
}
function makeTagTooltips(selector){
makeTooltips(selector, function(event, ui){
const $item = $(event.target);
const TagName = $.trim($item.text());
const TagLink = $item.attr('href');
const $tooltip = $(ui.tooltip);
$('div.ui-tooltip').not('#' + $tooltip.attr('id')).remove();
$tooltip.css({
'border-radius': '5px',
'z-index': '500',
'border': '1px solid rgb(102, 102, 102)',
'-webkit-box-shadow': '6px 6px 8px 0px rgba(0, 0, 0, 0.5)',
'-moz-box-shadow': '6px 6px 8px 0px rgba(0, 0, 0, 0.5)',
'box-shadow': '6px 6px 8px 0px rgba(0, 0, 0, 0.5)',
'word-break': 'break-all'
});
getTagData(TagName, TagLink, $tooltip, $tooltip.find('div#jras-tooltipcontainer'));
});
}
function getTagData(tagName, tagLink, $tooltip, $outContainer){
setTooltipBounds($tooltip, {width: defLoadTooltipSize});
GM.xmlHttpRequest({
method: 'GET',
url: tagLink,
onload: function(response){
if(response.status != 200){
$outContainer.text('Loading error: ' + response.status);
// win.console.log("Loading tag data error: - " + response.status);
}else{
const doc = document.implementation.createHTMLDocument("");
doc.documentElement.innerHTML = response.responseText;
clearContainer($outContainer);
let tmpW = win.innerWidth;
const w = defTagTooltipSize;//tmpW / 2 - 30;
if ($tooltip.position().left + w > tmpW){
tmpW = tmpW - w - 30;
} else {
tmpW = null;
}
setTooltipBounds($tooltip, {left: tmpW, width: w});
const $tagHeaderPathBlock = $('<div id="jras-tagHeaderPathBlock">')
.css({
'font-size': '10px',
'margin-top': '-6px',
'margin-bottom': '4px'
});
$outContainer.append($tagHeaderPathBlock);
const $tagDocHeaderSide = $(doc).find('div.sidebar_block div.sideheader.taginfo');
const $tagSideBar = $tagDocHeaderSide.closest('div#sidebar');
$tagDocHeaderSide.find('a').each(function(){
$(this).appendTo($tagHeaderPathBlock);
$tagHeaderPathBlock.append('<span> > </span>');
});
const $tagHeaderBlock = $('<div id="jras-tagHeaderBlock">').css({'line-height': '22px'});
$outContainer.append($tagHeaderBlock);
const $tagDocStats = $(doc).find('div.sidebar_block div.blog_stats');
$tagDocStats.closest('div.sidebarContent').find('img.blog_avatar').clone().appendTo($tagHeaderBlock);
$tagDocHeaderSide.find('span.fn').appendTo($tagHeaderBlock).addClass('jras-tooltip-caption');
makeTagModers($tagSideBar, $outContainer);
makeTagStatistics($tagDocStats, $outContainer);
const $mainBtnContainer = $('<div id="jras-tooltip-mainTagBtn" class="jras-tooltip-section-topborder"></div>').appendTo($outContainer);
if(page.isUserLogon){
const $tagDocHeader = $(doc).find('div#blogHeader');
let txtToTagAction;
let linkToTagAction;
if($tagDocHeader.find('div#blogFavroiteLinks > p').is('.add_to_fav')){
txtToTagAction = lng.getVal('JRAS_ADDTAGFAV');
linkToTagAction = $tagDocHeader.find('div#blogFavroiteLinks > p.add_to_fav > a.change_favorite_link').attr('href');
}else{
if($tagDocHeader.find('div#blogFavroiteLinks > p').is('.remove_from_fav')){
txtToTagAction = lng.getVal('JRAS_REMOVETAGFAV');
linkToTagAction = $tagDocHeader.find('div#blogFavroiteLinks > p.remove_from_fav > a.change_favorite_link').attr('href');
}
}
if(txtToTagAction){
const $favTagBtn = $mainBtnContainer.append(`
<div id="jras-tooltip-favtag" class="jras-tooltip-button" style="cursor: pointer;">
<i class="jras-tooltip-button-img jras-tooltip-favtag-img""></i>
<span id="jras-tooltip-favtag-txt" class="jras-tooltip-button-text">${txtToTagAction}</span>
</div>
`).find('#jras-tooltip-favtag');
actionTooltipButton($favTagBtn, linkToTagAction, 'jras-tooltip-favtag-txt');
}
if($tagDocHeader.find('div#blogFavroiteLinks > p').is('.add_to_unpopular')){
txtToTagAction = lng.getVal('JRAS_BLOCKTAG_JR');
linkToTagAction = $tagDocHeader.find('div#blogFavroiteLinks > p.add_to_unpopular > a.change_favorite_link').attr('href');
}else{
if($tagDocHeader.find('div#blogFavroiteLinks > p').is('.remove_from_unpopular')){
txtToTagAction = lng.getVal('JRAS_UNBLOCKTAG_JR');
linkToTagAction = $tagDocHeader.find('div#blogFavroiteLinks > p.remove_from_unpopular > a.change_favorite_link').attr('href');
}
}
if(txtToTagAction){
const $blockTagBtn = $mainBtnContainer.append(`
<div id="jras-tooltip-blocktag" class="jras-tooltip-button" style="cursor: pointer;">
<i class="jras-tooltip-button-img jras-tooltip-blockuser-img""></i>
<span id="jras-tooltip-blocktag-txt" class="jras-tooltip-button-text">${txtToTagAction}</span>
</div>
`).find('#jras-tooltip-blocktag');
actionTooltipButton($blockTagBtn, linkToTagAction, 'jras-tooltip-blocktag-txt');
}
}
makeJRASTagTooltipElm($mainBtnContainer, tagName);
}
}
});
}
function makeTagStatistics($tagDocStatsBlock, $container){
const $tagStatContainer = $('<div id="jras-tagStatContainer" class="jras-tooltip-section-topborder" style="line-height: 16px; font-size: 10px;"></div>')
.css({'margin-top': '6px'});
$container.append($tagStatContainer);
$tagDocStatsBlock.find('div').find('br').remove();
$tagDocStatsBlock.find('div').appendTo($tagStatContainer);
const a = $tagStatContainer.find('div:first > b')[0] ? '<br>' : '';
$tagStatContainer.find('div:first').prepend(`<b>${lng.getVal('JRAS_TOOLTIP_STATISTICS')}</b>` + a);
}
function makeTagModers($tagSideBar, $container){
if (!$tagSideBar || !$container) {
return
}
const $tagDocModCont = getSideBarSection($tagSideBar, 'Модераторы');
if (!$tagDocModCont[0]) {
return
}
const $modBlock = $container.append(`
<div style="line-height: 16px; font-size: 10px;" id="jras-tooltip-tagmoderators-block">
<div id="jras-tooltip-tagmoderators-header" style="margin-bottom: 3px; margin-top: 3px; cursor: pointer;">
<b>
${lng.getVal('JRAS_TOOLTIP_TAGMODERATORS')}
</b>
</div>
<div id="jras-tooltip-tagmoderators-tags" style="margin-bottom: 0; display: none;">
</div>
</div>
`).find('#jras-tooltip-tagmoderators-block');
const $modTags = $modBlock.find('#jras-tooltip-tagmoderators-tags');
$tagDocModCont.find('div').clone().appendTo($modTags);
$modTags.find('div').each(function(){
$(this).css({'margin-bottom': '3px'});
$('<span> </span>`').prependTo($(this));
$(this).find('img').css({'width': '22px', 'vertical-align': 'middle'}).prependTo($(this));
$(this).find('a').css({'vertical-align': 'middle'}).append(`<span>${$(this).attr('title')}</span>`);
});
$modBlock.find('#jras-tooltip-tagmoderators-header').click({updateContainer: $modTags}, function(eventObject){
eventObject.data.updateContainer.slideToggle('display');
});
return true;
}
function makeJRASTagTooltipElm($container, tagName){
const txtToTagAction = (userOptions.data.BlockTags.indexOf(tagName) == -1)
? lng.getVal('JRAS_BLOCKTAG_JRAS')
: lng.getVal('JRAS_UNBLOCKTAG_JRAS');
const $blockTagJRAS = $container.append(`
<div id="jras-tooltip-blocktag-jras" class="jras-tooltip-button" style="cursor: pointer;">
<i class="jras-tooltip-button-img jras-tooltip-blockuser-img" style="transform: scale(.7);"></i>
<span id="jras-tooltip-blocktag-jras-text" class="jras-tooltip-button-text">${txtToTagAction}</span>
</div>
`).find('#jras-tooltip-blocktag-jras');
$blockTagJRAS.click({dataTagName: tagName, updateContainer: $blockTagJRAS}, function(eventObject){
const t = eventObject.data.updateContainer.find('#jras-tooltip-blocktag-jras-text');
const iof = userOptions.data.BlockTags.indexOf(eventObject.data.dataTagName);
if(iof == -1){
t.text(lng.getVal('JRAS_UNBLOCKTAG_JRAS'));
userOptions.data.BlockTags.push(eventObject.data.dataTagName);
}else{
t.text(lng.getVal('JRAS_BLOCKTAG_JRAS'));
userOptions.data.BlockTags.splice(iof, 1);
}
userOptions.saveUserData(page.currentUser);
})
}
function makeUserTooltips(selector){
if(!userOptions.val('isToBeLoadingUserData')){ return }
makeTooltips(selector, function(event, ui){
const $item = $(event.target);
const UserName = $.trim($item.text());
const UserLink = $item.attr('href');
const $tooltip = $(ui.tooltip);
$('div.ui-tooltip').not('#' + $tooltip.attr('id')).remove();
$tooltip.css({
'border-radius': '5px',
'z-index': '500',
'border': '1px solid rgb(102, 102, 102)',
'-webkit-box-shadow': '6px 6px 8px 0px rgba(0, 0, 0, 0.5)',
'-moz-box-shadow': '6px 6px 8px 0px rgba(0, 0, 0, 0.5)',
'box-shadow': '6px 6px 8px 0px rgba(0, 0, 0, 0.5)',
'word-break': 'break-all'
});
getUserData(UserName, UserLink, $tooltip, $tooltip.find('div#jras-tooltipcontainer'));
});
}
function getUserData(userName, userLink, $tooltip, $outContainer){
let $mainBtnContainer;
const mainBtnContainer =
'<div id="jras-tooltip-mainBtnContainer" class="jras-tooltip-section-topborder"></div>';
if(userOptions.val('isToBeLoadingUserData')){
setTooltipBounds($tooltip, {width: defLoadTooltipSize});
GM.xmlHttpRequest({
method: 'GET',
url: userLink,
onload: function(response){
//win.console.log('Loading user data from "' + userLink + '" - ' + response.status);
if(response.status != 200){
$outContainer.text('Loading error: ' + response.status);
// win.console.log("Loading user data error: - " + response.status);
}else{
const doc = document.implementation.createHTMLDocument("");
doc.documentElement.innerHTML = response.responseText;
clearContainer($outContainer);
setTooltipBounds($tooltip, {width: defUserTooltipSize});
const $userSideBar = $(doc).find('div.user-awards').closest('div#sidebar');
const $userData = $(doc).find('div.user-awards').parent('div.sidebarContent');
$userData.find('div.user').clone().appendTo($outContainer).css({'line-height': '22px'})
.find('span').addClass('jras-tooltip-caption');
if (userOptions.val('chatlaneToPacaki')){
$outContainer.find('div.user > span').css('color', $outContainer.find('div.user').css('color'));
}
const colUserOnline = ($.trim($userData.find('span.userOnline').text()) == 'Оффлайн') ? 'rgb(255, 0, 0)' : 'rgb(0, 255, 0)';
$outContainer.find('div.user').prepend(
`<div style="background-color: ${colUserOnline}; height: 83%; margin-right: 4px; display: inline-block; width: 5px; border-radius: 10px;"></div>`
);
makeUserAwardsBlock($userData.find('div.user-awards'), $outContainer);
const $userStars = $userData.find('div.stars').clone().appendTo($outContainer);
$userStars.css('width', '100%');
$userStars.find('div:not([class])').not('[style*="border: black solid 1px"]').remove();
$userStars.find('div[class*="star-row-"]')
.css({
'height': '15px',
'margin-left': '15px',
'transform': 'scale(0.7)'
});
let a = page.isNewDesign ? 'rgb(230, 230, 230)' : 'rgb(72, 72, 72)';
$userStars.find('[style*="border: black solid 1px"]')
.css({
'border': '',
'margin-top': '3px',
'background-color': a,
'height': '4px'
});
a = makeModerElements($userSideBar, $outContainer) ? 'jras-tooltip-section-topborder' : '';
$userData.find('div#rating-text').clone().appendTo($outContainer)
.css('font-size', '10px')
.css('line-height', '16px')
.addClass(a);
makePostsElements($userSideBar, $outContainer);
const $mainBtnContainer = $outContainer.append(mainBtnContainer).find('#jras-tooltip-mainBtnContainer');
if(page.isUserLogon){ // если залоген
makeSendPMElements($mainBtnContainer, userName);
let txtToUserAction;
let linkToUserAction;
if($userData.find('div#friend_link > p').is('.add_tofr_lnk.user_icons')){
txtToUserAction = lng.getVal('JRAS_ADDFRIEND');
linkToUserAction = $userData.find('div#friend_link > p.add_tofr_lnk.user_icons > a[href]').attr('href');
}else{
if($userData.find('div#friend_link > p').is('.remove_fromfr_lnk.user_icons')){
txtToUserAction = lng.getVal('JRAS_REMOVEFRIEND');
linkToUserAction = $userData.find('div#friend_link > p.remove_fromfr_lnk.user_icons > a[href]').attr('href');
}
}
if(txtToUserAction){
const $friendUser = $mainBtnContainer.append(
'<div id="jras-tooltip-frienduser" class="jras-tooltip-button" style="cursor: pointer;">' +
'<i class="jras-tooltip-button-img jras-tooltip-frienduser-img"></i>' +
'<span id="jras-tooltip-frienduser-txt" class="jras-tooltip-button-text">' + txtToUserAction + '</span>' +
'</div>'
).find('#jras-tooltip-frienduser');
actionTooltipButton($friendUser, linkToUserAction, 'jras-tooltip-frienduser-txt');
}
txtToUserAction = null;
if($userData.find('div#friend_link > p').is('.add_toblock_lnk.user_icons')){
txtToUserAction = lng.getVal('JRAS_BLOCKUSER_JR');
linkToUserAction = $userData.find('div#friend_link > p.add_toblock_lnk.user_icons > a[href]').attr('href');
}else{
if($userData.find('div#friend_link > p').is('.remove_fromblock_lnk.user_icons')){
txtToUserAction = lng.getVal('JRAS_UNBLOCKUSER_JR');
linkToUserAction = $userData.find('div#friend_link > p.remove_fromblock_lnk.user_icons > a[href]').attr('href');
}
}
if(txtToUserAction){
const $blockUserJR = $mainBtnContainer.append(
'<div id="jras-tooltip-blockuser-jr" class="jras-tooltip-button" style="cursor: pointer;">' +
'<i class="jras-tooltip-button-img jras-tooltip-blockuser-img"></i>' +
'<span id="jras-tooltip-blockuser-jr-txt" class="jras-tooltip-button-text">' + txtToUserAction + '</span>' +
'</div>'
).find('#jras-tooltip-blockuser-jr');
actionTooltipButton($blockUserJR, linkToUserAction, 'jras-tooltip-blockuser-jr-txt');
}
}
makeJRASUserTooltipElm($mainBtnContainer, userName);
}
}
});
}else{
clearContainer($outContainer);
$mainBtnContainer = $outContainer.append(mainBtnContainer).find('#jras-tooltip-mainBtnContainer');
$mainBtnContainer.css({
'margin-top': '',
'border-top': '',
'padding-top': ''
});
makeJRASUserTooltipElm($mainBtnContainer, userName);
}
}
function getSideBarSection($sideBarUser, sectCaption){
return $sideBarUser.find('.sidebar_block>.sideheader:contains(' + sectCaption + ') + div.sidebarContent');
}
function makeModerElements($sideBarUser, $containerFor){
if (!$sideBarUser || !$containerFor) {
return false
}
const $userModCont = getSideBarSection($sideBarUser, 'Модерирует');
if (!$userModCont[0]) {
return false
}
const $modBlock = $containerFor.append(`
<div style="line-height: 16px; font-size: 10px;" id="jras-tooltip-moderator-block">
<div id="jras-tooltip-moderator-header" style="cursor: pointer;">
<b>
${lng.getVal('JRAS_TOOLTIP_MODERATOR')}
</b>
</div>
<div id="jras-tooltip-moderator-tags" style="margin-bottom: 0; display: none;">
</div>
</div>
`).find('#jras-tooltip-moderator-block');
const $modTags = $modBlock.find('#jras-tooltip-moderator-tags');
$modTags.append($userModCont.removeClass('sidebarContent').clone());
$modBlock.find('#jras-tooltip-moderator-header').click({updateContainer: $modTags}, function(eventObject){
eventObject.data.updateContainer.slideToggle('display');
});
return true;
}
function makePostsElements($sideBarUser, $containerFor){
if (!$sideBarUser || !$containerFor) {
return
}
const $userPostsCont = getSideBarSection($sideBarUser, 'Профиль');
if (!$userPostsCont[0]) {
return
}
const re = /(\d+)/gm;
let m, arr = [];
while ((m = re.exec($userPostsCont.find('>:first-child').text())) !== null) {
if (m.index === re.lastIndex) {
re.lastIndex++;
}
arr.push(m[0]);
}
const $modBlock = $containerFor.append(`
<div class="jras-tooltip-section-topborder" style="line-height: 16px; font-size: 10px;" id="jras-tooltip-posts-block">
${lng.getVal('JRAS_TOOLTIP_POSTS')}<b>${arr[0] + ' (' + arr[1] + ' / ' + arr[2] + ')'}</b><br>
${lng.getVal('JRAS_TOOLTIP_COMMENTS')}<b> ${arr[3]}</b><br>
${lng.getVal('JRAS_TOOLTIP_REG')}<b><span id="jras-tooltip-posts-regdate"></b></span>
</div>
`).find('#jras-tooltip-posts-block');
$modBlock.find('#jras-tooltip-posts-regdate').append($userPostsCont.find('span[id^=usertime]').clone());
}
function makeSendPMElements(containerFoElements, userName){
if(!page.isUserLogon || userName == 'anon' || userName == page.currentUser){
return
}
const $sendPM = containerFoElements.append(`
<div id="jras-tooltip-sendPM" class="jras-tooltip-button" style="cursor: pointer;">
<i class="jras-tooltip-button-img jras-tooltip-sendmess-img"></i>
<span class="jras-tooltip-button-text">${lng.getVal('JRAS_SENDPRIVMESS')}</span>
</div>
`).find('#jras-tooltip-sendPM');
$sendPM.click({user: userName}, function(eventObject){
sendPM(eventObject.data.user)
})
}
function makeJRASUserTooltipElm(containerFoElements, userName){
const txtToUserAction = (userOptions.data.BlockUsers.indexOf(userName) == -1)
? lng.getVal('JRAS_BLOCKUSER_JRAS')
: lng.getVal('JRAS_UNBLOCKUSER_JRAS');
const $blockUserJRAS = containerFoElements.append(
'<div id="jras-tooltip-blockuser-jras" class="jras-tooltip-button" style="cursor: pointer;">' +
'<i class="jras-tooltip-button-img jras-tooltip-blockuser-img" style="transform: scale(.7);"></i>' +
'<span id="jras-tooltip-blockuser-jras-text" class="jras-tooltip-button-text">' + txtToUserAction + '</span>' +
'</div>'
).find('#jras-tooltip-blockuser-jras');
$blockUserJRAS.click({dataUserName: userName, updateContainer: $blockUserJRAS}, function(eventObject){
const t = eventObject.data.updateContainer.find('#jras-tooltip-blockuser-jras-text');
const iof = userOptions.data.BlockUsers.indexOf(eventObject.data.dataUserName);
if(iof == -1){
t.text(lng.getVal('JRAS_UNBLOCKUSER_JRAS'));
userOptions.data.BlockUsers.push(eventObject.data.dataUserName);
}else{
t.text(lng.getVal('JRAS_BLOCKUSER_JRAS'));
userOptions.data.BlockUsers.splice(iof, 1);
}
userOptions.saveUserData(page.currentUser);
})
}
function makeUserAwardsBlock($userAwards, $containerFor){
let hideUserAwardsWhen = userOptions.val('hideUserAwardsWhen');
let minShowUserAwards = userOptions.val('minShowUserAwards');
if (hideUserAwardsWhen != 0 && hideUserAwardsWhen < minShowUserAwards){
hideUserAwardsWhen = +minShowUserAwards + 1;
}
if(hideUserAwardsWhen != 0 && $userAwards.children().length > hideUserAwardsWhen){
const $jrasTooltipUserAwards = $containerFor.append('<div id="jras-tooltip-user-awards" class="jras-user-awards-slice" style="-webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none;"></div>')
.find('#jras-tooltip-user-awards');
$jrasTooltipUserAwards.append($userAwards.children().slice(0, minShowUserAwards));
$jrasTooltipUserAwards.append('<div id="jras-tooltip-user-awards-hide" class="jras-user-awards-slice" style="display: none;"></div>')
.find('#jras-tooltip-user-awards-hide')
.append($userAwards.children().clone());
const $jrasTooltipUserAwardsHideBtn = $jrasTooltipUserAwards.append('<div id="jras-tooltip-user-awards-hide-btn"></div>')
.find('#jras-tooltip-user-awards-hide-btn')
.addClass('jras-tooltip-user-awards-hide-btn')
.addClass('jras-tooltip-user-awards-hide-btn-close');
const correctShadow = function(visible){
if(!page.isNewDesign && !page.isSchemeLight()){
return
}
$jrasTooltipUserAwardsHideBtn.css('background-color', '#C3C3C3');
$jrasTooltipUserAwardsHideBtn.hover(function(){
$(this).css('background-color', '#F0E400')
}, function(){
$(this).css('background-color', '#C3C3C3')
});
if(visible){
$jrasTooltipUserAwardsHideBtn.css('box-shadow', '0px -4px 8px 0px rgb(138, 138, 138)');
}else{
$jrasTooltipUserAwardsHideBtn.css('box-shadow', '');
}
};
correctShadow(true);
$jrasTooltipUserAwardsHideBtn.click(function(){
const $toggleContainer = $('#jras-tooltip-user-awards-hide');
if($toggleContainer.css('display') == 'none'){
$toggleContainer.slideToggle('display', function(){
$jrasTooltipUserAwardsHideBtn.toggleClass('jras-tooltip-user-awards-hide-btn-close');
correctShadow(false);
});
}else{
$jrasTooltipUserAwardsHideBtn.toggleClass('jras-tooltip-user-awards-hide-btn-close');
correctShadow(true);
$toggleContainer.slideToggle('display');
}
});
}else{
$userAwards.clone().appendTo($containerFor).addClass('jras-user-awards');
}
$containerFor.find('img').css('border', 'none')
}
function sendPM(userName){
let $pmDialog = $('body #jras-send-pm-dialog');
if(!$pmDialog[0]){
$pmDialog = $('body').append(`
<div id="jras-send-pm-dialog" title="" style="width: 100%;height: 100%;">
<form action="/private/create" method="POST" id="private_form" style="width: 100%;height: 100%;">
<div id="private_form_flash" style="display:none;"></div>
<input id="jras-send-pm-username" name="username" type="hidden" id="private_form_username" value="">
<textarea style="width: 100%;height: 70%;" id="private_form_text" name="text" rows="12" cols="76"></textarea>
<div class="ui-dialog-buttonpane ui-widget-content ui-helper-clearfix" style="margin:0; padding:0;border: none;">
<div class="ui-dialog-buttonset">
<input type="submit" value="" id="jras-send-pm-sendbutton">
</div>
<div id="private_form_uploading" style="display: none;">
<img src="http://css.joyreactor.cc/images/jquery-ui/ui-anim_basic_16x16.gif" alt="uploading...">
<span id="jras-send-pm-sendmess"></span>
</div>
</div>
</form>
</div>
`).find('#jras-send-pm-dialog');
}
$pmDialog.attr('title', lng.getVal('JRAS_SENDPMDIALOG_HEADERCAPTION') + userName);
$pmDialog.find('input#jras-send-pm-username').attr('value', userName);
$pmDialog.find('input#jras-send-pm-sendbutton').attr('value', lng.getVal('JRAS_SENDPMDIALOG_SENDBUTTON'));
const $pmSendMess = $pmDialog.find('span#jras-send-pm-sendmess');
$pmSendMess.text(lng.getVal('JRAS_SENDPMDIALOG_SENDMESS'));
if(!page.isSchemeLight()){
$pmSendMess.css('color', 'rgb(172, 174, 173)');
}
$pmDialog.dialog({
resizable: false,
minWidth: 300,
minHeight: 200,
width: 550,
height: 300,
title: lng.getVal('JRAS_SENDPMDIALOG_HEADERCAPTION') + userName,
closeText: lng.getVal('JRAS_SENDPMDIALOG_CLOSEBUTTON'),
show: {
effect: "drop",
duration: 400
},
hide: {
effect: "scale",
duration: 300
},
open: function(){
let magicNumber = 40; //высота нижней панели
if(page.isNewDesign){
magicNumber = 55;
}
$('textarea#private_form_text').css({
width: $(this).width(),
height: $(this).height() - magicNumber
});
}
});
}
function closeSettingDialog(){
$('#jras-prop-gui-dialog').find('label.modal__close').click();
}
function themeDependentCSS(){
if (!page.isSchemeLight()){
newCssClass(`
.post_content table td {
border: 1px solid #474747;
}
`);
}
}
function newCssClass(cssClass){
const head = document.head || document.getElementsByTagName('head')[0];
const style = document.createElement('style');
style.type = 'text/css';
if(style.styleSheet){
style.styleSheet.cssText = cssClass;
}else{
style.appendChild(document.createTextNode(cssClass));
}
head.appendChild(style);
}
function addNewCSSClasses(){
newCssClass(`
.video_gif_source{
top: 0;
right: 0;
}
.video_gif_holder {
display: inline-block;
}
.video_gif_holder:hover .video_gif_source{
display: block;
}
/* для старого дизайна */
.treeCross-old{
float: left;
width: 13px;
margin-top: -8px;
margin-left: -34px;
font-weight: bold;
border-radius: 14px;
display: block;
position: absolute;
height: 20px;
padding: 0 1px 0 6px;
cursor: pointer;
}
.avatarCorrect{
background: url("../images/comments.png") no-repeat;
padding-left: 9px;
left: -10px;
}
.avatarForOldDesign{
float: left;
border-radius: 3px;
margin-left: -15px;
margin-right: 6px;
height: 35px;
}
.treeCross-old-toparent {
border-radius: 6px;
height: 10px;
width: 4px;
margin-left: -37px;
margin-top: 6px;
}
table img {
width: 100%;
height: 100%;
}
table video {
width: 100%;
height: 100%;
}
/* для нового дизайна */
.treeCross-new{
float: left;
width: 10px;
border-radius: 14px;
display: block;
position: absolute;
color: rgb(255, 255, 255);
border: 2px solid rgb(255, 255, 255);
margin-top: -8px;
margin-left: -16px;
background: #DFDFDF none repeat scroll 0 0;
font-weight: bold;
font-size: 18px;
height: 28px;
padding: 0 16px 0 8px;
cursor: pointer;
}
.treeCross-new-toparent {
margin-top: 10px;
border-radius: 8px;
height: 15px;
padding: 0 12px 0 0;
margin-left: -18px;
}
.treeCross-new:hover, .treeCross-new-toparent:hover {
background-color: rgb(254, 204, 101);
}
.jras-tooltip-caption {
font-size: large;
position: absolute;
overflow: hidden;
max-width: 75%;
word-wrap: break-word;
padding-left: 8px;
max-height: 20%;
}
.jras-comment-expand-all {
cursor: pointer;
width: 18px;
height: 10px;
display: inline-block;
opacity: 0.6;
margin-left: -1px;
}
.jras-comment-expand-all:hover {
border-left: 3px solid rgb(255, 0, 0);
margin-left: -3px;
border-radius: 4px;
}
.jras-comment-sizer {
display: inline-block;
cursor: pointer;
bottom: 0;
overflow: hidden;
height: 10px;
width: 97%;
background-image: linear-gradient(to right, rgba(244, 244, 240, 0.15), rgb(192, 192, 192), rgba(244, 244, 244, 0.15));
}
.jras-user-awards img {
width: 16px;
height: 16px;
}
.jras-user-awards-slice img {
height: 16px;
padding-left: 3px;
}
.jras-tooltip-button:hover span, .jras-tooltip-button:hover i {
color: #CC9622;
opacity: 1;
}
.jras-tooltip-button-img {
vertical-align: middle;
width: 16px;
height: 16px;
display: inline-block;
opacity: 0.7;
}
.jras-tooltip-button-text {
padding-left: 4px;
font-size: 10px;
vertical-align: middle;
display: inline-block;
line-height: 10px;
}
.jras-tooltip-favtag-img {
background: transparent url("") no-repeat scroll 0 0;
}
.jras-tooltip-blockuser-img {
background: transparent url("") no-repeat scroll 0 0;
}
.jras-tooltip-sendmess-img {
background: transparent url("") no-repeat scroll 0 0;
}
.jras-tooltip-frienduser-img {
background: transparent url("") no-repeat scroll 0 0;
}
.jras-comment-expand-all-img {
background: transparent url("") no-repeat scroll 0 -3px;
}
.jras-tooltip-section-topborder {
margin-top: 4px;
border-top: 1px solid rgb(85, 85, 85);
padding-top: 3px;
}
.jras-PostControlBlock-new sitm{
right: -75px;
background-color: #fecc65;
}
.jras-PostControlBlock-old sitm{
right: -85px;
background-color: #fab728;
}
.jras-PostControlBlock-old-dark sitm{
right: -85px;
background-color: #7B7B7B;
}
.jras-pcInfo-img {
background: transparent url("") no-repeat scroll 8px 4px;
}
.jras-pcShare-img {
background: transparent url("") no-repeat scroll 4px 4px;
}
.jras-pcRating-img {
background: transparent url("") no-repeat scroll 4px 4px;
}
.jras-pcLinks-img {
background: transparent url("") no-repeat scroll 4px 4px;
}
.jras-pcShareFAV-img {
background: transparent url("") no-repeat scroll 0px 0px;
}
.jras-pcShareFAV-exists-img {
background: transparent url("") no-repeat scroll 0px 0px;
}
.jras-pcShareTEL-img {
background: transparent url("") no-repeat scroll 0px 0px;
}
.jras-pcShareVK-img {
background: transparent url("") no-repeat scroll 0px 0px;
}
.jras-pcShareMAIL-img {
background: transparent url("") no-repeat scroll 0px 0px;
}
.jras-pcShareTWIT-img {
background: transparent url("") no-repeat scroll 0px 0px;
}
.jras-pcShareFACE-img {
background: transparent url("") no-repeat scroll 0px 0px;
}
.jras-pcVotePlus-img {
background: transparent url("") no-repeat scroll 0px 0px;
}
.jras-pcVoteMinus-img {
background: transparent url("") no-repeat scroll 0px 0px;
}
.jras-pcToTop{
width: 24px;
height: 18px;
display: inline-block;
background: transparent url("") no-repeat scroll 3px -3px;
}
.jras-pcToDown{
width: 33px;
height: 18px;
display: inline-block;
background: transparent url("") no-repeat scroll 3px -3px;
}
.jras-pcLinksSepAfter:after{
color: #535353;
content: " | ";
}
.jras-pcLinksSepBefore:before{
color: #535353;
content: " | ";
}
.jras-PostControlRatingVote {
width: 20px;
height: 21px;
cursor: pointer;
display: inline-block;
}
.jras-PostControlRatingVote-new {
line-height: 33px;
margin: 7px 0 0 14px;
background-image: url(../images/icon_smiles.png);
width: 22px;
height: 22px;
background-size: 42px;
vertical-align: top;
}
#jras-PostControlShare a{
height: 16px;
width: 16px;
display: inline-block;
}
#jras-PostControlShare a{
display: inline-block;
background-size: 16px 16px;
-o-transition: all 0.5s ease-in-out;
-moz-transition: all 0.5s ease-in-out;
-webkit-transition: all 0.5s ease-in-out;
transition: all 0.2s ease-in-out;
}
#jras-PostControlShare a:hover{
-o-transform: scale(2, 2);
-ms-transform: scale(2, 2);
-moz-transform: scale(2, 2);
-webkit-transform: scale(2, 2);
transform: scale(2, 2);
box-shadow: 0 0 4px 1px rgba(128, 128, 128, 0.53);
}
#jras-PostControlBlock{
position: absolute;
right: 0;
z-index: 1;
border-left: 1px solid rgba(0, 0, 0, 0.3);
}
#jras-PostControlBlock sitm {
position: absolute;
transition: 0.5s cubic-bezier(0.56, 1.35, 0.37, 0.97);
padding: 4px;
width: 100px;
border-radius: 4px 0px 0px 4px;
box-shadow: 1px 1px 4px 0px rgba(0,0,0, .5);
opacity: 0.6;
font-size: 12px;
display: inline-flex;
}
#jras-PostControlBlock sitm:hover {
opacity: 1;
}
.jras-gui-btn-newdesign {
border-radius: 3px;
padding-left: 3px;
padding-right: 3px;
width: 24px;
height: 22px;
}
.jras-gui-btn-pmme {
background-image: url("");
background-repeat: no-repeat;
background-position: center center;
border: medium none;
}
.jras-gui-btn-deleteall {
background-image: url("");
background-repeat: no-repeat;
background-position: center center;
border: medium none;
}
.jras-gui-btn-resetdef {
background-image: url("");
background-repeat: no-repeat;
background-position: center center;
border: medium none;
}
.jras-tooltip-user-awards-hide-btn-close{
position: relative;
box-shadow: 0 -4px 8px 0 rgb(0, 0, 0);
margin-bottom: -6px;
}
.jras-tooltip-user-awards-hide-btn{
background-color: rgb(80, 80, 80);
height: 5px;
width: 105%;
margin-left: -5px;
top: -4px;
border-radius: 0 0 10px 10px;
}
.jras-tooltip-user-awards-hide-btn:hover{
background-color: rgb(0, 135, 21);
}
.jras-prop-gui-content, .jras-prop-gui-contentTop, .jras-prop-gui-contentBottom{
background-color: #2F2E2E;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 30px;
overflow: hidden;
}
.jras-prop-gui-contentTop{
margin-bottom: 5px;
}
.jras-prop-gui-contentBottom{
top: auto;
bottom: 0;
height: 30px;
overflow: hidden;
margin-top: 5px;
}
.jras-prop-gui-contentMain{
position: absolute;
top: 30px;
left: 0;
right: 0;
bottom: 30px;
overflow: auto;
background-color: #262626;
}
.jras-prop-gui-section{
margin-top: 5px;
margin-bottom: 14px;
}
.jras-prop-gui-button-right{
padding-left: 20px;
right: 0px;
padding-right: 20px;
margin-right: 5px;
position: absolute;
margin-top: 4px;
height: 22px;
}
.jras-prop-gui-button-left{
left: 0px;
margin-left: 5px;
margin-top: 4px;
cursor: pointer;
}
.jras-tabs-panel-content {padding: 6px 10px;}
#jras-prop-gui-dialog{
border: 0;
width: 100%;
}
#jras-prop-gui-dialog .jras-tabs-nav{
margin-left: 6px;
margin-top: 6px;
float: left;
width: 25%;
border: 0;
background: none;
}
#jras-prop-gui-dialog .jras-tabs-nav li{
height: 30px;
clear: left;
width: 100%;
margin: 0 0 5px 0;
background: #2d2d2d none repeat scroll 0 0;
border: 0 none;
padding: 0 0 3px 5px;
font-weight: normal;
border-radius: 3px;
}
#jras-prop-gui-dialog .jras-tabs-nav li.ui-tabs-active{
background-color: #3e7a35;
}
#jras-prop-gui-dialog .jras-tabs-nav li.ui-state-focus{
background-color: #2b5326;
}
#jras-prop-gui-dialog .ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited{
line-height: 30px;
color: #818181;
text-decoration: none;
}
#jras-prop-gui-dialog .ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited{
color: #d4d4d4;
font-weight: bold;
text-decoration: none;
line-height: 30px;
}
#jras-prop-gui-dialog .jras-tabs-panel{
box-shadow: -1px 0 20px 0 #000000;
border: 0;
left: 25%;
height: 100%;
overflow: auto;
position: absolute;
float: right;
right: 0;
}
/* Окно настроек */
.modal {
z-index: 1000;
opacity: 0;
visibility: hidden;
position: fixed;
top: 0;
right: 0;
bottom: 0;
left: 0;
text-align: left;
background: rgba(0,0,0, .9);
transition: opacity .25s ease;
}
.modal__bg {
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
cursor: pointer;
}
.modal-state {
display: none;
}
.modal-state:checked + .modal {
opacity: 1;
visibility: visible;
}
.modal-state:checked + .modal .modal__inner {
top: 0;
}
.modal__inner {
transition: top .25s ease;
position: absolute;
top: -20%;
width: 55%;
margin-left: 42%;
margin-top: 20px;
overflow: auto;
background: #fff;
border-radius: 5px;
height: 55%;
}
.modal__close {
position: absolute;
right: 8px;
top: 8px;
width: 1.1em;
height: 1.1em;
cursor: pointer;
}
.modal__close:after,
.modal__close:before {
content: "";
position: absolute;
width: 2px;
height: 1.5em;
background: #ccc;
display: block;
transform: rotate(45deg);
left: 50%;
margin: -3px 0 0 -1px;
top: 0;
}
.modal__close:hover:after,
.modal__close:hover:before {
background: #aaa;
}
.modal__close:before {
transform: rotate(-45deg);
}
@media screen and (max-width: 768px) {
.modal__inner {
width: 93%;
height: 93%;
margin-left: 3%;
box-sizing: border-box;
}
}
@media screen and (max-height: 600px) {
.modal__inner {
height: 75%;
box-sizing: border-box;
}
}
@media screen and (max-height: 400px) {
.modal__inner {
height: 91%;
box-sizing: border-box;
}
}
`);
}
function correctStyle(){
if (!userOptions.val('stCorrectStyle')){
return;
}
const stretchContent = (userOptions.val('stStretchContent'))
? `div#header{width: ${userOptions.val('stStretchSize')}%;} div#page{width: ${userOptions.val('stStretchSize')}%;}`
: '';
let sideBarHover = '';
let divContainer = '';
let sideBar = '';
let divContent = '';
if (userOptions.val('stHideSideBar')){
divContent = 'div#content{width: 100%;}';
if (page.isNewDesign){
sideBar = 'right: -310px; width: 320px; border-left: 2px solid lightgray; border-bottom: 2px solid lightgray; background-color: white;';
sideBarHover = 'right: 0;';
divContainer = 'width: 100%;';
}else{
sideBar = 'right: -285px; width: 259px; padding-right: 26px; margin-top: 1px; padding-top: 10px; background-color: ';
sideBar += (page.isSchemeLight()) ? 'white;' : '#3B3B3B;';
sideBarHover = 'right: -15px;';
divContainer = 'width: 98%;';
}
sideBar = `div#sidebar{${sideBar} transition: 0.2s; position: absolute;padding-left: 10px; z-index: 10;}`;
}
const form_addPost = (!page.isNewDesign && !page.isSchemeLight())
? 'form#add_post{ background-size: 100% !important;}'
: '';
const centerContent = (userOptions.val('stCenterContent'))
? '.image { text-align: center !important; }'
: '';
const style = `
${stretchContent}
${divContent}
div#tagArticle{width: 100%;}
${sideBar}
div#sidebar:hover, div#sidebar.hovered { ${sideBarHover} box-shadow: -6px 0px 20px -5px rgba(0, 0, 0, 0.47);}
div#contentinner { ${divContainer} }
div#showCreatePost { width: 100%; }
div#add_post_holder { width: 100%; }
div[id^=postContainer]{ box-shadow: 10px 0px 20px -10px rgba(0, 0, 0, 0.4); }
div#navcontainer { background-size: 100%; }
div#searchBar { background-size: 100%; }
div.blogs a img { width: 100%; }
div#searchBar{ display: flex; }
form#searchform{ float: right; }
div#submenu{ width: 75%; }
div#blogName{ max-width: 85%; }
div.tagname{ max-width: 60%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
div#searchmenu{ width: 25%; }
textarea#add_post_text { width: 99%; border: 1px ${(page.isSchemeLight()) ? 'solid #bbbbbb; background: none;' : 'border-color: #444 !important;'} }
input[name="tag"], input[name="header"] { width: 99% !important; margin-top: -6px !important; }
.article .ufoot { width: 100% !important; }
${centerContent}
${form_addPost}
.post_content table { margin: 0 auto; }
.post_content_expand{ width: 100% !important; }
`;
newCssClass(style);
if (!userOptions.val('stHideSideBar')){
newCssClass(`div#content{width: ${$('div#page').width() - $('div#sidebar').width()}px;}`);
}
}
function dynamicStyle(){
if (!(userOptions.val('stCorrectStyle') || (!userOptions.val('stCorrectStyle') && userOptions.val('stUseDynStyleChanges')))){
return;
}
if (userOptions.val('stSideBarSizeToPage')){
if (!userOptions.val('stCorrectStyle')){
newCssClass(`div#sidebar.hovered { ${(page.isNewDesign)?'right: 0;':'right: -15px;'} box-shadow: -6px 0px 20px -5px rgba(0, 0, 0, 0.47);}`);
}
correctPageHeight();
$('div.post_content_expand').each(function(){
new MutationObserver(function(){ correctPageHeight() }).observe(this, {attributes: true});
});
}
}
function correctPageHeight(){
if (!(userOptions.val('stCorrectStyle') || (!userOptions.val('stCorrectStyle') && userOptions.val('stUseDynStyleChanges')))){
return;
}
if (userOptions.val('stSideBarSizeToPage')){
const $divSideBar = $('div#sidebar');
const sbh = $divSideBar.height();
const $divPageInner = $('div#pageinner');
$divPageInner.css('height', 'auto');
if ($divPageInner.height() < sbh){
$divPageInner.height(sbh);
const $contentBlock = $('div#content');
if (userOptions.val('stShowSideBarOnHideContent')){
$(window).on('scroll', function(){
if ($contentBlock.offset().top + $contentBlock.height() < win.pageYOffset){
$divSideBar.addClass('hovered');
}else{
$divSideBar.removeClass('hovered');
}
})
}
}
}
}
function makeBlockPostElements(forElm, parentID, blockMess, blockMessBold, blockMessDesc, fromTag){
// буээээ
if($('#togglebutton' + parentID)[0]){
return
}
let newElement;
if (!userOptions.val('delUserPost') || fromTag){
newElement = document.createElement("input");
newElement.style.marginRight = '30px';
newElement.style.paddingLeft = '20px';
newElement.style.paddingRight = '20px';
newElement.id = 'togglebutton' + parentID;
newElement.type = 'button';
newElement.value = lng.getVal('JRAS_TOGGLEBUTTONCAPTIONSHOW');
newElement.onclick = function(){
const toggleContainer = $('#' + parentID + ' > div');
const buttonCaption = toggleContainer.css('display') != 'none'
? lng.getVal('JRAS_TOGGLEBUTTONCAPTIONHIDE')
: lng.getVal('JRAS_TOGGLEBUTTONCAPTIONSHOW');
toggleContainer.slideToggle('display', function(){
correctPageHeight();
});
$('#togglebutton' + parentID).attr("value", buttonCaption);
};
forElm.parentElement.insertBefore(newElement, forElm);
}
const newDIV = document.createElement("div");
newDIV.style.display = 'inline';
forElm.parentElement.insertBefore(newDIV, forElm);
newElement = document.createElement("span");
newElement.textContent = blockMess;
newDIV.appendChild(newElement);
newElement = document.createElement("span");
newElement.style.fontWeight = 'bold';
if (userOptions.val('showUserNameDelPost') || fromTag){
newElement.textContent = blockMessBold;
}else{
newElement.textContent = '---';
}
newDIV.appendChild(newElement);
newElement = document.createElement("span");
newElement.textContent = blockMessDesc;
newDIV.appendChild(newElement);
}
function makeBlockCommElements(forElm, parentID, blockMess, blockMessBold, blockMessDesc){
// древние копролиты
if($('#newToggle_' + parentID)[0]){
return
}
const newDIV = document.createElement("div");
newDIV.id = 'newToggle_' + parentID;
newDIV.style.display = 'inline';
forElm.parentElement.insertBefore(newDIV, forElm);
let newElement = document.createElement("span");
newElement.textContent = blockMess;
newElement.style.color = 'rgb(242, 119, 119)';
// newElement.className = 'comment_show';
if(page.isNewDesign){
newElement.style.paddingLeft = '20px';
}
if (!userOptions.val('delUserComment')){
newElement.style.cursor = 'pointer';
newElement.onclick = function(){
$('#' + parentID + ' > div.txt').slideToggle('display', function(){
correctPageHeight();
});
};
}
newDIV.appendChild(newElement);
newElement = document.createElement("span");
newElement.style.fontWeight = 'bold';
if (userOptions.val('showUserNameDelComment')){
newElement.textContent = blockMessBold;
}else{
newElement.textContent = '---';
if (userOptions.val('makeAvatarOnOldDesign') && !page.isNewDesign){
$(forElm).parent().find('>img.avatarForOldDesign').css('display', 'none');
}
}
newDIV.appendChild(newElement);
newElement = document.createElement("span");
newElement.textContent = blockMessDesc;
newDIV.appendChild(newElement);
}
function getPropID(prop){
return 'jras-gui-' + prop;
}
function makePropElements(){
const getHTMLProp = function(prop, styleFor, style){
let retVal = '';
if (prop === undefined){return}
const propObj = userOptions.data[prop];
if (propObj === undefined){return}
const propID = getPropID(prop);
switch(propObj.type) {
case 'checkbox':
retVal = `<input id="${propID}Val" type="${propObj.type}" style="vertical-align: middle;"/>
<label id="${propID}Caption" for="${prop}" style="cursor: pointer;vertical-align: middle;"/>`;
break;
case 'combobox':
retVal = `<span id="${propID}Caption" style="vertical-align: middle;"/>
<select id="${propID}Val" name="jras-${prop}" style="vertical-align: middle;">`;
const values = propObj.values();
for (let a in values){ retVal += '<option value="' + a + '">' + values[a] + '</option>'}
retVal += '</select>';
break;
case 'number':
retVal = `<span id="${propID}Caption" style="vertical-align: middle;margin-left: 3px;line-height: 28px;"/>
<input id="${propID}Val" type="${propObj.type}" min="${propObj.min}" max="${propObj.max}" style="width: 50px; vertical-align: middle;"/>`;
break;
}
if (styleFor !== undefined){ $(retVal).find('#' + propID + styleFor).css(style) }
return retVal;
};
if(page.isNewDesign){
$('div.topbar_right:first div.lang_select').after(
'<label id="jras_prop-button" style="cursor: pointer;" class="lang_select" for="modal-1">JRAS</label>'
);
$('label#jras_prop-button').click(openProp);
}else{
$('div#header:first div.lang_select').after(`
<label id="navcontainer" class="lang_select" for="modal-1"
style="cursor: pointer; right: 39px; padding: 1px 2px 2px;
font-size: 9px; border-radius: 0 0 5px 5px; height: 17px;
background: transparent url('../images/mainmenu_active_bg1.png') repeat-x scroll 0 0;">
JRAS
</label>
`);
$('div#header:first div.lang_select + label').click(openProp);
}
$('body').append(`
<div id="jras-prop-gui-dialog">
<input class="modal-state" id="modal-1" type="checkbox" />
<div class="modal">
<label class="modal__bg" for="modal-1"></label>
<div class="modal__inner">
<div class="jras-prop-gui-contentTop">
<span style="color: #8B857B;font-weight: bold; line-height: 27px; padding-left: 8px;">
JRAS - JoyReactor Advanced Script v.${JRAS_CurrVersion}
</span>
<label class="modal__close" for="modal-1"></label>
</div>
<div class="jras-prop-gui-contentMain">
<div id="jras-prop-gui-tabs" style="border: 0 none;">
<ul class="jras-tabs-nav">
<li id="jras-tabs-nav-0"><a href="#jras-prop-gui-tab-1"></a></li>
<li id="jras-tabs-nav-1"><a href="#jras-prop-gui-tab-2"></a></li>
<li id="jras-tabs-nav-2"><a href="#jras-prop-gui-tab-3"></a></li>
<li id="jras-tabs-nav-3"><a href="#jras-prop-gui-tab-4"></a></li>
<li id="jras-tabs-nav-4"><a href="#jras-prop-gui-tab-5"></a></li>
</ul>
<div id="jras-prop-gui-tab-1" class="jras-tabs-panel">
<div class="jras-tabs-panel-content">
<section class="jras-prop-gui-section"> ${getHTMLProp('currentLng', 'Val', {'width': '30%'})} </section>
<section class="jras-prop-gui-section"> ${getHTMLProp('removeShareButtons')} </section>
<section class="jras-prop-gui-section"> ${getHTMLProp('fixedTopbar')} </section>
<section class="jras-prop-gui-section" style="margin-left: 20px; margin-top: -10px;"> ${getHTMLProp('hideFixedTopbar')} </section>
<section class="jras-prop-gui-section"> ${getHTMLProp('correctRedirectLink')} </section>
<section class="jras-prop-gui-section"> ${getHTMLProp('showHiddenComments')} </section>
<section class="jras-prop-gui-section" style="margin-left: 20px; margin-top: -10px;"> ${getHTMLProp('showHiddenCommentsMark')} </section>
<section class="jras-prop-gui-section""> ${getHTMLProp('pcbShowPostControl')} </section>
<section class="jras-prop-gui-section" style="margin-left: 20px; margin-top: -10px;">
${getHTMLProp('pcbShowInFullPost')} <br>
${getHTMLProp('pcbHideShareButoons')} <br>
${getHTMLProp('pcbHideJRShareBlock')} <br>
${getHTMLProp('pcbHideJRRatingBlock')}<br>
${getHTMLProp('pcbAnimateMove')} <br>
${getHTMLProp('pcbAnimateMoveSpeed')}<br>
${getHTMLProp('pcbTopScreenPos')} <br>
${getHTMLProp('pcbTopBorder')} <br>
${getHTMLProp('pcbBottomBorder')} </section>
</div>
</div>
<div id="jras-prop-gui-tab-2" class="jras-tabs-panel">
<div class="jras-tabs-panel-content">
<section class="jras-prop-gui-section"> ${getHTMLProp('delUserComment')} </section>
<section class="jras-prop-gui-section" style="margin-top: -10px;"> ${getHTMLProp('showUserNameDelComment')} </section>
<section class="jras-prop-gui-section" style="margin-top: -10px;"> ${getHTMLProp('fullDelUserPost')} </section>
<section class="jras-prop-gui-section" style="margin-top: -10px;"> ${getHTMLProp('delUserPost')} </section>
<section class="jras-prop-gui-section" style="margin-top: -10px;"> ${getHTMLProp('showUserNameDelPost')} </section>
<span id="jras-guiBlockUserListCaption"></span>
<textarea id="jras-guiBlockUserList" style="width: 98%; border: 1px solid rgb(216, 216, 216); height: 139px;">
</textarea>
<span id="jras-guiBlockTagListCaption"></span>
<textarea id="jras-guiBlockTagList" style="width: 98%; border: 1px solid rgb(216, 216, 216); height: 139px;">
</textarea>
</div>
</div>
<div id="jras-prop-gui-tab-3" class="jras-tabs-panel">
<div class="jras-tabs-panel-content">
<section class="jras-prop-gui-section"> ${getHTMLProp('isToBeLoadingUserData')} </section>
<section class="jras-prop-gui-section" style="margin-left: 20px; margin-top: -10px;">
${getHTMLProp('showUTOnLine')} <br>
${getHTMLProp('showUTOnComment')}<br>
${getHTMLProp('showUTOnPrivateMess')} <br>
${getHTMLProp('showUTOnPeople')} <br>
${getHTMLProp('showUTOnSidebarTopUsers')} <br>
${getHTMLProp('showUTOnSidebarOnline')} <br>
${getHTMLProp('showUTOnPostControl')} <br>
${getHTMLProp('hideUserAwardsWhen', 'Val', {'width': '60px'})}
${getHTMLProp('minShowUserAwards', 'Val', {'width': '60px'})} <br>
${getHTMLProp('chatlaneToPacaki')} <br>
${getHTMLProp('showUTOnTopComments')} </section>
<section class="jras-prop-gui-section" style="margin-top: -10px;"> ${getHTMLProp('isToBeLoadingTagData')} </section>
<section class="jras-prop-gui-section" style="margin-left: 20px; margin-top: -10px;">
${getHTMLProp('showTTOnLine')} <br>
${getHTMLProp('showTTFullPost')} <br>
${getHTMLProp('showTTOnTrends')} <br>
${getHTMLProp('showTTOnLikeTags')} <br>
${getHTMLProp('showTTOnInteresting')} </section>
</div>
</div>
<div id="jras-prop-gui-tab-4" class="jras-tabs-panel">
<div class="jras-tabs-panel-content">
<section class="jras-prop-gui-section"> ${getHTMLProp('makeTreeComments')} </section>
<section class="jras-prop-gui-section" style="margin-left: 20px; margin-top: -10px;">
${getHTMLProp('treeCommentsOnlyFullPost')} </section>
<section class="jras-prop-gui-section"> ${getHTMLProp('makeAvatarOnOldDesign')} </section>
<section class="jras-prop-gui-section" style="margin-left: 20px; margin-top: -10px;">
${getHTMLProp('makeAvatarOnlyFullPost')} <br>
${getHTMLProp('showCommentDate')} <br>
${getHTMLProp('avatarHeight')}</section>
<section class="jras-prop-gui-section"> ${getHTMLProp('whenCollapseMakeRead')} </section>
<section class="jras-prop-gui-section"> ${getHTMLProp('collapseComments')} </section>
<section class="jras-prop-gui-section" style="margin-left: 20px; margin-top: -10px;">
${getHTMLProp('collapseCommentsOnlyFullPost')} <br>
${getHTMLProp('collapseCommentWhenSize')} <br>
${getHTMLProp('collapseCommentToSize')} </section>
</div>
</div>
<div id="jras-prop-gui-tab-5" class="jras-tabs-panel">
<div class="jras-tabs-panel-content">
<section class="jras-prop-gui-section"> ${getHTMLProp('stCorrectStyle')} </section>
<section class="jras-prop-gui-section" style="margin-left: 20px; margin-top: -10px;">
${getHTMLProp('stHideSideBar')} <br>
${getHTMLProp('stStretchContent')} <br>
${getHTMLProp('stCenterContent')} <br>
${getHTMLProp('stStretchSize')}
</section>
<section class="jras-prop-gui-section"> ${getHTMLProp('stUseDynStyleChanges')} </section>
<section class="jras-prop-gui-section"> ${getHTMLProp('stSideBarSizeToPage')}
<section class="jras-prop-gui-section" style="margin-left: 20px;">${getHTMLProp('stShowSideBarOnHideContent')} </section>
</section>
<div style="opacity: .7; line-height: 12px; font-size: 80%; padding: 15px; border-top: 1px dashed; width: 90%;">
* JRAS style так же можно найти в виде стилей для Stylish и подобных. Мне кажется что использовать их отдельно от скрипта удобнее, хотя и настроить сложно.<br>
Они доступны по ссылкам<br>
- Для нового дизайна - <a href="https://userstyles.org/styles/148705/jras-style-for-new-reactor-cc" target="_blank" rel="nofollow">ссылка</a><br>
- Для старого дизайна - <a href="https://userstyles.org/styles/148704/jras-style-for-old-reactor-cc" target="_blank" rel="nofollow">ссылка</a><br>
- Для старого со стилем Steam - <a href="https://userstyles.org/styles/148702/jras-style-for-old-black-reactor-cc-steam" target="_blank" rel="nofollow">ссылка</a> (Сам стиль Steam доступен <a href="https://userstyles.org/styles/102457/joyreactor-old-steam" target="_blank" rel="nofollow">здесь</a>)
</div>
</div>
</div>
</div>
</div>
<div id="jras-prop-gui-bottomCcontent" class="jras-prop-gui-contentBottom">
<input id="jras-gui-SaveSettings" style="padding-left: 20px; padding-right: 20px; height: 22px;" class="jras-prop-gui-button-right" value="" type="button">
</div>
</div>
</div>
</div>
`);
$(`body label[id*=${getPropID('')}]`).click(function(){
$(this).parent().find('input#' + getPropID($(this).attr('for')) + 'Val').get(0).click();
});
const $propDialog = $('#jras-prop-gui-dialog');
$propDialog.find('[id*=jras-tabs-nav-]').click(function(){
$propDialog.find('#jras-prop-gui-tabs').tabs({active: $(this).attr('id').replace('jras-tabs-nav-', '')});
});
if(page.isSchemeLight()){$propDialog.find('[id*=jras-prop-gui-tab]').css('color', '#686868');
}else{$propDialog.find('[id*=jras-prop-gui-tab]').css('color', '#BBBBBB');}
if(!page.isNewDesign){$propDialog.find('ul.jras-tabs-nav li a').css('padding-top', '11px');}
makeServiceGUIButton();
updateGuiLocalize();
}
function openProp(){
const $propDialog = $('#jras-prop-gui-dialog');
userOptions.each(function(optName, opt){
switch(opt.type) {
case 'checkbox':
$propDialog.find('#' + getPropID(optName) + 'Val').prop('checked', userOptions.val(optName));
break;
case 'combobox':
case 'number':
$propDialog.find('#' + getPropID(optName) + 'Val').val(userOptions.val(optName));
break;
}
});
$propDialog.find('#jras-guiBlockUserList').val(userOptions.data.BlockUsers.join("\n"));
$propDialog.find('#jras-guiBlockTagList').val(userOptions.data.BlockTags.join("\n"));
$propDialog.find('#jras-prop-gui-tabs').tabs({active: 0});
$propDialog.find('#jras-prop-gui-tabs').tabs({selected: 0});
$propDialog.find('#jras-prop-gui-tabs').tabs({focused: 0});
}
function updateGuiLocalize(){
const $propDialog = $('#jras-prop-gui-dialog');
$propDialog.find('#jras-gui-SaveSettings').attr('value', lng.getVal('JRAS_GUI_BTNSAVE'));
$propDialog.find('#jras-gui-sendPMforMe').attr('title', lng.getVal('JRAS_GUI_BTNSENDPMME'));
$propDialog.find('#jras-gui-DeleteAllSavedSettings').attr('title', lng.getVal('JRAS_GUI_BTNDELETESETT'));
$propDialog.find('#jras-gui-ResetSettings').attr('title', lng.getVal('JRAS_GUI_BTNRESETSETT'));
$propDialog.find('#jras-tabs-nav-0 a').text(lng.getVal('JRAS_GUI_TABMAIN'));
$propDialog.find('#jras-tabs-nav-1 a').text(lng.getVal('JRAS_GUI_TABBLOCK'));
$propDialog.find('#jras-tabs-nav-2 a').text(lng.getVal('JRAS_GUI_TABTOOLTIP'));
$propDialog.find('#jras-tabs-nav-3 a').text(lng.getVal('JRAS_GUI_TABCOMMENTS'));
$propDialog.find('#jras-tabs-nav-4 a').text(lng.getVal('JRAS_GUI_TABSTYLE'));
$propDialog.find('#jras-guiBlockUserListCaption').text(lng.getVal('JRAS_GUI_BLOCKUSERLIST'));
$propDialog.find('#jras-guiBlockTagListCaption').text(lng.getVal('JRAS_GUI_BLOCKTAGLIST'));
userOptions.each(function(optName){
$propDialog.find('#' + getPropID(optName) + 'Caption').text(userOptions.getGuiDesc(optName));
});
}
function makeServiceGUIButton(){
const $propDialog = $('#jras-prop-gui-dialog');
if(page.isNewDesign){
$propDialog.find('#jras-gui-SaveSettings').css('border-radius', '3px');
$propDialog.find('#jras-prop-gui-bottomCcontent').prepend(`
<div id="jras-gui-sendPMforMe" class="big_button jras-gui-btn-newdesign jras-prop-gui-button-left jras-gui-btn-pmme" title=""> </div>
<div id="jras-gui-DeleteAllSavedSettings" class="big_button jras-gui-btn-newdesign jras-prop-gui-button-left jras-gui-btn-deleteall" title="" > </div>
<div id="jras-gui-ResetSettings" class="big_button jras-gui-btn-newdesign jras-prop-gui-button-left jras-gui-btn-resetdef" title="" > </div>
`);
}else{
$propDialog.find('#jras-prop-gui-bottomCcontent').prepend(`
<input id="jras-gui-sendPMforMe" style="padding-left: 3px;padding-right: 3px;width: 24px;height: 22px;" class="jras-prop-gui-button-left jras-gui-btn-pmme" title="" value="" type="button">
<input id="jras-gui-DeleteAllSavedSettings" style="padding-left: 3px; padding-right: 3px; width: 24px; height: 22px;" class="jras-prop-gui-button-left jras-gui-btn-deleteall" title="" value="" type="button">
<input id="jras-gui-ResetSettings" style="padding-left: 3px; padding-right: 3px; width: 24px; height: 22px;" class="jras-prop-gui-button-left jras-gui-btn-resetdef" title="" value="" type="button">
`);
}
$propDialog.find('#jras-gui-sendPMforMe').click(function(){
closeSettingDialog();
sendPM('AntiUser')
});
$propDialog.find('#jras-gui-DeleteAllSavedSettings').click(function(){
closeSettingDialog();
userOptions.removeAllSavedData();
});
$propDialog.find('#jras-gui-ResetSettings').click(function(){
closeSettingDialog();
userOptions.setDef();
});
$propDialog.find('#jras-gui-SaveSettings').click(function(){
const $propDialog = $('#jras-prop-gui-dialog');
userOptions.each(function(optName, opt){
switch(opt.type) {
case 'checkbox':
userOptions.val(optName, $propDialog.find('#' + getPropID(optName) + 'Val').prop('checked'));
break;
case 'combobox':
case 'number':
userOptions.val(optName, $propDialog.find('#' + getPropID(optName) + 'Val').val());
break;
}
});
userOptions.data.BlockUsers = $propDialog.find('#jras-guiBlockUserList').val().split('\n');
userOptions.data.BlockTags = $propDialog.find('#jras-guiBlockTagList').val().split('\n');
updateGuiLocalize();
userOptions.saveUserData(page.currentUser);
closeSettingDialog()
});
}
function PageData(){
const getColorSchema = function(){ // light or dark
let c = $('#background').css('background-color');
if (!c){c = $('body').css('background-color')}
const rgb = (/^#[0-9A-F]{6}$/i.test(c)) ? c : c.match(/^rgba?\((\d+),\s*(\d+),\s*(\d+)/);
const mono = (rgb !== null)
? parseInt((0.2125 * rgb[1]) + (0.7154 * rgb[2]) + (0.0721 * rgb[3]), 10)
: 0;
return (mono <= 128) ? 'dark' : 'light';
};
// Opera 8.0+
this.isOpera = (!!window.opr && !!opr.addons) || !!window.opera || navigator.userAgent.indexOf(' OPR/') >= 0;
// Firefox 1.0+
this.isFirefox = typeof InstallTrigger !== 'undefined';
// At least Safari 3+: "[object HTMLElementConstructor]"
this.isSafari = Object.prototype.toString.call(window.HTMLElement).indexOf('Constructor') > 0;
// Internet Explorer 6-11
this.isIE = /*@cc_on!@*/false || !!document.documentMode;
// Edge 20+
this.isEdge = !this.isIE && !!window.StyleMedia;
// Chrome 1+
this.isChrome = !!window.chrome && !!window.chrome.webstore;
// Blink engine detection
this.isBlink = (this.isChrome || this.isOpera) && !!window.CSS;
let regEx;
let matches;
this.currentPage = win.location.href;
this.isUserLogon = $('li.login.lastitem a').is('#logout');
this.currentUser = this.isUserLogon ? $('li.login a#settings').attr('href') : 'Anonymous';
if (this.currentUser != 'Anonymous'){
regEx = /(^.user.)(.+)/g;
matches = regEx.exec(this.currentUser);
this.currentUser = matches[2];
if (this.currentUser === undefined || this.currentUser == ''){
this.currentUser = 'Anonymous';
}
}
this.scheme = getColorSchema();
this.isSchemeLight = function(){
return this.scheme == 'light'
};
this.isNewDesignFunc = function(){
regEx = /^((https?:)(\/\/\/?)([\w]*(?::[\w]*)?@)?([\d\w\.-]+)(?::(\d+))?)?([\/\\\w\.()-]*)?(?:([?][^#]*)?(#.*)?)*/gmi;
matches = regEx.exec(this.currentPage);
if (matches[5] == undefined){
return false
}
return (matches[5] != 'old.reactor.cc') && (matches[5] != 'old.jr-proxy.com');
};
this.isNewDesign = this.isNewDesignFunc();
this.pageIs = function(page){
let retVal = false;
const regEx = /^((https?:)(\/\/\/?)([\w]*(?::[\w]*)?@)?([\d\w\.-]+)(?::(\d+))?)?([\/\\\w\.()-]*)?(?:([?][^#]*)?(#.*)?)*/gmi;
const matches = regEx.exec(this.currentPage);
if (matches[7] !== undefined){
if (matches[7].match(new RegExp('.*(' + page + ').*'))){
retVal = true;
}
}
return retVal;
}
}
function LanguageData(){
this.getVal = function(val){
if (this[val] === undefined){return val}
const cl = userOptions.val('currentLng');
if(!this[val][cl]){
return this[val]['ru'];
}
return this[val][cl];
};
this.getLangs = function(){
let retVal = {};
for(let a in this.JRAS_LANGLIST){
retVal[a] = this.JRAS_LANGLIST[a];
}
return retVal;
};
this.JRAS_LANGLIST = {
ru: 'Русский',
en: 'English'
};
this.JRAS_POSTBLOCKBYUSER = {
ru: 'Пост заблокированного пользователя: '
};
this.JRAS_TOGGLEBUTTONCAPTIONHIDE = {
ru: 'Скрыть'
};
this.JRAS_TOGGLEBUTTONCAPTIONSHOW = {
ru: 'Показать'
};
this.JRAS_POSTBLOCKBYTAG = {
ru: 'Пост заблокированый по тегам: '
};
this.JRAS_COMMBLOCKBYUSER = {
ru: 'Комментарий заблокированного пользователя: '
};
this.JRAS_GUI_SELECTLANGUAGE = {
ru: 'Язык интерфейса: '
};
this.JRAS_GUI_MAKEAVATARONOLDDESIGN = {
ru: ' Создавать аватары для старого дизайна'
};
this.JRAS_GUI_MAKEAVATARONLYFULLPOST = {
ru: ' Создавать аватары только для полного поста'
};
this.JRAS_GUI_AVATARHEIGHT = {
ru: ' Размер аватара (px)'
};
this.JRAS_GUI_MAKETREECOMMENTS = {
ru: ' Создавать дерево комментариев'
};
this.JRAS_GUI_CORRECTREDIRECTLINK = {
ru: ' Раскрывать ссылки из редиректа'
};
this.JRAS_GUI_REMOVESHAREBUTTONS = {
ru: ' Удалить кнопки "Поделиться..." (vk, fb, twitter и т.п.)'
};
this.JRAS_GUI_TREECOMMENTSONLYFULLPOST = {
ru: ' Дерево комментариев только для полного поста'
};
this.JRAS_GUI_WHENCOLLAPSEMAKEREAD = {
ru: ' При сворачивании ветки комментариев все дочерние помечаются прочитанными'
};
this.JRAS_GUI_FIXEDTOPBAR = {
ru: ' Зафиксировать верхнюю панель наверху окна'
};
this.JRAS_GUI_HIDEFIXEDTOPBAR = {
ru: ' Скрывать зафиксированную верхнюю панель'
};
this.JRAS_GUI_ISTOBELOADINGUSERDATA = {
ru: ' Загружать данные пользователя для Tooltip\u0027а'
};
this.JRAS_GUI_HIDEUSERAWARDSWHEN = {
ru: ' Если медалек больше чем: '
};
this.JRAS_GUI_MINSHOWUSERAWARDS = {
ru: ' то показывать первые: '
};
this.JRAS_GUI_SHOWUTONLINE = {
ru: ' Показывать в ленте'
};
this.JRAS_GUI_SHOWUTONCOMMENT = {
ru: ' Показывать в комментариях'
};
this.JRAS_GUI_SHOWUTONPRIVATEMESS = {
ru: ' Показывать на странице ПМ'
};
this.JRAS_GUI_SHOWUTONPEOPLE = {
ru: ' Показывать на странице Люди'
};
this.JRAS_GUI_SHOWUTONSIDEBARTOPUSERS = {
ru: ' Показывать в правом баре для юзеров топа'
};
this.JRAS_GUI_SHOWUTONSIDEBARONLINE = {
ru: ' Показывать в правом баре для аватарок'
};
this.JRAS_GUI_SHOWUTONPOSTCONTROL = {
ru: ' Показывать на авторе в блоке управления постом'
};
this.JRAS_GUI_SHOWHIDDENCOMMENTS = {
ru: 'Загружать скрытые заминусованные коменты сразу'
};
this.JRAS_GUI_SHOWHIDDENCOMMENTSMARK = {
ru: 'Отмечать загруженные коменты'
};
this.JRAS_GUI_SHOWUTONTOPCOMMENTS = {
ru: ' Показывать в правом баре для лучших коментов'
};
this.JRAS_GUI_ISTOBELOADINGTAGDATA = {
ru: 'Загружать данные тега для Tooltip\u0027а'
};
this.JRAS_GUI_SHOWTTONLINE = {
ru: 'Показывать в ленте'
};
this.JRAS_GUI_SHOWTTFULLPOST = {
ru: 'Показывать в полном посте'
};
this.JRAS_GUI_SHOWTTONTRENDS = {
ru: ' Показывать в правом баре для трендов'
};
this.JRAS_GUI_SHOWTTONLIKETAGS = {
ru: ' Показывать в правом баре для любимых тегов'
};
this.JRAS_GUI_SHOWTTONINTERESTING = {
ru: ' Показывать в правом баре для интересного'
};
this.JRAS_GUI_CHATLANETOPACAKI = {
ru: ' Убирать цветовую отметку донатера'
};
this.JRAS_GUI_DELUSERCOMMENT = {
ru: 'Скрывать комментарий без возможности просмотра'
};
this.JRAS_GUI_SHOWUSERNAMEDELCOMMENT = {
ru: 'Показывать в заблокированном комментарии ник юзера'
};
this.JRAS_GUI_FULLDELUSERPOST = {
ru: 'Удалять пост из ленты полностью'
};
this.JRAS_GUI_DELUSERPOST = {
ru: 'Скрывать пост без возможности просмотра'
};
this.JRAS_GUI_SHOWUSERNAMEDELPOST = {
ru: 'Показывать в заблокированном посте ник юзера'
};
this.JRAS_GUI_BLOCKUSERLIST = {
ru: 'Заблокированные пользователи'
};
this.JRAS_GUI_BLOCKTAGLIST = {
ru: 'Заблокированные теги'
};
this.JRAS_GUI_COLLAPSECOMMENTS = {
ru: 'Уменьшать большие комментарии'
};
this.JRAS_GUI_COLLAPSECOMMENTSONLYFULLPOST = {
ru: 'Уменьшать большие комментарии только в полном посте'
};
this.JRAS_GUI_COLLAPSECOMMENTWHENSIZE = {
ru: 'Уменьшать если размер больше (px)'
};
this.JRAS_GUI_COLLAPSECOMMENTTOSIZE = {
ru: 'Уменьшать до (px)'
};
this.JRAS_GUI_BTNSAVE = {
ru: 'Сохранить'
};
this.JRAS_GUI_BTNSENDPMME = {
ru: 'Отправить мне персональное сообщение'
};
this.JRAS_GUI_BTNDELETESETT = {
ru: 'Удалить все сохраненные данные'
};
this.JRAS_GUI_BTNRESETSETT = {
ru: 'Настройки по умолчанию'
};
this.JRAS_GUI_TABMAIN = {
ru: 'Общие'
};
this.JRAS_GUI_TABBLOCK = {
ru: 'Блокировки'
};
this.JRAS_GUI_TABTOOLTIP = {
ru: 'Tooltip\u0027ы'
};
this.JRAS_GUI_TABCOMMENTS = {
ru: 'Комментарии'
};
this.JRAS_GUI_TABSTYLE = {
ru: 'Стиль'
};
this.JRAS_LOADINGUSERDATA = {
ru: 'Загрузка данных...'
};
this.JRAS_SENDPRIVMESS = {
ru: 'Отправить сообщение'
};
this.JRAS_ADDFRIEND = {
ru: 'Добавить в друзья'
};
this.JRAS_REMOVEFRIEND = {
ru: 'Удалить из друзей'
};
this.JRAS_ADDTAGFAV = {
ru: 'Подписаться на тег'
};
this.JRAS_REMOVETAGFAV = {
ru: 'Отписаться от тега'
};
this.JRAS_TOOLTIP_MODERATOR = {
ru: 'Модератор...'
};
this.JRAS_TOOLTIP_TAGMODERATORS = {
ru: 'Модераторы...'
};
this.JRAS_TOOLTIP_STATISTICS = {
ru: 'Статистика: '
};
this.JRAS_TOOLTIP_POSTS = {
ru: 'Постов (х/л): '
};
this.JRAS_TOOLTIP_COMMENTS = {
ru: 'Комментариев:'
};
this.JRAS_TOOLTIP_REG = {
ru: 'Регистрация:'
};
this.JRAS_BLOCKUSER_JR = {
ru: 'Блокировать юзера (JR)'
};
this.JRAS_UNBLOCKUSER_JR = {
ru: 'Разблокировать юзера (JR)'
};
this.JRAS_BLOCKUSER_JRAS = {
ru: 'Блокировать юзера (JRAS)'
};
this.JRAS_UNBLOCKUSER_JRAS = {
ru: 'Разблокировать юзера (JRAS)'
};
this.JRAS_BLOCKTAG_JR = {
ru: 'Блокировать тег (JR)'
};
this.JRAS_UNBLOCKTAG_JR = {
ru: 'Разблокировать тег (JR)'
};
this.JRAS_BLOCKTAG_JRAS = {
ru: 'Блокировать тег (JRAS)'
};
this.JRAS_UNBLOCKTAG_JRAS = {
ru: 'Разблокировать тег (JRAS)'
};
this.JRAS_COMMENTS_EXPANDCOLL_ALL = {
ru: 'Свернуть/развернуть всё'
};
this.JRAS_SENDPMDIALOG_SENDBUTTON = {
ru: 'Отправить'
};
this.JRAS_SENDPMDIALOG_CLOSEBUTTON = {
ru: 'Закрыть'
};
this.JRAS_SENDPMDIALOG_HEADERCAPTION = {
ru: 'Отправка сообщения для '
};
this.JRAS_SENDPMDIALOG_SENDMESS = {
ru: 'Отправка данных...'
};
this.JRAS_GUI_PCBSHOWPOSTCONTROL = {
ru: 'Блок управления постом'
};
this.JRAS_GUI_PCBSHOWINFULLPOST = {
ru: 'Только в полном посте'
};
this.JRAS_GUI_PCBHIDEJRSHAREBLOCK = {
ru: 'Скрывать блок шарных кнопок поста'
};
this.JRAS_GUI_PCBHIDEJRRATINGBLOCK = {
ru: 'Скрывать блок рейтинга поста'
};
this.JRAS_GUI_PCBTOPBORDER = {
ru: 'Верхний стопор для блока внутри поста (px)'
};
this.JRAS_GUI_PCBBOTTOMBORDER = {
ru: 'Нижний стопор для блока внутри поста (px)'
};
this.JRAS_GUI_PCBTOPSCREENPOS = {
ru: 'Верхняя позиция на экране (px)'
};
this.JRAS_ADDFAVORITE = {
ru: 'Добавить в избранное'
};
this.JRAS_REMOVEFAVORITE = {
ru: 'Удалить из избранного'
};
this.JRAS_GUI_SHOWCOMMENTDATE = {
ru: 'Показывать в коменте его дату'
};
this.JRAS_GUI_PCBANIMATEMOVE = {
ru: 'Анимировать перемещения блока'
};
this.JRAS_GUI_PCBANIMATEMOVESPEED = {
ru: 'Скорость перемещения при анимации (1-9)'
};
this.JRAS_GUI_PCBHIDESHAREBUTOONS = {
ru: 'Скрыть кнопки шары оставить только избранное'
};
this.JRAS_GUI_STCORRECTSTYLE = {
ru: 'Корректировать дизайн и стиль сайта'
};
this.JRAS_GUI_STHIDESIDEBAR = {
ru: 'Скрывать правое меню'
};
this.JRAS_GUI_STSTRETCHCONTENT = {
ru: 'Растягивать контент по границам экрана'
};
this.JRAS_GUI_STSTRETCHSIZE = {
ru: 'Растягивать контент на (%)'
};
this.JRAS_GUI_STSIDEBARSIZETOPAGE = {
ru: 'Устанавливать высоту страницы по высоте правого меню'
};
this.JRAS_GUI_STSHOWSIDEBARONHIDECONTENT = {
ru: 'Показывать правое меню когда контент вышел за границы'
};
this.JRAS_GUI_STUSEDYNSTYLECHANGES = {
ru: 'Мне нужны только динамические эффекты нового стиля (я использую JRAS style)'
};
this.JRAS_GUI_STCENTERCONTENT = {
ru: 'Центровать контент'
};
}
}(typeof unsafeWindow != undefined ? unsafeWindow : window));