KING RUSSIA | Testers QA

Для сотрудников "Контроля Качества"

当前为 2025-03-24 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name KING RUSSIA | Testers QA
  3. // @namespace https://forum.kingrussia.com
  4. // @version 1.20
  5. // @description Для сотрудников "Контроля Качества"
  6. // @author KING RUSSIA
  7. // @match https://forum.kingrussia.com/index.php*
  8. // @include https://forum.kingrussia.com/index.php
  9. // @grant none
  10. // @license MIT
  11. // @collaborator Basis of Antonio Carrizo and consultant Rosenfeld
  12. // @icon https://icons.iconarchive.com/icons/thesquid.ink/free-flat-sample/128/support-icon.png
  13. // // @downloadURL
  14. // ==/UserScript==
  15. (function () {
  16. 'use strict';
  17. const PAQUA_PREFIX = 15; // Prefix that will be set when thread solved
  18. const COMMAND_PREFIX = 10; // Prefix that will be set when thread send to project team
  19. const buttons = [
  20. {
  21. title: 'Нарушение правил раздела',
  22. content:
  23. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]{{ greeting }}, уважаемый(-ая)[B] {{ user.name }}[/B]![/CENTER]<br><br>' +
  24. "[CENTER][size=15px][font=Georgia][COLOR=rgb(255,255,255)]Пожалуйста, убедительная просьба, [COLOR=rgb(255,215,0)]ознакомиться с назначением данного раздела [COLOR=rgb(255,255,255)]в котором Вы создали тему, так как Ваш запрос никоим образом [COLOR=rgb(255,215,0)]не относится к технической проблеме.[/CENTER]<br><br>" +
  25. '[CENTER][size=15px][font=Georgia][COLOR=rgb(255,0,0)]Отказано, закрыто.[/CENTER]<br>' +
  26. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]С уважение от отдела контроля качества![/CENTER]',
  27. prefix: PAQUA_PREFIX,
  28. status: false,
  29. },
  30. {
  31. title: 'Краш / вылет',
  32. content:
  33. '[CENTER]{{ greeting }}, уважаемый(-ая)[B] {{ user.name }}[/B]![/CENTER]<br><br>' +
  34. "[CENTER]В том случае, если Вы вылетели из игры во время игрового процесса (произошел краш), в обязательном порядке необходимо обратиться в данную тему - https://clck.ru/aqMZu [/CENTER]<br>" +
  35. "[CENTER][CODE]01. Ваш игровой никнейм: <br> 02. Сервер: <br> 03. Тип проблемы: Обрыв соединения | Проблема с ReCAPTCHA | Краш игры (закрытие игры) | Другое [Выбрать один вариант ответа] <br> 04. Действия, которые привели к этому (при вылетах, по возможности предоставлять место сбоя): <br> 05. Как часто данная проблема: <br> 06. Полное название мобильного телефона: <br> 07. Версия Android: <br> 08. Дата и время (по МСК): <br> 09. Связь с Вами по Telegram/VK:[/CODE]<br><br>" +
  36. '[CENTER]Решено, заполните данную форму в теме, указанной выше.[/CENTER]',
  37. prefix: PAQUA_PREFIX,
  38. status: false,
  39. },
  40. {
  41. title: 'Дублирование темы',
  42. content:
  43. '[CENTER]{{ greeting }}, уважаемый(-ая)[B] {{ user.name }}[/B]![/CENTER]<br><br>' +
  44. "[CENTER]Ответ уже был дан в подобной теме. Пожалуйста, прекратите создавать идентичные или похожие темы - иначе Ваш форумный аккаунт может быть заблокирован.<br><br>" +
  45. '[CENTER]Отказано, закрыто.[/CENTER]',
  46. prefix: PAQUA_PREFIX,
  47. status: false,
  48. },
  49. {
  50. title: 'Проблема будет исправлена',
  51. content:
  52. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]{{ greeting }}, уважаемый(-ая)[B] {{ user.name }}[/B]![/CENTER]<br><br>' +
  53. "[CENTER][size=15px][font=Georgia][COLOR=rgb(255,255,255)]Данная недоработка будет [COLOR=rgb(255,140,0)]проверена и исправлена. [COLOR=rgb(255,0,0)]Спасибо, [COLOR=rgb(255,255,255)]ценим Ваш вклад!<br><br>" +
  54. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]Рассмотрено.[/CENTER]<br>' +
  55. '[CENTER][size=15px][font=Georgia][CENTER][COLOR=rgb(0,255,255)]С уважение от отдела контроля качества![/CENTER]',
  56. prefix: PAQUA_PREFIX,
  57. status: false,
  58. },
  59. {
  60. title: 'Уточните суть проблемы',
  61. content:
  62. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]{{ greeting }}, уважаемый(-ая)[B] {{ user.name }}[/B]![/CENTER]<br><br>' +
  63. "[CENTER][size=15px][font=Georgia][COLOR=rgb(255,255,255)]Данная недоработка будет [COLOR=rgb(255,140,0)]проверена и исправлена. [COLOR=rgb(255,0,0)]Спасибо, [COLOR=rgb(255,255,255)]ценим Ваш вклад!<br><br>" +
  64. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]Рассмотрено.[/CENTER]<br>' +
  65. '[CENTER][size=15px][font=Georgia][CENTER][COLOR=rgb(0,255,255)]С уважение от отдела контроля качества![/CENTER]',
  66. prefix: PAQUA_PREFIX,
  67. status: false,
  68. },
  69. {
  70. title: 'Известно о проблеме',
  71. content:
  72. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]{{ greeting }}, уважаемый(-ая)[B] {{ user.name }}[/B]![/CENTER]<br><br>' +
  73. "[CENTER][size=15px][font=Georgia][COLOR=rgb(255,215,0)]Команде разработчиков [COLOR=rgb(255,255,255)]уже известно о данной проблеме, она обязательно будет рассмотрена и исправлена. [COLOR=rgb(255,0,0)]Спасибо [COLOR=rgb(255,255,255)]за Ваше обращение!<br><br>" +
  74. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]Рассмотрено.[/CENTER]<br>' +
  75. '[CENTER][size=15px][font=Georgia][CENTER][COLOR=rgb(0,255,255)]С уважение от отдела контроля качества![/CENTER]',
  76. prefix: PAQUA_PREFIX,
  77. status: false,
  78. },
  79. {
  80. title: 'Передано на тестирование',
  81. content:
  82. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]{{ greeting }}, уважаемый(-ая)[B] {{ user.name }}[/B]![/CENTER]<br><br>' +
  83. "[CENTER][size=15px][font=Georgia][COLOR=rgb(255,255,0)]Благодарим за уведомление о недоработке. [COLOR=rgb(255,255,255)]Ваша тема находится в процессе тестирования.<br><br>" +
  84. '[CENTER][size=15px][font=Georgia][COLOR=rgb(255,215,0)]На рассмотрении.[/CENTER]' +
  85. '[CENTER][size=15px][font=Georgia][CENTER][COLOR=rgb(0,255,255)]С уважение от отдела контроля качества![/CENTER]',
  86. prefix: PAQUA_PREFIX,
  87. status: false,
  88. },
  89. {
  90. title: 'Команде проекта',
  91. content:
  92. '[CENTER]{{ greeting }}, уважаемый(-ая)[B] {{ user.name }}[/B]![/CENTER]<br><br>' +
  93. "[CENTER]Ваша тема закреплена и находится на рассмотрении. Пожалуйста, ожидайте выноса вердикта команды проекта.<br><br>" +
  94. '[CENTER]Создавать новые темы с данной проблемой — не нужно, ожидайте ответа в данной теме. Если проблема решится - Вы всегда можете уведомить нас о ее решении.[/CENTER]',
  95. prefix: COMMAND_PREFIX,
  96. status: false,
  97. },
  98. {
  99. title: 'Недостаточно доказательств',
  100. content:
  101. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]{{ greeting }}, уважаемый(-ая)[B] {{ user.name }}[/B]![/CENTER]<br><br>' +
  102. "[CENTER][size=15px][font=Georgia][COLOR=rgb(255,255,255)]Без доказательств (в частности скриншоты или видео)[COLOR=rgb(255,0,0)] – решить проблему не получится. [COLOR=rgb(255,255,255)]Если доказательства найдутся - создайте новую тему, приложив доказательства с фото-хостинга yapx.ru или imgur.com<br><br>" +
  103. '[CENTER][size=15px][font=Georgia][COLOR=rgb(0,255,255)]Рассмотрено, [COLOR=rgb(255,0,0)]закрыто.[/CENTER]<br>' +
  104. '[CENTER][size=15px][font=Georgia][CENTER][COLOR=rgb(0,255,255)]С уважение от отдела контроля качества![/CENTER]',
  105. prefix: PAQUA_PREFIX,
  106. status: false,
  107. },
  108. ];
  109.  
  110. $(document).ready(() => {
  111. // Загрузка скрипта для обработки шаблонов
  112. $('body').append('<script src="https://cdn.jsdelivr.net/npm/handlebars@latest/dist/handlebars.js"></script>');
  113.  
  114. // Добавление кнопок при загрузке страницы
  115. addButton('На рассмотрении', 'pin');
  116. addButton('КП', 'teamProject');
  117. addButton('Отказано', 'unaccept');
  118. addButton('Рассмотрено', 'watched');
  119. addButton('Решено', 'accepted');
  120. addButton('Закрыто', 'closed');
  121. addButton('Ответы', 'selectAnswer');
  122.  
  123.  
  124. // Поиск информации о теме
  125. const threadData = getThreadData();
  126.  
  127. $('button#unaccept').click(() => editThreadData(UNACCEPT_PREFIX, false));
  128. $('button#pin').click(() => editThreadData(PIN_PREFIX, true));
  129. $('button#accepted').click(() => editThreadData(ACCEPT_PREFIX, false));
  130. $('button#teamProject').click(() => editThreadData(COMMAND_PREFIX, true));
  131. $('button#watched').click(() => editThreadData(WATCHED_PREFIX, false));
  132. $('button#closed').click(() => editThreadData(CLOSE_PREFIX, false));
  133.  
  134. $(`button#selectAnswer`).click(() => {
  135. XF.alert(buttonsMarkup(buttons), null, 'Добавьте ответ:');
  136. buttons.forEach((btn, id) => {
  137. $(`button#answers-${id}`).click(() => pasteContent(id, threadData));
  138. });
  139. });
  140. });
  141.  
  142.  
  143. function addButton(name, id) {
  144. $('.button--icon--reply').before(
  145. `<button type="button" class="button rippleButton" id="${id}" style="margin: 3px;">${name}</button>`,
  146. );
  147. }
  148.  
  149. function buttonsMarkup(buttons) {
  150. return `<div class="select_answer">${buttons
  151. .map(
  152. (btn, i) =>
  153. `<button id="answers-${i}" class="button--primary button ` +
  154. `rippleButton" style="margin:5px"><span class="button-text">${btn.title}</span></button>`,
  155. )
  156. .join('')}</div>`;
  157. }
  158.  
  159. function pasteContent(id, data = {}) {
  160. const template = Handlebars.compile(buttons[id].content);
  161. if ($('.fr-element.fr-view p').text() === '') $('.fr-element.fr-view p').empty();
  162.  
  163. $('span.fr-placeholder').empty();
  164. $('div.fr-element.fr-view p').append(template(data));
  165. $('a.overlay-titleCloser').trigger('click');
  166. }
  167.  
  168. // Приветствие и время суток
  169. function getThreadData() {
  170. const authorID = $('a.username')[0].attributes['data-user-id'].nodeValue;
  171. const authorName = $('a.username').html();
  172. const hours = new Date().getHours();
  173. return {
  174. user: {
  175. id: authorID,
  176. name: authorName,
  177. mention: `[USER=${authorID}]${authorName}[/USER]`,
  178. },
  179. greeting: () =>
  180. 4 < hours && hours <= 11
  181. ? 'Доброе утро'
  182. : 11 < hours && hours <= 17
  183. ? 'Добрый день'
  184. : 17 < hours && hours <= 23
  185. ? 'Добрый вечер'
  186. : 'Доброй ночи',
  187. };
  188. }
  189.  
  190. function editThreadData(prefix, pin = false) {
  191. // Получаем заголовок темы, так как он необходим при запросе
  192. const threadTitle = $('.p-title-value')[0].lastChild.textContent;
  193.  
  194. if(pin == false){
  195. fetch(`${document.URL}edit`, {
  196. method: 'POST',
  197. body: getFormData({
  198. prefix_id: prefix,
  199. title: threadTitle,
  200. _xfToken: XF.config.csrf,
  201. _xfRequestUri: document.URL.split(XF.config.url.fullBase)[1],
  202. _xfWithData: 1,
  203. _xfResponseType: 'json',
  204. }),
  205. }).then(() => location.reload());
  206. }
  207. if(pin == true){
  208. fetch(`${document.URL}edit`, {
  209. method: 'POST',
  210. body: getFormData({
  211. prefix_id: prefix,
  212. title: threadTitle,
  213. discussion_open: 1,
  214. sticky: 1,
  215. _xfToken: XF.config.csrf,
  216. _xfRequestUri: document.URL.split(XF.config.url.fullBase)[1],
  217. _xfWithData: 1,
  218. _xfResponseType: 'json',
  219. }),
  220. }).then(() => location.reload());
  221. }
  222. if(prefix == UNACCEPT_PREFIX || prefix == ACCEPT_PREFIX || prefix == CLOSE_PREFIX || prefix == WATCHED_PREFIX) {
  223. moveThread(prefix, 230);
  224. }
  225. }
  226.  
  227. function moveThread(prefix, type) {
  228. }
  229. })();