Instagram - 为用户添加备注(别名/标签)

为用户添加备注(别名/标签)功能,以帮助识别和搜索

目前为 2022-06-02 提交的版本。查看 最新版本

// ==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://gf.qytechs.cn/zh-CN/users/193133-pana
// @homepage            https://gf.qytechs.cn/zh-CN/users/193133-pana
// @icon                
// @version             5.3.8
// @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/[email protected]/minified/arrive.min.js
// @require             https://cdn.jsdelivr.net/npm/[email protected]/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
// ==/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;
        }
        .note-obj-ins-left-box {
          height: 25%;
        }
    `;
  var selector = {
    body: 'body',
    homepage: {
      article: 'article',
      id: '._aaqt a',
      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',
    },
    stories: {
      id: 'a.notranslate',
      id_shell: '._ac0q',
    },
    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 stories_shell of document.querySelectorAll(selector.stories.id_shell)) {
      let stories = stories_shell.querySelector(selector.stories.id);
      if (stories) {
        let stories_user_id = Note_Obj.fn.getUserIdFromLink(stories.href);
        (!user_id || user_id == stories_user_id) &&
          note_obj.handler(stories_user_id, stories, null, {
            classname: 'note-obj-ins-font-blue-color',
          });
      }
    }
    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.body.arrive(selector.stories.id_shell, arrive_option, stories_shell => {
      let stories = stories_shell.querySelector(selector.stories.id);
      if (stories) {
        let stories_user_id = Note_Obj.fn.getUserIdFromLink(stories.href);
        note_obj.judgeUsers(stories_user_id) &&
          note_obj.handler(stories_user_id, stories, null, {
            classname: 'note-obj-ins-font-blue-color',
          });
      }
    });
    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://gf.qytechs.cn/zh-CN/users/193133-pana',
      },
      address: 'https://gf.qytechs.cn/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,
      },
    },
    leftBtnBoxClassName: 'note-obj-ins-left-box',
  });
  init_Instagram(note_obj);
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址