0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

常に最新ツイートが一番上に来るChrome Extensionを作るためにいろいろやったけど手動でやった方が早いなってなった話

Posted at

完成図

完成動画

トップツイート順なら最新ツイート順に並べなおします。

私たちのTwitterを取り戻すために

トップツイート

なぜ?
Twitterはなぜトップツイートという概念を生み出したのか。

私はTwitterを情報垂れ流しツールという場として見ています。

フォーマルではなくフランクで、誰もとりつくろわず、みんながバカ騒ぎして楽しむ。そんな場だと思っていました。
私はTwitterが大好きでした。

Twitterはいつまでも変わらず、そばで僕を見てくれていると思っていました。

でも facebook が気になるのか、Twitterはもう私のそばで笑っていません。

最新ツイート

毎回手動で最新ツイート順に直しています。

データベースで持っていないのか、少しすると「トップツイート」に戻っています。

毎回手動で「最新ツイート」をクリックして戻すのがいやなので、Chromeエクステンションを作ります。

準備

Chrome Extensionを作るのには準備がいるのでひな型を作ってもらいます。

TypeScriptで簡単にChrome Extensionを作る方法

windowsだと簡単に動かないかな~~と思っていましたが、問題なかったです。

ひながたを作っていると

Would you like more UI Features?

みたいに聞かれます。何をするExtensionを作るか、を選択できます。

試しなので全部潜影蛇手すればいいんですが、最低限いるのは Content Scripts です。

windowsだと yarn を入れる必要があったりしますが、なかったら入れる でどうにかなりました。


とりあえずいい感じにぶち込んだら

$ yarn install

このとき「もしかして別に npm install でも大丈夫だったんじゃないか」と思いましたが、試していないのでわかりません。
すべてが入ったら

$ yarn run dev:chrome

を実行します。あとは
dist/chrome をエクステンションとして Chrome にぶち込みます。

chrome://extensions/ にアクセスしてパッケージ化されていない拡張機能を読み込みます。
パッケージ化されていない拡張機能を読み込む

上記画像の「パッケージ化されていない拡張機能を読み込む」から dist 以下の chrome を読み込みます。

開発ツールからコンソールを見ると成功していればなんか出ていると思います。 app\scripts\contentscript.tsconsole.log に対応しています。

くるっと更新

ちょっとはまったこととしては上記実行は hotreload みたいな感じで修正すれば動くんですけど contentscript に関しては画像の矢印(更新ボタン)を押さないと変更が反映されません。

コードを書いていく

とりあえず潜影蛇手

contentscript.ts
window.addEventListener("load", Main);

function Main():void {
  let event = document.createEvent( 'MouseEvents' );
  setTimeout(() => {
    const top_tweet_label = document.querySelector('[aria-label="トップツイートがオフになります"]');
    const home_tweet_label = document.querySelector('[aria-label="トップツイートがオンになります"]');
    let timeline_change_star = home_tweet_label === null ? top_tweet_label : home_tweet_label;
    event.initEvent("click", true, true);
    if(timeline_change_star !== null){
      timeline_change_star.dispatchEvent(event);
      setTimeout(() => {
        let button_change_timeline_change = document.querySelector('[role="menu"] [role="menuitem"]');
        event.initEvent("click", true, true);
        if(button_change_timeline_change !== null){
          button_change_timeline_change.dispatchEvent(event);
        }
      }, 500);
    }
  }, 4000);

このコードだと起動のたびに最新ツイートとトップツイートを入れ替えます。

はまったところ

二回マウスイベントを発火させないといけない

一回目の星クリックで 「ホーム」ではトップツイートが優先的に表示されます というのが出て、その下の「最新ツイート表示に切り替える」で実際に切り替えられます。

画面ロード時と全体描画のタイミングが違う

よくあることなんですかね…。
とりあえず

window.addEventListener("load", Main);

ってしたらよしなに読み込んでくれると思ったのですが、実際はちょっとずらしているっぽいです。 React の動作なのかな。 とりあえず setTimeout で4秒後に実行にします。 だいたい3.5秒くらいで(私の環境では)ロードされました。 これはネットワークなどによって異なるため、ほんまは繰り返して成功したタイミングで!!とかやりたかったんですけど、無限ループでブラウザ落ちて(正確には閉じることすらできなくなった)だめだったので、暫定対応です。

画面ロード完了後に読み込まれるメソッドは?

window.addEventListener("load", Main);

いつも jQuery 使っていたので知らなかったです。

タイムラインを並び順を変更するボタンをどうやって取得する?

Class は難読化のためか、まったく規則性がなくて使えない。
id もけっこう上にしかついていなくて、取得できない。
諦めかけていたのですが、「トップツイートがオフになります」「トップツイートがオンになります」これだけは不変であるようでした。これを取得することに

document.querySelector('[aria-label="トップツイートがオフになります"]');

いつも jQuery 使っていたので querySelector 初めて使いました

このボタンを押せばタイムラインを変更できるボタンが画面に出てきます。

マウスイベントをどうやって発火させる?(そもそもマウスイベントでやるべきなのか、まだ検討中です)

ここも地味にはまりました。検索かけても取得する方法で発火させる方法は全然出てこない。

document.createEvent( 'MouseEvents' );

マウスイベントを作った?上で

event.initEvent("click", true, true);

クリックイベントを登録?して(すみません、残り二つの引数の意味わかっていないです。最初動かなくて適当に入れたら動きました…)

timeline_change_star.dispatchEvent(event);

実際に発火させます。

ディスパァァァッチ!!

タイムラインを切り変えるためのボタンはどう押す?

これも地味にはまりました。 idclass もあてにならないので。

document.querySelector('[role="menu"] [role="menuitem"]');

こんな実装に…。

initEvent 二回する意味ある?

今検討中です。

結論

動作の読み込み待ったり面倒なので拡張はやめました。
今は手動でやっています。

所感

作るのは楽しかったです。
Twitterは普通に created_at でタイムラインを並べてほしいと切に願ってやみません。

facebookとはりあわなくていいのです。

落書き

Twitter始めてからもう十年になります。オフ会もたくさんしました。
私も学生、周りもわいわい楽しんでいました。

みな社会人になり、社会の波にのまれみんなのツイートは減っていきました。
うつ病になった友人もいます。

タイムラインは活気がなくなり、ネガティブな言葉が増えてきます。
くだらないやり取りは減り、1日100ツイートしていた人はいい企業に入ってライブなどに行き、愚痴をこぼしながらも楽しそうです。

結婚した人もいます。
周りのフォロワーのフォロワーくらいの人が次々と結婚していきます。

一方、出会いがないと嘆き、合コンや彼女が欲しいというツイートも増えました。

良いとか悪いとかではないのです。
単純に私のいたタイムラインはもうそこにはありません。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?