您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Работа с форумом РУСИ
// ==UserScript== // @name Кураторы форума | РУСЬ МОБАЙЛ // @namespace https://forum.russia-game.ru/ // @version 0.2 // @description Работа с форумом РУСИ // @author Kosty Youmans // @match https://forum.russia-game.ru/* // @grant none // @license MIT // @icon https://icons.iconarchive.com/icons/thesquid.ink/free-flat-sample/128/support-icon.png // ==/UserScript== (function () { 'use strict'; const PIN_PREFIX = 2; // На рассмотрении const RESHENO_PREFIX = 3; // Решено const UNACCEPT_PREFIX = 4; // Отказано const ACCEPT_PREFIX = 5; // Одобрено const COMMAND_PREFIX = 6; // Команде проекта const GA_PREFIX = 7; // Главному администратору const WATCHED_PREFIX = 9; const buttons = [ { title: '-----------------------------------------------------Раздел игроков-----------------------------------------------------' }, { title: 'Взять жалобу на рассмотрение', content: '[CENTER][size=15px][font=Trebuchet MS][CENTER]Приветствую, уважаемый игрок [COLOR=rgb(255,200,0)] {{ user.mention }}[/color].[/size][/font][/CENTER]<br><br>' + '[CENTER][size=15px][font=Trebuchet MS]Благодарим вас за ваше обращение. Ваша жалоба получает Статус: [Color=rgb(255, 155 ,0)]На рассмотрении.[/color][/size][/font][/CENTER]<br><br>' + '[CENTER][size=15px][font=Trebuchet MS]Ожидайте ответа в данной теме[/color].[/size][/font][/CENTER>', prefix: PIN_PREFIX, status: false, }, { title: 'Недостаточно док-в', content: '[CENTER][size=15px][font=Trebuchet MS][CENTER]Доброго времени суток, уважаемый [COLOR=rgb(255,200,0)] {{ user.mention }}[/color].[/size][/font][/CENTER]<br><br>' + '[CENTER][size=15px][font=Trebuchet MS]Недостаточно доказательств[/size][/font][/CENTER]<br><br>' + '[CENTER][size=15px][font=Trebuchet MS]Отказано, Закрыто[/color].[/size][/font][/CENTER]', prefix: UNACCEPT_PREFIX, status: false, }, { title: '-------------------------------------------------Раздел администраций------------------------------------------------' }, { title: 'Админ выдал наказание верно', content: '[CENTER][size=15px][font=Trebuchet MS][CENTER]Приветствую, уважаемый игрок [COLOR=rgb(255,200,0)] {{ user.mention }}[/color].[/size][/font][/CENTER]<br><br>' + '[CENTER][size=15px][font=Trebuchet MS]Благодарим вас за вашу жалобу. После проведения расследования мы пришли к выводу, что в данной жалобе администратор выдал наказание верно.[/size][/font][/CENTER><br><br>' + '[CENTER][size=15px][font=Trebuchet MS]Мы всегда стремимся поддерживать честную и справедливую игровую среду для всех участников.[/size][/font][/CENTER><br><br>' + '[CENTER][size=15px][font=Trebuchet MS]Ваша внимательность и активное участие в сообществе игры оцениваются нами. Спасибо за понимание![/size][/font][/CENTER><br><br>' + '[CENTER][size=15px][font=Trebuchet MS]С уважением, Администрация [COLOR=rgb(255,200,0)]РУСЬ Mobile[/color].[/size][/font][/CENTER]', prefix: UNACCEPT_PREFIX, status: false, }, ]; $(document).ready(() => { $('button#teamProject').click(() => editThreadData(COMMAND_PREFIX, true)); $('button#unaccept').click(() => editThreadData(UNACCEPT_PREFIX, false)); $('button#selectAnswer').click(() => { XF.alert(buttonsMarkup(buttons), null, 'Выберите ответ:'); buttons.forEach((btn, id) => { $(`button#answers-${id}`).click(() => pasteContent(id, threadData, id > 0)); }); }); 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); const editor = $('div.fr-element.fr-view p'); editor.empty(); // Очищаем редактор перед вставкой editor.append(template(data)); $('a.overlay-titleCloser').trigger('click'); if (send) { 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'].value; const authorName = $('a.username').html(); return { user: { id: authorID, name: authorName, mention: `[USER=${authorID}]${authorName}[/USER]`, }, }; } function editThreadData(prefix, pin = false) { const threadTitle = $('.p-title-value').text().trim(); const data = { prefix_id: prefix, title: threadTitle, _xfToken: XF.config.csrf, _xfRequestUri: document.URL.split(XF.config.url.fullBase)[1], _xfWithData: 1, _xfResponseType: 'json', }; if (pin) { data.pin = 1; } fetch(`${document.URL}edit`, { method: 'POST', body: getFormData(data), }).then(() => location.reload()); } function moveThread(prefix, type) { const threadTitle = $('.p-title-value').text().trim(); const data = { 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', }; fetch(`${document.URL}move`, { method: 'POST', body: getFormData(data), }).then(() => location.reload()); } function getFormData(data) { const formData = new FormData(); Object.entries(data).forEach(([key, value]) => formData.append(key, value)); return formData; } }); })