您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Comfort moderation
// ==UserScript== // @name Belgorod Kurator's Forums || Script // @namespace https://wh10919.web1.maze-host.ru/index.php // @version 1.8.2 // @description Comfort moderation // @author Sergey_Medvedev // @match https://wh10919.web1.maze-host.ru/index.php* // @include https://wh10919.web1.maze-host.ru/index.php // @grant none // @license MIT // @copyright 2024, // ==/UserScript== (function () { 'use strict'; const UNACCСEPT_PREFIX = 4; // Prefix that will be set when thread closes const ACCСEPT_PREFIX = 8; // Prefix that will be set when thread accepted const RESHENO_PREFIX = 6; // Prefix that will be set when solving the problem const PINN_PREFIX = 2; // Prefix that will be set when thread pins const GA_PREFIX = 12; // Prefix that will be set when thread send to ga const COMMAND_PREFIX = 10; // Prefix that will be set when thread send to project team const WATCHED_PREFIX = 9; const CLOSE_PREFIX = 7; const SPECY_PREFIX = 11; const TEXY_PREFIX = 13; const OTKAZBIO_PREFIX = 4; const ODOBRENOBIO_PREFIX = 8; const NARASSMOTRENIIBIO_PREFIX = 2; const OTKAZRP_PREFIX = 4; const ODOBRENORP_PREFIX = 8; const NARASSMOTRENIIRP_PREFIX = 2; const OTKAZORG_PREFIX = 4; const ODOBRENOORG_PREFIX = 8; const NARASSMOTRENIIORG_PREFIX = 2; const buttons = [ { title: 'Приветствие', content: '[FONT=Courier New][CENTER]{{ greeting }}, уважаемый {{ user.mention }}![/CENTER]<br>' + '[CENTER] [/CENTER][/FONT]', }, { title: 'На рассмотрение', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + '[Color=Orange][CENTER]При рассмотрении вашей темы, были выявлены следующие ошибки:[/CENTER][/color]' + '[CENTER] [/CENTER]', prefix: NARASSMOTRENIIRP_PREFIX, status: true, }, { title: '╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴РП биографии╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴', }, { title: 'Био одобрено', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП биография получает статус: [Color=Lime]Одобрено.[/I][/CENTER][/color][/FONT]", prefix: ODOBRENOBIO_PREFIX, status: false, }, { title: 'Уже есть био на доработке', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]У вас уже имеется RolePlay биография на рассмотрении, работайте там.[/CENTER]<br>" + '[Color=Red][CENTER] Отказано, закрыто.[/I][CENTER][/color][/FONT]', prefix: OTKAZBIO_PREFIX, status:false, }, { title: 'Био украдена', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП биография скопирована/украдена.[/CENTER]<br>" + '[Color=Red][CENTER]Отказано, закрыто.[/I][CENTER][/color][/FONT]', prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Био (мало инфы)', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша RolePlay биография практически пуста. Рекомендую подумать над новым сценарием вашего игрового персонажа. Не забудьте ознакомиться с правилами подачи биографии в этом разделе.[/CENTER]<br>" + '[Color=Red][CENTER]Отказано, закрыто.[/I][CENTER][/color][/FONT]', prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Био отказ(3е лицо)', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП биография получает статус: [Color=Red]Отказано.[/color]<br>Причиной отказа могло послужить создание биографии от 3го лица.[/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Био отказ(Грамматические ошибки)', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП биография получает статус: [Color=Red]Отказано.[/color]<br>Причиной отказа могло послужить большое количество грамматических ошибок.[/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Био отказ(Возраст и Дата)', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП биография получает статус: [Color=Red]Отказано.[/color]<br>Причиной отказа могло послужить несовпадение возраста и даты рождения.[/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Био отказ(18 лет)', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП биография получает статус: [Color=Red]Отказано.[/color]<br>Причина отказа: минимальный возраст для составления биографии: 18 лет.[/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Истек срок рассмотрения', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП биография получает статус: [Color=Red]Отказано.[/color]<br>По истечению 24-х часов полного объёма изменений не последовало.[/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Ошиблись разделом', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Вы ошиблись сервером/разделом.<br> [Color=Red]Отказано, закрыто.[/color][/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Не по теме', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваше сообщение никаким образом не относится к теме данного раздела.<br> [Color=Red]Отказано, закрыто.[/color][/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Не по форме', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]<br>Ваша RolePlay биография составлена не по форме. Ниже представлена актуальная форма: <br>Имя Фамилия:<br>Пол:<br>Дата рождения:<br>Возраст:<br>Национальность:<br>Семья:<br>Описание внешности:<br>Особенности характера:<br>Место текущего проживания:<br>Образование:<br>Жизнь в детстве и юности (Отсюда требуется расписать каждый из пунктов):<br>Взрослая жизнь (включая настоящее время):<br>Хобби:[/CENTER]<br> [Color=Red]Отказано, закрыто.[/color][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Заголовок биографии (отказ)', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Название темы должно быть строго по данной форме: «RolePlay биография гражданина Имя Фамилия».<br> [Color=Red]Отказано, закрыто.[/color][/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'nRP ник', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]У вас nRP ник, с данным ником RolePlay биография рассматриватся не будет.<br> [Color=Red]Отказано, закрыто.[/color][/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: 'Нарушение логики', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП биография получает статус: [Color=Red]Отказано.[/color]<br>Причина отказа: Нарушение логики при написании RolePlay биографии.[/CENTER][/FONT]", prefix: OTKAZBIO_PREFIX, status: false, }, { title: '╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴РП ситуации╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴', }, { title: 'РП ситуация одобрено', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП ситуация получает статус: [Color=Lime]Одобрено.[/I][/CENTER][/color][/FONT]", prefix: ODOBRENORP_PREFIX, status: false, }, { title: 'РП ситуация на доработке', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER][B][I][FONT=georgia]Вам даётся 24 часа на дополнение вашей РП ситуации[/CENTER]", prefix: NARASSMOTRENIIRP_PREFIX, status: false, }, { title: 'РП ситуация отказ', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП ситуация получает статус: [Color=Red]Отказано.[/color]<br>Причиной отказа могло послужить какое-либо нарушение из Правила RP ситуаций[/CENTER][/FONT]", prefix: OTKAZRP_PREFIX, status: false, }, { title: '╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴Неофициал. орг.╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴╴', }, { title: 'Неофициальная Орг Одобрено', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП ситуация получает статус: [Color=Lime]Одобрено.[/I][/CENTER][/color][/FONT]", prefix: ODOBRENOORG_PREFIX, status: false, }, { title: 'Неофициальная Орг на дороботке', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER][B][I][FONT=georgia]Вам даётся 24 часа на дополнение вашей Неофициальная Орг[/CENTER]", prefix: NARASSMOTRENIIORG_PREFIX, status: false, }, { title: 'Неофициальная Орг отказ', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER]Ваша РП ситуация получает статус: [Color=Red]Отказано.[/color]<br>Причиной отказа могло послужить какое-либо нарушение из Правила создания неофициальной RolePlay организации.[/CENTER][/FONT]", prefix: OTKAZORG_PREFIX, status: false, }, { title: 'Неофициальная Орг запроси активности', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER][B][I][FONT=georgia]Ваша неофициальная РП организация может быть закрыта по пункту правил: Неактив в топике организации более недели, он закрывается. Прикрепите отчёт о активности организации в виде скриншотов. Через 24 часа если отчёта не будет или он будет некорректный организация будет закрыта.[/CENTER]", prefix: PINN_PREFIX, status: false, }, { title: 'Неофициальная Орг закрытие активности', content: '[Color=rgb(222, 143, 255)][FONT=Georgia][CENTER][I]{{ greeting }}, уважаемый {{ user.mention }}.[/color][/CENTER]<br>' + "[CENTER][B][I][FONT=georgia]Активность не была предоставлена. Организация закрыта.[/CENTER]", prefix: UNACCСEPT_PREFIX, status: false, }, ]; $(document).ready(() => { // Загрузка скрипта для обработки шаблонов $('body').append('<script src="https://cdn.jsdelivr.net/npm/handlebars@latest/dist/handlebars.js"></script>'); // Добавление кнопок при загрузке страницы addButton('Одобрить', 'accepted'); addButton('Отказать', 'unaccept'); addButton('На рассмотрение', 'pin'); addButton('Меню скрипта', 'selectAnswer'); // Поиск информации о теме const threadData = getThreadData(); $('button#pin').click(() => editThreadData(PINN_PREFIX, true)); $('button#Ga').click(() => editThreadData(GA_PREFIX, true)); $('button#Spec').click(() => editThreadData(SPECY_PREFIX, true)); $('button#teamProject').click(() => editThreadData(COMMAND_PREFIX, true)); $(`button#selectAnswer`).click(() => { XF.alert(buttonsMarkup(buttons), null, 'Выберите ответ:'); buttons.forEach((btn, id) => { if (id > 0) { $(`button#answers-${id}`).click(() => pasteContent(id, threadData, true)); } else { $(`button#answers-${id}`).click(() => pasteContent(id, threadData, false)); } }); }); }); function addButton(name, id) { $('.button--icon--reply').before( `<button type="button" class="button rippleButton" id="${id}" style="margin: 3px;">${name}</button>`, ); } function buttonsMarkup(buttons) { return `<div class="select_answer">${buttons .map( (btn, i) => `<button id="answers-${i}" class="button--primary button ` + `rippleButton" style="margin:5px"><span class="button-text">${btn.title}</span></button>`, ) .join('')}</div>`; } function pasteContent(id, data = {}, send = false) { const template = Handlebars.compile(buttons[id].content); if ($('.fr-element.fr-view p').text() === '') $('.fr-element.fr-view p').empty(); $('span.fr-placeholder').empty(); $('div.fr-element.fr-view p').append(template(data)); $('a.overlay-titleCloser').trigger('click'); if (send == true) { editThreadData(buttons[id].prefix, buttons[id].status); $('.button--icon.button--icon--reply.rippleButton').trigger('click'); } } function getThreadData() { const authorID = $('a.username')[0].attributes['data-user-id'].nodeValue; const authorName = $('a.username').html(); const hours = new Date().getHours(); return { user: { id: authorID, name: authorName, mention: `[USER=${authorID}]${authorName}[/USER]`, }, greeting: () => 4 < hours && hours <= 11 ? 'Доброе утро' : 11 < hours && hours <= 15 ? 'Добрый день' : 15 < hours && hours <= 21 ? 'Добрый вечер' : 'Доброй ночи', }; } function editThreadData(prefix, pin = false) { // Получаем заголовок темы, так как он необходим при запросе const threadTitle = $('.p-title-value')[0].lastChild.textContent; if(pin == false){ fetch(`${document.URL}edit`, { method: 'POST', body: getFormData({ prefix_id: prefix, title: threadTitle, _xfToken: XF.config.csrf, _xfRequestUri: document.URL.split(XF.config.url.fullBase)[1], _xfWithData: 1, _xfResponseType: 'json', }), }).then(() => location.reload()); } else { fetch(`${document.URL}edit`, { method: 'POST', body: getFormData({ prefix_id: prefix, title: threadTitle, pin: 1, _xfToken: XF.config.csrf, _xfRequestUri: document.URL.split(XF.config.url.fullBase)[1], _xfWithData: 1, _xfResponseType: 'json', }), }).then(() => location.reload()); } if(pin == false){ fetch(`${document.URL}edit`, { method: 'POST', body: getFormData({ prefix_id: prefix, title: threadTitle, _xfToken: XF.config.csrf, _xfRequestUri: document.URL.split(XF.config.url.fullBase)[1], _xfWithData: 1, _xfResponseType: 'json', }), }).then(() => location.reload()); } else { fetch(`${document.URL}edit`, { method: 'POST', body: getFormData({ prefix_id: prefix, title: threadTitle, pin: 1, _xfToken: XF.config.csrf, _xfRequestUri: document.URL.split(XF.config.url.fullBase)[1], _xfWithData: 1, _xfResponseType: 'json', }), }).then(() => location.reload()); } function moveThread(prefix, type) { // Получаем заголовок темы, так как он необходим при запросе const threadTitle = $('.p-title-value')[0].lastChild.textContent; fetch(`${document.URL}move`, { method: 'POST', body: getFormData({ prefix_id: prefix, title: threadTitle, target_node_id: type, redirect_type: 'none', notify_watchers: 1, starter_alert: 1, starter_alert_reason: "", _xfToken: XF.config.csrf, _xfRequestUri: document.URL.split(XF.config.url.fullBase)[1], _xfWithData: 1, _xfResponseType: 'json', }), }).then(() => location.reload()); } function getFormData(data) { const formData = new FormData(); Object.entries(data).forEach(i => formData.append(i[0], i[1])); return formData; } } })();