// ==UserScript==
// @name Greasyfork - Add notes to the script
// @name:en Greasyfork - Add notes(aliases/tags) to the script
// @name:zh-CN Greasyfork - 为脚本添加备注(别名/标签)
// @name:zh-TW Greasyfork - 為腳本新增備註(別名/標籤)
// @name:ja Greasyfork - スクリプトにメモを追加する(エイリアス/タグ)
// @name:ko Greasyfork - 스크립트에 메모 추가 (별칭/태그)
// @name:fr Greasyfork - Ajouter des notes (alias/tag) au script
// @namespace https://gf.qytechs.cn/zh-CN/users/193133-pana
// @homepage https://gf.qytechs.cn/zh-CN/users/193133-pana
// @icon 
// @version 2.1.4
// @description Add a note(alias/tag) for scripts to help identify and search
// @description:en Add a note(alias/tag) for scripts to help identify and search
// @description:zh-CN 为脚本添加备注(别名/标签)功能,以帮助识别和搜索
// @description:zh-TW 為腳本新增備註(別名/標籤)功能,以幫助識別和搜尋
// @description:ja 識別と検索に役立つコメント(エイリアス/タグ)関数をスクリプトに追加
// @description:ko 식별 및 검색을 돕기 위해 스크립트에 주석 (별칭/태그) 기능 추가
// @description:fr Ajouter une fonction de commentaire (alias/tag) au script pour aider à identifier et rechercher
// @author pana
// @license GNU General Public License v3.0 or later
// @compatible chrome
// @compatible firefox
// @include http*://*gf.qytechs.cn/*
// @include http*://*sleazyfork.org/*
// @require https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.min.js
// @require https://cdn.jsdelivr.net/gh/LightAPIs/greasy-fork-library@8505bfa589b6b7bd3ec9f33bdf350f7cd607cf69/Note_Obj.js
// @grant GM_info
// @grant GM.info
// @grant GM_getValue
// @grant GM.getValue
// @grant GM_setValue
// @grant GM.setValue
// @grant GM_deleteValue
// @grant GM.deleteValue
// @grant GM_listValues
// @grant GM.listValues
// @grant GM_openInTab
// @grant GM.openInTab
// @grant GM_registerMenuCommand
// @grant GM_unregisterMenuCommand
// @grant GM_addValueChangeListener
// @grant GM_removeValueChangeListener
// ==/UserScript==
(async function () {
'use strict';
if (typeof Note_Obj !== 'function') {
alert('Note_Obj.js was not loaded successfully!');
}
const updated = '2021-08-04';
const GF_ICON = {
NOTE_BLACK:
'url()',
};
const GF_STYLE = `
.note-obj-gf-note-btn {
background-image: ${GF_ICON.NOTE_BLACK};
background-repeat: no-repeat;
background-position: center;
cursor: pointer;
vertical-align: top;
}
.note-obj-gf-info-note-btn {
background-size: 32px auto;
width: 32px;
height: 32px;
margin-left: 20px;
display: inline-block;
}
.note-obj-gf-library-note-btn {
background-size: 24px auto;
width: 24px;
height: 24px;
margin-left: 20px;
display: inline-block;
}
.note-obj-gf-list-note-btn {
background-size: 24px auto;
width: 24px;
height: 24px;
margin-left: 10px;
display: none;
}
.note-obj-gf-ts-note-btn {
background-size: 16px auto;
width: 16px;
height: 16px;
margin-left: 10px;
display: none;
vertical-align: sub;
}
ol.script-list li:hover .note-obj-gf-list-note-btn,
#script-table tbody tr:hover .note-obj-gf-ts-note-btn {
display: inline-block;
}
.note-obj-gf-note-tag,
.note-obj-gf-ts-note-tag {
background-color: #3c81df;
color: #fff;
display: inline-block;
align-items: center;
white-space: nowrap;
border-radius: 50px;
padding: 1px 10px;
line-height: 1em;
}
.note-obj-gf-list-note-tag {
text-decoration: none;
}
`;
function change_Event(note_obj, id = null) {
let pathname = location.pathname;
if (/^\/[\w-]+\/scripts\/\d+-/i.test(pathname)) {
let script_id = /^\/[\w-]+\/scripts\/(\d+)-/i.exec(pathname)[1];
let ele = document.querySelector('#script-info h2');
ele &&
(!id || id == script_id) &&
note_obj.handler(script_id, ele, null, {
add: 'span',
class: 'note-obj-gf-note-tag',
});
} else if (/^\/[\w-]+\/scripts/i.test(pathname) || /^\/[\w-]+\/users\/\d+/i.test(pathname)) {
let browse_list = document.querySelectorAll('ol.script-list li');
for (let ele of browse_list) {
let script_id = ele.getAttribute('data-script-id');
if (script_id) {
let header = ele.querySelector('article > h2 > a');
header &&
(!id || id == script_id) &&
note_obj.handler(script_id, header, null, {
add: 'span',
class: ['note-obj-gf-note-tag', 'note-obj-gf-list-note-tag'],
});
}
}
document.querySelectorAll('#script-table tbody tr').forEach(item => {
let script_title = item.querySelector('.thetitle a');
if (script_title) {
let script_id = script_title.href.match(/\d+$/) && script_title.href.match(/\d+$/)[0];
(!id || id == script_id) &&
note_obj.handler(script_id, script_title, null, {
add: 'span',
class: 'note-obj-gf-ts-note-tag',
});
}
});
}
}
function init_Script(note_obj) {
let browse_list = document.querySelectorAll('ol.script-list li');
for (let ele of browse_list) {
let script_id = ele.getAttribute('data-script-id');
if (script_id) {
let description = ele.querySelector('.description');
let script_name = (ele.querySelector('article > h2 > a') && ele.querySelector('article > h2 > a').textContent) || '';
description &&
!description.parentNode.querySelector('.note-obj-add-note-btn') &&
description.before(note_obj.createNoteBtn(script_id, script_name, ['note-obj-gf-note-btn', 'note-obj-gf-list-note-btn']));
let header = ele.querySelector('article > h2 > a');
header &&
note_obj.judgeUsers(script_id) &&
note_obj.handler(
script_id,
header,
null,
{
add: 'span',
class: ['note-obj-gf-note-tag', 'note-obj-gf-list-note-tag'],
},
script_name
);
}
}
}
function init_TS(note_obj) {
document.querySelectorAll('#script-table tbody tr').forEach(item => {
let script_title = item.querySelector('.thetitle a');
if (script_title) {
let script_id = script_title.href.match(/\d+$/) && script_title.href.match(/\d+$/)[0];
let thetitle = item.querySelector('.thetitle');
script_id &&
thetitle.appendChild(
note_obj.createNoteBtn(script_id, script_title.textContent, ['note-obj-gf-note-btn', 'note-obj-gf-ts-note-btn'])
);
note_obj.judgeUsers(script_id) &&
note_obj.handler(
script_id,
script_title,
null,
{
add: 'span',
class: 'note-obj-gf-ts-note-tag',
},
script_title.textContent
);
}
});
}
async function init() {
let old_config = await Note_Obj.GM.getValue('greasyfork_config', null);
if (old_config && old_config.scripts_array) {
for (let item of old_config.scripts_array) {
Note_Obj.GM.setValue(item.id, {
tag: item.tag,
});
}
await Note_Obj.GM.deleteValue('greasyfork_config');
}
let note_obj = new Note_Obj('myGreasyForkNote');
await note_obj.init({
style: GF_STYLE,
changeEvent: change_Event,
script: {
author: {
name: 'pana',
homepage: 'https://gf.qytechs.cn/zh-CN/users/193133-pana',
},
address: 'https://gf.qytechs.cn/scripts/404275',
updated: updated,
},
itemClick: key => 'https://gf.qytechs.cn/scripts/' + key,
type: 'script',
});
let pathname = location.pathname;
if (/^\/[\w-]+\/scripts\/\d+-/i.test(pathname)) {
let script_id = /^\/[\w-]+\/scripts\/(\d+)-/i.exec(pathname)[1];
let install_help_link = document.querySelector('#install-area .install-help-link:last-child');
let suggestion = document.querySelector('#script-feedback-suggestion');
let script_name = (document.querySelector('header h2') && document.querySelector('header h2').textContent) || '';
if (install_help_link) {
install_help_link.after(note_obj.createNoteBtn(script_id, script_name, ['note-obj-gf-note-btn', 'note-obj-gf-info-note-btn']));
} else if (suggestion) {
suggestion.appendChild(note_obj.createNoteBtn(script_id, script_name, ['note-obj-gf-note-btn', 'note-obj-gf-library-note-btn']));
}
let ele = document.querySelector('#script-info h2');
ele &&
note_obj.judgeUsers(script_id) &&
note_obj.handler(
script_id,
ele,
null,
{
add: 'span',
class: 'note-obj-gf-note-tag',
},
script_name
);
} else if (/^\/[\w-]+\/scripts/i.test(pathname) || /^\/[\w-]+\/users\/\d+/i.test(pathname)) {
init_Script(note_obj);
let browse_script_list = document.querySelector('#browse-script-list');
if (browse_script_list) {
let script_observer = new MutationObserver(() => {
init_Script(note_obj);
});
script_observer.observe(browse_script_list, {
childList: true,
});
}
init_TS(note_obj);
let ts_tbody = document.querySelector('#script-table tbody');
if (ts_tbody) {
let observer = new MutationObserver(() => {
init_TS(note_obj);
});
observer.observe(ts_tbody, {
childList: true,
});
}
}
}
init();
})();