// ==UserScript== // @name Instagram为关注用户添加备注 // @name:en Instagram - Add notes(aliases/tags) to the user // @name:zh-CN Instagram - 为用户添加备注(别名/标签) // @name:zh-TW Instagram - 為用戶添加備註(別名/標籤) // @name:ja Instagram - ユーザーへのメモの追加(エイリアス/ラベル) // @name:ko Instagram - 사용자에게 메모 추가 (별칭/라벨) // @name:fr Instagram - ajouter des notes aux utilisateurs (alias/tag) // @namespace https://greasyfork.org/zh-CN/users/193133-pana // @homepage https://greasyfork.org/zh-CN/users/193133-pana // @icon  // @version 5.3.6 // @description 为用户添加备注(别名/标签)功能,以帮助识别和搜索 // @description:en Add a note(alias/tag) for users to help identify and search // @description:zh-CN 为用户添加备注(别名/标签)功能,以帮助识别和搜索 // @description:zh-TW 為用戶添加備註(別名/標籤)功能,以幫助識別和搜尋 // @description:ja ユーザーが識別と検索に役立つメモ(エイリアス/タグ)機能を追加する // @description:ko 사용자 식별 및 검색에 도움이되는 메모 (별칭/태그) 기능 추가 // @description:fr Ajouter une fonction de notes (alias/tag) pour les utilisateurs pour aider à identifier et rechercher // @license GNU General Public License v3.0 or later // @compatible chrome // @compatible firefox // @author pana // @include http*://*instagram.com/* // @require https://cdn.jsdelivr.net/npm/arrive@2.4.1/minified/arrive.min.js // @require https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.min.js // @require https://cdn.jsdelivr.net/gh/LightAPIs/greasy-fork-library@d07ae4ecc5829d3674761f3069f8801b429bab49/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 // @downloadURL none // ==/UserScript== (async function () { 'use strict'; if (typeof Note_Obj !== 'function') { alert('Note_Obj.js was not loaded successfully!'); } const updated = '2022-06-02'; const INS_ICON = { NOTE_BLACK: 'url()', SERACH_BLUE: 'url()', }; const INS_STYLE = ` .note-obj-ins-font-blue-color { color: #336699; } .note-obj-ins-background-box { display: inline-block; align-items: center; white-space: nowrap; border-radius: 50px; padding: 0px 10px; background-color: #336699; color: #fff; } .note-obj-ins-add-btn { background-image: ${INS_ICON.NOTE_BLACK}; background-size: 24px; background-repeat: no-repeat; background-position: center; margin-left: 5px; cursor: pointer; width: 24px; height: 24px; } .note-obj-ins-homepage-btn { margin: 6px !important; } .note-obj-ins-homepage-btn:hover { opacity: 0.5; } .note-obj-ins-userpage-btn { margin-top: 2px; } .note-obj-ins-userpage-tag { display: block; font-size: 20px; margin-bottom: 20px; white-space: nowrap; } .note-obj-ins-mobile-search-button { background-image: ${INS_ICON.SERACH_BLUE}; background-size: 24px; background-repeat: no-repeat; background-position: center; cursor: pointer; min-width: 0px; height: 100%; flex: 1 1 auto; } .note-obj-ins-font-bold { font-weight: bold; } .note-obj-veryins-blue-tag { background-color: #3c81df; color: #fff; display: inline-flex; align-items: center; padding: 0px 10px; white-space: nowrap; line-height: 100%; border-radius: 50px; padding: 2px 10px; } .note-obj-veryins-userpage-btn { display: inline-block; vertical-align: middle; } `; var selector = { body: 'body', homepage: { article: 'article', id: '._aaqt a', id_shell: '._aaqt', icon: 'span._aamz', comment_id: '._aap6._aap7._aap8 a', comment_at: '._aat6 ._aade > .notranslate', }, homepage_stories: { id: '._aamb._aamc', id_shell: '._aam8', }, homepage_recommend: { id: '._aak3 ._aap6._aap7._aap8 a', }, user_page: { frame: '._aa_h', id: '._aa_m h2', bar: '._aa_n', box: '._aa_m', common: 'span._aaai', suggest: '._acj1 a.notranslate', info_at: '.notranslate', user_name: '._aa_c > span', }, watch_list: { initial_item: '._aae- li', later_item: '._aaei', id: '._aap6._aap7._aap8 a', }, dialog: { frame: '._a3gq article', comment_id: '._a9zm ._aap6._aap7._aap8 a', comment_at: '._a9zs .notranslate', }, request: { follow: '._aajc ._aap6._aap7._aap8 a', }, mobile: { bottom_bar: '._abp7', }, suggest: { user: '._aa0- ._aap6._aap7._aap8 a', }, }; function instagram_Change_Event(note_obj, user_id = null) { for (let article of document.querySelectorAll(selector.homepage.article)) { let article_user = article.querySelector(selector.homepage.id); if (article_user) { let article_user_id = Note_Obj.fn.getUserIdFromLink(article_user.href); (!user_id || user_id == article_user_id) && note_obj.handler(article_user_id, article_user, null, { add: note_obj.getConfig().other.replaceHomepageID ? null : 'span', classname: note_obj.getConfig().other.replaceHomepageID ? 'note-obj-ins-font-blue-color' : 'note-obj-ins-background-box', title: note_obj.getConfig().other.replaceHomepageID, }); } for (let comment of article.querySelectorAll(selector.homepage.comment_id)) { let comment_id = Note_Obj.fn.getUserIdFromLink(comment.href); (!user_id || user_id == comment_id) && note_obj.handler(comment_id, comment, null, { classname: 'note-obj-ins-font-blue-color', }); } for (let comment_at of article.querySelectorAll(selector.homepage.comment_at)) { let comment_at_id = Note_Obj.fn.getUserIdFromLink(comment_at.href); (!user_id || user_id == comment_at_id) && note_obj.handler(comment_at_id, comment_at, null, { symbol: { prefix: '@', }, title: true, classname: 'note-obj-ins-font-blue-color', }); } for (let pic_comment_user of article.querySelectorAll(selector.dialog.comment_id)) { let pic_comment_id = Note_Obj.fn.getUserIdFromLink(pic_comment_user.href); (!user_id || user_id == pic_comment_id) && note_obj.handler(pic_comment_id, pic_comment_user, null, { title: true, classname: 'note-obj-ins-font-blue-color', }); } for (let pic_comment_at of article.querySelectorAll(selector.dialog.comment_at)) { if (!pic_comment_at.classList.contains(selector.homepage.comment_id.replace(/^\.|\s+.*$/g, ''))) { let pic_comment_at_id = Note_Obj.fn.getUserIdFromLink(pic_comment_at.href); (!user_id || user_id == pic_comment_at_id) && note_obj.handler(pic_comment_at_id, pic_comment_at, null, { symbol: { prefix: '@', }, title: true, classname: 'note-obj-ins-font-blue-color', }); } } } for (let homepage_stories of document.querySelectorAll(selector.homepage_stories.id_shell)) { if (homepage_stories.querySelector(selector.homepage_stories.id)) { let homepage_stories_id = homepage_stories.querySelector(selector.homepage_stories.id).textContent; if (!user_id || user_id == homepage_stories_id) { homepage_stories.title = note_obj.getUserTag(homepage_stories_id); } } } for (let homepage_recommend of document.querySelectorAll(selector.homepage_recommend.id)) { let homepage_recommend_id = Note_Obj.fn.getUserIdFromLink(homepage_recommend.href); (!user_id || user_id == homepage_recommend_id) && note_obj.handler(homepage_recommend_id, homepage_recommend, null, { classname: 'note-obj-ins-font-blue-color', }); } for (let user_page of document.querySelectorAll(selector.user_page.frame)) { if (user_page.querySelector(selector.user_page.id)) { let user_page_id = user_page.querySelector(selector.user_page.id).textContent; if (!user_id || user_id == user_page_id) { let user_page_tag = user_page.querySelector('.note-obj-user-tag'); user_page_tag && user_page_tag.remove(); note_obj.judgeUsers(user_page_id) && user_page.querySelector(selector.user_page.box).after( note_obj.createNoteTag( user_page_id, { secondaryColor: false, offsetWidth: -20, }, 'div', ['note-obj-ins-userpage-tag', 'note-obj-ins-font-blue-color', 'note-obj-ins-font-bold'] ) ); } } for (let common_user of user_page.querySelectorAll(selector.user_page.common)) { let common_user_id = common_user.textContent; if (!user_id || user_id == common_user_id) { if (note_obj.judgeUsers(common_user_id)) { common_user.title = note_obj.getUserTag(common_user_id); if (note_obj.getShowNoteColorConfig()) { common_user.style.setProperty('color', note_obj.getPrimaryColor(common_user_id), 'important'); } else { common_user.style.setProperty('color', ''); } common_user.classList.add('note-obj-ins-font-blue-color'); } else { (common_user.title = ''), common_user.style.setProperty('color', ''); common_user.classList.remove('note-obj-ins-font-blue-color'); } } } for (let info_at_user of user_page.querySelectorAll(selector.user_page.info_at)) { let info_at_user_id = Note_Obj.fn.getUserIdFromLink(info_at_user.href); (!user_id || user_id == info_at_user_id) && note_obj.handler(info_at_user_id, info_at_user, null, { symbol: { prefix: '@', }, classname: 'note-obj-ins-font-blue-color', title: true, }); } } for (let initial of document.querySelectorAll(selector.watch_list.initial_item)) { let initial_item = initial.querySelector(selector.watch_list.id); if (initial_item) { let initial_item_id = Note_Obj.fn.getUserIdFromLink(initial_item.href); (!user_id || user_id == initial_item_id) && note_obj.handler(initial_item_id, initial_item, null, { classname: 'note-obj-ins-font-blue-color', }); } } for (let later of document.querySelectorAll(selector.watch_list.later_item)) { let later_item = later.querySelector(selector.watch_list.id); if (later_item) { let later_item_id = Note_Obj.fn.getUserIdFromLink(later_item.href); (!user_id || user_id == later_item_id) && note_obj.handler(later_item_id, later_item, null, { classname: 'note-obj-ins-font-blue-color', }); } } for (let dialog of document.querySelectorAll(selector.dialog.frame)) { let dialog_a = dialog.querySelector(selector.homepage.id); if (dialog_a) { let dialog_a_id = Note_Obj.fn.getUserIdFromLink(dialog_a.href); (!user_id || user_id == dialog_a_id) && note_obj.handler(dialog_a_id, dialog_a, null, { title: true, classname: 'note-obj-ins-font-blue-color', }); } for (let like of dialog.querySelectorAll(selector.homepage.comment_id)) { let like_id = Note_Obj.fn.getUserIdFromLink(like.href); (!user_id || user_id == like_id) && note_obj.judgeUsers(like_id) && note_obj.handler(like_id, like, null, { classname: 'note-obj-ins-font-blue-color', }); } for (let comment_user of dialog.querySelectorAll(selector.dialog.comment_id)) { let comment_id = Note_Obj.fn.getUserIdFromLink(comment_user.href); (!user_id || user_id == comment_id) && note_obj.handler(comment_id, comment_user, null, { classname: 'note-obj-ins-font-blue-color', title: true, }); } for (let comment_at of dialog.querySelectorAll(selector.dialog.comment_at)) { let comment_at_id = Note_Obj.fn.getUserIdFromLink(comment_at.href); (!user_id || user_id == comment_at_id) && note_obj.handler(comment_at_id, comment_at, null, { symbol: { prefix: '@', }, classname: 'note-obj-ins-font-blue-color', title: true, }); } } for (let follow of document.querySelectorAll(selector.request.follow)) { let follow_user_id = Note_Obj.fn.getUserIdFromLink(follow.href); (!user_id || user_id == follow_user_id) && note_obj.handler(follow_user_id, follow, null, { classname: 'note-obj-ins-font-blue-color', }); } for (let suggest_user of document.querySelectorAll(selector.suggest.user)) { let suggest_user_id = Note_Obj.fn.getUserIdFromLink(suggest_user.href); (!user_id || user_id == suggest_user_id) && note_obj.handler(suggest_user_id, suggest_user, null, { classname: 'note-obj-ins-font-blue-color', }); } for (let suggest of document.querySelectorAll(selector.user_page.suggest)) { let suggest_user_id = Note_Obj.fn.getUserIdFromLink(suggest.href); (!user_id || user_id == suggest_user_id) && note_obj.handler(suggest_user_id, suggest, null, { classname: 'note-obj-ins-font-blue-color', }); } } function instagram_Homepage_Event(newValue, oldValue) { if (newValue != oldValue) { for (let article of document.querySelectorAll(selector.homepage.article)) { let article_user = article.querySelector(selector.homepage.id); if (article_user) { let article_user_id = Note_Obj.fn.getUserIdFromLink(article_user.href); note_obj.handler(article_user_id, article_user, null, { add: oldValue ? null : 'span', classname: oldValue ? 'note-obj-ins-font-blue-color' : 'note-obj-ins-background-box', title: oldValue, restore: true, }); note_obj.handler(article_user_id, article_user, null, { add: newValue ? null : 'span', classname: newValue ? 'note-obj-ins-font-blue-color' : 'note-obj-ins-background-box', title: newValue, }); } } } } function init_Instagram(note_obj) { let arrive_option = { fireOnAttributesModification: true, existing: true, }; Note_Obj.fn.isMobilePage() && document.body.arrive(selector.mobile.bottom_bar, arrive_option, item => item.appendChild(note_obj.createSearchButton('note-obj-ins-mobile-search-button')) ); document.body.arrive(selector.homepage.article, arrive_option, article => { let article_user = article.querySelector(selector.homepage.id); if (article_user) { let article_user_id = Note_Obj.fn.getUserIdFromLink(article_user.href); note_obj.judgeUsers(article_user_id) && note_obj.handler(article_user_id, article_user, null, { add: note_obj.getConfig().other.replaceHomepageID ? null : 'span', classname: note_obj.getConfig().other.replaceHomepageID ? 'note-obj-ins-font-blue-color' : 'note-obj-ins-background-box', title: note_obj.getConfig().other.replaceHomepageID, }); article.querySelector(selector.homepage.icon) && article .querySelector(selector.homepage.icon) .insertAdjacentElement( 'beforebegin', note_obj.createNoteBtn(article_user_id, null, ['note-obj-ins-add-btn', 'note-obj-ins-homepage-btn'], 'span') ); } for (let comment of article.querySelectorAll(selector.homepage.comment_id)) { let comment_id = Note_Obj.fn.getUserIdFromLink(comment.href); note_obj.judgeUsers(comment_id) && note_obj.handler(comment_id, comment, null, { classname: 'note-obj-ins-font-blue-color', }); } article.arrive(selector.homepage.comment_at, arrive_option, comment_at => { let comment_at_id = Note_Obj.fn.getUserIdFromLink(comment_at.href); note_obj.judgeUsers(comment_at_id) && note_obj.handler(comment_at_id, comment_at, null, { symbol: { prefix: '@', }, title: true, classname: 'note-obj-ins-font-blue-color', }); }); article.arrive(selector.dialog.comment_id, arrive_option, pic_comment_user => { let pic_comment_id = Note_Obj.fn.getUserIdFromLink(pic_comment_user.href); note_obj.judgeUsers(pic_comment_id) && note_obj.handler(pic_comment_id, pic_comment_user, null, { title: true, classname: 'note-obj-ins-font-blue-color', }); }); article.arrive(selector.dialog.comment_at, arrive_option, pic_comment_at => { if (!pic_comment_at.classList.contains(selector.homepage.comment_id.replace(/^\.|\s+.*$/g, ''))) { let pic_comment_at_id = Note_Obj.fn.getUserIdFromLink(pic_comment_at.href); note_obj.judgeUsers(pic_comment_at_id) && note_obj.handler(pic_comment_at_id, pic_comment_at, null, { symbol: { prefix: '@', }, title: true, classname: 'note-obj-ins-font-blue-color', }); } }); }); document.body.arrive(selector.homepage_stories.id_shell, arrive_option, homepage_stories => { if (homepage_stories.querySelector(selector.homepage_stories.id)) { let homepage_stories_id = homepage_stories.querySelector(selector.homepage_stories.id).textContent; if (note_obj.judgeUsers(homepage_stories_id)) { homepage_stories.title = note_obj.getUserTag(homepage_stories_id); } } }); document.body.arrive(selector.homepage_recommend.id, arrive_option, homepage_recommend => { let homepage_recommend_id = Note_Obj.fn.getUserIdFromLink(homepage_recommend.href); note_obj.judgeUsers(homepage_recommend_id) && note_obj.handler(homepage_recommend_id, homepage_recommend, null, { classname: 'note-obj-ins-font-blue-color', }); }); document.body.arrive(selector.user_page.frame, arrive_option, user_page => { if (user_page.querySelector(selector.user_page.id)) { let user_page_id = user_page.querySelector(selector.user_page.id).textContent; let user_name = user_page.querySelector(selector.user_page.user_name); let user_name_text = ''; if (user_name) { user_name_text = user_page.querySelector(selector.user_page.user_name).textContent; } user_page.querySelector(selector.user_page.bar) && user_page .querySelector(selector.user_page.bar) .after(note_obj.createNoteBtn(user_page_id, user_name_text, ['note-obj-ins-add-btn', 'note-obj-ins-userpage-btn'])); note_obj.judgeUsers(user_page_id) && user_page.querySelector(selector.user_page.box).after( note_obj.createNoteTag( user_page_id, { secondaryColor: false, offsetWidth: -20, }, 'div', ['note-obj-ins-userpage-tag', 'note-obj-ins-font-blue-color', 'note-obj-ins-font-bold'], user_name_text ) ); } for (let common_user of user_page.querySelectorAll(selector.user_page.common)) { let common_user_id = common_user.textContent; if (note_obj.judgeUsers(common_user_id)) { common_user.title = note_obj.getUserTag(common_user_id); note_obj.getShowNoteColorConfig() && common_user.style.setProperty('color', note_obj.getPrimaryColor(common_user_id), 'important'); common_user.classList.add('note-obj-ins-font-blue-color'); } } for (let info_at_user of user_page.querySelectorAll(selector.user_page.info_at)) { let info_at_user_id = Note_Obj.fn.getUserIdFromLink(info_at_user.href); note_obj.judgeUsers(info_at_user_id) && note_obj.handler(info_at_user_id, info_at_user, null, { symbol: { prefix: '@', }, classname: 'note-obj-ins-font-blue-color', title: true, }); } }); document.querySelector(selector.body).arrive(selector.watch_list.initial_item, arrive_option, initial => { let initial_item = initial.querySelector(selector.watch_list.id); if (initial_item) { let initial_item_id = Note_Obj.fn.getUserIdFromLink(initial_item.href); note_obj.judgeUsers(initial_item_id) && note_obj.handler(initial_item_id, initial_item, null, { classname: 'note-obj-ins-font-blue-color', }); } }); document.querySelector(selector.body).arrive(selector.watch_list.later_item, arrive_option, later => { let later_item = later.querySelector(selector.watch_list.id); if (later_item) { let later_item_id = Note_Obj.fn.getUserIdFromLink(later_item.href); note_obj.judgeUsers(later_item_id) && note_obj.handler(later_item_id, later_item, null, { classname: 'note-obj-ins-font-blue-color', }); } }); document.querySelector(selector.body).arrive(selector.dialog.frame, arrive_option, dialog => { let dialog_a = dialog.querySelector(selector.homepage.id); if (dialog_a) { let dialog_a_id = Note_Obj.fn.getUserIdFromLink(dialog_a.href); note_obj.judgeUsers(dialog_a_id) && note_obj.handler(dialog_a_id, dialog_a, null, { title: true, classname: 'note-obj-ins-font-blue-color', }); dialog.querySelector(selector.homepage.icon) && dialog .querySelector(selector.homepage.icon) .insertAdjacentElement( 'beforebegin', note_obj.createNoteBtn(dialog_a_id, null, ['note-obj-ins-add-btn', 'note-obj-ins-homepage-btn'], 'span') ); } for (let like of dialog.querySelectorAll(selector.homepage.comment_id)) { let like_id = Note_Obj.fn.getUserIdFromLink(like.href); note_obj.judgeUsers(like_id) && note_obj.handler(like_id, like, null, { classname: 'note-obj-ins-font-blue-color', }); } dialog.arrive(selector.dialog.comment_id, arrive_option, comment_user => { let comment_id = Note_Obj.fn.getUserIdFromLink(comment_user.href); note_obj.judgeUsers(comment_id) && note_obj.handler(comment_id, comment_user, null, { classname: 'note-obj-ins-font-blue-color', title: true, }); }); dialog.arrive(selector.dialog.comment_at, arrive_option, comment_at => { let comment_at_id = Note_Obj.fn.getUserIdFromLink(comment_at.href); note_obj.judgeUsers(comment_at_id) && note_obj.handler(comment_at_id, comment_at, null, { symbol: { prefix: '@', }, classname: 'note-obj-ins-font-blue-color', title: true, }); }); }); document.body.arrive(selector.request.follow, arrive_option, follow => { let follow_user_id = Note_Obj.fn.getUserIdFromLink(follow.href); note_obj.judgeUsers(follow_user_id) && note_obj.handler(follow_user_id, follow, null, { classname: 'note-obj-ins-font-blue-color', }); }); document.body.arrive(selector.suggest.user, arrive_option, suggest_user => { let suggest_user_id = Note_Obj.fn.getUserIdFromLink(suggest_user.href); note_obj.judgeUsers(suggest_user_id) && note_obj.handler(suggest_user_id, suggest_user, null, { classname: 'note-obj-ins-font-blue-color', }); }); document.body.arrive(selector.user_page.suggest, arrive_option, suggest => { let suggest_user_id = Note_Obj.fn.getUserIdFromLink(suggest.href); note_obj.judgeUsers(suggest_user_id) && note_obj.handler(suggest_user_id, suggest, null, { classname: 'note-obj-ins-font-blue-color', }); }); } let note_obj = new Note_Obj('myInstagramNote'); await note_obj.init({ style: INS_STYLE, changeEvent: instagram_Change_Event, script: { author: { name: 'pana', homepage: 'https://greasyfork.org/zh-CN/users/193133-pana', }, address: 'https://greasyfork.org/scripts/387871', updated: updated, library: [ { name: 'arrive.js', version: '2.4.1', url: 'https://github.com/uzairfarooq/arrive', }, ], }, primaryColor: '#336699', settings: { replaceHomepageID: { type: 'checkbox', lang: { en: 'Allow to replace the user ID on the instagram homepage', zh_cn: '允许替换 Instagram 首页上的用户 ID', zh_tw: '允許替換 Instagram 首頁上的用戶 ID', ja: 'Instagram ホームページのユーザーIDの置き換えを許可する', ko: 'Instagram 첫 페이지에 있는 사용자 ID 바꾸기 허용', fr: "Permettre de remplacer l'ID utilisateur sur la page d'accueil Instagram", }, default: true, event: instagram_Homepage_Event, }, }, }); init_Instagram(note_obj); })();