記録配列構成の変更
「Snap」のデータ記録は「多次元配列」を利用しています。 ひとつの記事に関して「記事ID」「投稿形式」のデータを配列にして、これが記事の数だけ集まった「配列」の形です。 この様な形式の「配列」は、後でデータを検索したり、ソートするのに適しています。下は、実際の配列のサンプルで [記事ID, 投稿形式]の組が[雛形, 記事1, ~ , 記事4]の5個集まっています。
これまでの「Every Page Map 💢」はこれとは別の配列に、「年」「月」「投稿形式の数」のデータを、やはり多次元配列で格納して、マップ表示に使っていました。
下は、そのサンプルです。
しかし、投稿形式のカウントは、あまり程度の良くない方式を使っていました。 ある月のカウントが複数ページに渡る場合、配列に更新で格納すると最後のページの値だけが格納されてしまうので、同月のカウントがある場合は更新ではなく合算して更新する必要があります。 この方法は、同じ範囲を重複して調査すると、2倍の値になってしまいます。
つまり、ブログの最初から末尾まで一気に調査する場合は良いのですが、部分的に調査して、飛んだ場所でまた調査するといった使い方をすると、誤カウントの場所が出来てきます。
これを防ぐには、カウント方法を根本的に改める必要があります。 方法は以下。
①「記事ID」「投稿形式」「投稿年月」の3個のデータを配列にして、これを記事の数だけ集めた「配列」の形式に母データを収納する。
➁ ①の配列に、常に「記事ID」の重複を排除しながらデータを格納して行く。
➂ 母データから調査中の「年月」と同じ「投稿年月」の値のデータのみ抽出し、その中の「投稿形式」の内訳をカウントする。
④ ➂のカウント値を、常にマップ用の配列に記録し、更新を続ける。
説明が下手で複雑に見えますが、実際はそうでもありません。➁の処理があるので、ある個所を重複調査を行っても、最新データに更新されるだけで、カウント値の誤算が生じません。 これは、複数ページの渡る月でも、そうでない月も同じです。
配列とカウント方法を改めた事で、一部の期間のみの調査、調査期間の継ぎ足し、調査期間の後戻りをしても、調査した範囲は正確にカウントされる様になりました。
配列を全てセッションストレージに記録
「Snap」データは、「投稿形式」を保存しておくという目的から、ユーザーが意図しないでも保存が継続するローカルストレージを、配列の記録場所にしていました。 これまでの「Every Page Map 💢」は、そのままのコードを受け継いだのですが、データの保存に余り拘る必要は無いと考えました。 一応、マップをファイル化して保存できますが、余禄の機能といった位置付けです。
という事から、セッションを終了すれば(ウインドウを閉じれば)自動的に消滅するセッションストレージに配列を記録する方式に改めました。 上記の様に、母データ用の配列と、そこから月単位の投稿形式をカウントしたマップ用の配列の2個です。 ファイル化して保存できるのは後者だけです。
調査の一旦停止操作を改善
色々とテストをしていて、調査の速度が早過ぎて、却って一部の調査だけで済ますといった目的には使い難いと感じました。 自動スキャンの進行を止めるのが止め難く、以前から色々と工夫して来たのですが、今回はスキャン速度を少し落とす事と、キー操作を採り入れました。
●「Ctrl」キーを押下すると、スキャン停止する。
● コンソール上の「MAPの調査を停止 ❚❚」のボタンをクリックすると停止する。
この2種の停止方法に変えています。 特に「Ctrl」キーは思い通りに停止がし易く、マウス操作よりも良いと思います。 Click操作は、慌てて2回のクリックになって、再び進めてしまう事が無い様に、コードを工夫しています。
この様にしても、「止まらない」「次の月で停止する」といった事が時々あります。 これは操作タイミングか関係し、スピードを落とすと安定しますが、今度は調査時間が長くなりますから。
今回の設定は、少しだけ速度を落としましたが、計測をすると「記事の編集・削除」の1ページが 3.5secでした。 毎日書く人は 2ページ/月として、1年分が 1分30秒程度の速度で調査が進みます。
画面のデザインとインターフェイスを変更
下は、一旦停止をした時のコンソールの背景色ですが、赤枠の「通常表示⏏」のボタンを作りました。 このボタンを押すと、本来の「記事の編集・削除」の表示に戻るので、「ブログ管理画面」や「ブログページ」に移動できます。
また、下部に表示される「記事リスト」のデザインを、「Ameblo Management」のデザインと共通にしました。「編集」「複製」「削除」のボタンが使え、マップ表示下で記事の処理が出来るので、こちらの方が都合が良いと思います。
▪ 調査をしたウインドウ(ウインドウタブ)を閉じない限り、調査データは残っているので、「通常表示」→「HOME」等へ移動しても、再び「記事の編集・削除」を開くと、マップを参照できます。
▪「通常表示」にしても「Every Page Map 💢」を「OFF」にしていなければ、ページをリロードするとコンソールの表示に戻ります。
「Every Page Map 💢」 利用上のご注意
これは「非常駐型」のツールです。 このツールを「Tampermonkey」上で「ON」にすると、「記事の編集・削除」の通常のデザインと操作を一部変更します。
この事により、ブログの各種操作で間違いを生じない様に、マップ関連の作業が終了した後は、忘れずに「Every Page Map 💢」を「OFF」にしてください。
▪ ツールの「ON/OFF」は「Tampermonkey」のダッシュボードで行うと確実です。
「Every Page Map 💢」は、そう複雑な操作を必要としませんが、扱い方については、以下のページを参照ください。
「Every Page Map 💢」を利用するには
このツールは Chrome / Edge / Firefox版の拡張機能「Tampermonkey」上で動作します。 以下に、このツールの導入手順を簡単に説明します。
❶「Tampermonkey」を導入します
◎ 使用しているブラウザに拡張機能「Tampermonkey」を導入する事が必要です。
既に「Tampermonkey」を導入している場合は、この手順 ❶ は不要です。
拡張機能の導入については、以下のページに簡単な説明があるので参照ください。
❷「Tampermonkey」にスクリプトを登録します
◎「Tampermonkey」の「+」マークの「新規スクリプト」タブを開きます。
◎「新規スクリプト」には、最初からテンプレートが記入されています。 これは全て削除して、完全に空白の編集枠に 下のコードをコピー&ペーストします。
〔コピー方法〕 軽量シンプルなツール「PreBox Button 」を使うと
コード枠内を「Ctrl+左Click」➔「Copy code 」を「左Click」
の操作で、掲載コードのコピーが可能になります。
◎ 最後に「ファイル」メニューの「保存」を押すと、ツールが使用可能になります。
〔 Every Page Map 💢 〕 ver. 2.7
// ==UserScript== // @name Every Page Map 💢 // @namespace http://tampermonkey.net/ // @version 2.7 // @description 「記事の編集・削除」ページで全記事の「公開設定」を記録する // @author Ameba Blog User // @match https://blog.ameba.jp/ucs/entry/srventrylist* // @run-at document-start // ==/UserScript== let retry=0; let interval=setInterval(wait_target, 1); function wait_target(){ retry++; if(retry>100){ // リトライ制限 100回 0.1secまで clearInterval(interval); } let target=document.documentElement; // 監視 target if(target){ clearInterval(interval); style_in(); }} function style_in(){ let style= '<style id="EPS">'+ 'html { overflow-y: overlay !important }'+ '#globalHeader, #ucsHeader, #ucsMainLeft h1, .l-ucs-sidemenu-area, #ucsMainRight,'+ '.selection-bar, #footerAd, #globalFooter, .checkboxAllControl { display: none }'+ '#ucsContent{ width: 840px; background: #fff; box-shadow: 0 0 0 100vh #c5d8e1 }'+ '#ucsMain{ background: #fff } #ucsMainLeft { width: 810px; float: none }'+ '#entryYear { margin: 0 5px; }'+ '#entryMonth { font-size: 14px; overflow: visible; margin-top: 3px }'+ '#entryMonth li, #entryMonth #nowMonthLi { font-weight: bold; padding: 2px 10px 0; }'+ '#entryMonth li a:visited { color: #3970B5; }'+ '#nowMonth { padding: 1px 6px 0; border: none; border-radius: 1px; '+ 'color: #000; box-shadow: 0 0 0 2px #0066cc; }'+ '#entryListEdit form { display: flex; flex-direction: column } #entrySort { order: -2 }'+ '.pagingArea { order: -1; padding: 4px; margin-bottom: -33px; background: #ddedf3 !important }'+ '.pagingArea a { border: 1px solid #888 } .pagingArea .active{ border: 2px solid #0066cc }'+ '.pagingArea a, .pagingArea .active, .pagingArea .disabled { font-size: 14px; line-height: 23px }'+ '#sorting { margin: 38px 0 4px; padding: 4px 10px; height: 110px; '+ 'font: 14px Meiryo; background: #ddedf3 }'+ '#sorting .pagingArea, #sorting select, #sorting ul { display: none }'+ 'input { font-family: meiryo; font-size: 14px }'+ '#entryList .entry-item { padding: 6px 5px 2px; }'+ '#entryList li:hover{ background-color: #e2eef0 }'+ '#entryList .leftCol, #entryList .titleCol h2{ width: 560px; }'+ '#entryList .leftCol a { text-decoration: none !important; color: #3970b5 !important; }'+ '#entryList dl { font-size: 13px; padding-left: 20px; }'+ '#entryList dl.reactions { margin: -19px 0 -2px 360px; }'+ '#entryList dd { margin-right: 8px; }'+ '#entryList .rightCol { width: 250px; min-width: unset; margin: -2px 0 0 0; }'+ '#entryList .txtCol{ white-space: nowrap; font-size: 13px; margin-bottom: 2px; line-height: 16px }'+ '#entryList .status-text { display: inline-block; width: 64px; padding: 2px 4px 0; overflow: hidden; '+ 'margin-bottom: -4px; font-weight: normal; color: #000; }'+ '#entryList .txtCol .date{ display: inline-block; padding: 2px 4px 0; font-size: 13px; color: #000; }'+ '#entryList .status-text { display: inline-block; font-weight: normal; color: #000; '+ 'width: 64px; padding: 2px 4px 0; overflow: hidden; margin-bottom: -4px; }'+ '#entryList ul input[value="1"] + input + li .txtCol span:first-child{ display: inline-block;'+ 'text-indent: 12px; color: #fff; background: #2196f3 !important }'+ '#entryList ul input[value="2"] + input + li .txtCol span:first-child{ display: inline-block;'+ 'text-indent: 2px; color: #fff; background: #009688 !important }'+ '#entryList .deleteCol { margin-bottom: 0; }'+ '#entryList .deleteCol a { padding: 2px 5px 0; font-size: 14px; text-decoration: none !important; '+ 'border: 1px solid #aaa; border-radius: 4px; background: linear-gradient(0deg, #eee, #fff); }'+ '#entryList .deleteCol a:hover { outline: auto #1976d2; }'+ '#entryList .deleteCol .process + .process, #entryList dd + dd { margin-left: 10px; }'+ '#entryList .deleteCol .process svg { width: 16px; height: 16px; }'+ '#div0 { color: #333; margin: 10px -10px 0 15px; }'+ '#div1 { color: #000; margin: 8px 15px; border: 1px solid #888; background: #fafcfd; }'+ '#list_snap { padding: 2px 0 0; margin: 7px 40px 7px 0; width: 210px; }'+ '#reset { padding: 2px 0 0; margin-right: 20px; width: 60px; }'+ '#export { padding: 2px 0 0; margin: 7px 10px 7px 0; width: 150px; }'+ '#import_sw { padding: 2px 0 0; margin: 7px 10px 7px 0; width: 115px; }'+ '#import_result { display: inline-flex; padding: 2px 0 0; margin: 7px 0; width: 160px; '+ 'overflow: hidden; white-space: nowrap; }'+ '#import { display: none; }'+ '#snap_result { display: inline-block; margin: 6px 12px 4px; }'+ '#entryYear { width: 120px !important; } '+ '#entryMonth li, #entryMonth #nowMonthLi { padding: 2px 0 0 !important; width: 54px; } '+ '.div_add { display: flex; flex-direction: row; justify-content: space-evenly; width: 758px; '+ 'margin: 8px 15px; padding: 4px 0; border: 1px solid #777; background: #fafcfd; } '+ '.m.y_index { width: 80px; font-size: 18px; text-align: center; } '+ '.m.y_index p { border: none !important; } '+ '.m { display: flex; flex-direction: column; font: bold 14px Meiryo; width: 50px; text-align: right; } '+ '.m:hover { outline: 1px solid #2196f3; outline-offset: -1px; cursor: pointer; } '+ '.mt { font-size: 13px; color: #3970bc; padding: 4px 0 0 !important; height: 22px; '+ 'margin-bottom: 3px; text-align: center; border: none !important; } '+ '.m p { padding: 0 10px; margin-top: -1px; border: 1px solid #ccc; } '+ '#amb_menu { float: right; padding: 2px 4px 0; margin: 2px 4px 3px -20px; cursor: pointer; } '+ 'input[value="entry_ym=100001"] + #entrySort { visibility: hidden; } '+ '</style>'; if(!document.querySelector('#EPS')){ document.documentElement.insertAdjacentHTML('beforeend', style); } } // style_in() window.addEventListener('load', function(){ let drive_mode; let blogDB={}; // 記事ID 投稿フラグ 投稿年月 の配列 let entry_id_DB; // ID検索用の配列 let entry_id; let publish_f; let entry_date; let pub_all; let pub_dra; let pub_ame; let ua=0; let agent=window.navigator.userAgent.toLowerCase(); if(agent.indexOf('firefox') > -1){ ua=1; } // Firefoxの場合のフラグ let read_json=sessionStorage.getItem('blogDB_back'); // ストレージ 保存名 blogDB=JSON.parse(read_json); if(blogDB==null){ blogDB=[['00000000000', 's', 0]]; } // 記事ID, 投稿フラグ, 投稿年月 6桁 let year; // 現在開いているページの年度 let month; // 現在開いているページの月 let year_index; // 現在のページの年度を記録する MAPのindex let disp_year=document.querySelector('#year'); year= parseInt(disp_year.textContent, 10); let disp_month=document.querySelector('#nowMonth'); month=parseInt(disp_month.textContent.replace(/[^0-9]/g, ''),10); let blogMAP={}; // 公開情報の件数データMAP let read_map_json=sessionStorage.getItem('blogMAP_back'); // セッションストレージ 保存名 blogMAP=JSON.parse(read_map_json); if(blogMAP==null){ blogMAP=[[['blog_map', 1000, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0], [0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0]]]; } year_index=-1; for(let k=0; k<blogMAP.length; k++){ if(year==blogMAP[k][0][1]){ year_index=k; }} if(year_index==-1){ year_index=blogMAP.length; blogMAP.push([['blog_map', year, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0], [0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0],[0, 0, 0]]); } blogMAP.sort(function(a, b){ // 年度の昇順にソート return b[0][1] - a[0][1]; }); for(let k=0; k<blogMAP.length; k++){ if(year==blogMAP[k][0][1]){ // ソート後にyear_indexを再取得 year_index=k; }} write_MAP(); // MAP 保存 drive_mode=blogDB[0][1]; // 起動時に動作フラグを取得 if(drive_mode==0){ drive_mode='s'; } // 旧ファイルの救済 reg_set(); function reg_set(){ let k; entry_id_DB=[]; // リセット pub_all=0; pub_dra=0; pub_ame=0; for(k=0; k<blogDB.length; k++){ entry_id_DB[k]=blogDB[k][0]; // ID検索用の配列を作成 if(blogDB[k][1]=='0'){ pub_all +=1; continue; } if(blogDB[k][1]=='1'){ pub_dra +=1; continue; } if(blogDB[k][1]=='2'){ pub_ame +=1; continue; }}} control_pannel(drive_mode); function control_pannel(d){ let box=document.querySelector('#sorting'); if(box){ let insert_div= '<div id="div2"></div>'+ '<div id="div0">'+ '<input id="list_snap" type="submit">'+ '<input id="reset" type="submit" value="初期化">'+ '<input id="export" type="submit" value="MAPをファイル保存">'+ '<input id="import_sw" type="submit" value="ファイル読込み">'+ '<span id="import_result"></span>'+ '<input id="import" type="file">'+ '</div>'+ '<div id="div1">'+ '<span id="snap_result"></span>'+ '<input id="amb_menu" type="submit" value="通常表示 ⏏">'+ '</div>'; if(!box.querySelector('#div0')){ box.insertAdjacentHTML('beforeend', insert_div); } now_year_disp(); // MAPを表示 easy_go(); let button1=box.querySelector('#list_snap'); let button2=box.querySelector('#reset'); let button3=box.querySelector('#export'); let button4=box.querySelector('#import_sw'); let span5=box.querySelector('#import_result'); let input6=box.querySelector('#import'); let span7=box.querySelector('#snap_result'); if(d=='s'){ button1.value='MAPの調査を開始 ▶'; button1.onclick=function(e){ e.preventDefault(); start(); } function start(){ let conf_str=[' 🔴 このページ以降の記事に関して 「公開設定MAP」を調査します', '\n 連続動作は [ Ctrl ] キーを押すか [ ❚❚ ] のクリックで停止します'].join(' '); let ok=confirm(conf_str); if(ok){ blogDB[0][1]='c'; // 連続動作フラグをセット write_DB(); // DB 保存 next(); }}} else if(d=='c'){ //「c」は連続動作 button2.style.display='none'; // 動作モードが「c」の場合は非表示 button3.style.display='none'; // 動作モードが「c」の場合は非表示 button4.style.display='none'; // 動作モードが「c」の場合は非表示 span5.style.display='none'; // 動作モードが「c」の場合は非表示 button1.value='MAPの調査を停止 ❚❚'; button1.style.width='760px'; button1.onclick=function(e){ e.preventDefault(); stop(); } document.addEventListener('keydown', (e)=>{ if(e.ctrlKey){ e.preventDefault(); stop(); }}); function stop(){ blogDB[0][1]='s'; // 連続動作フラグをセット write_DB(); // DB 保存 button1.value='MAPの調査を続行 ▶'; button1.style.pointerEvents='none'; box.style.background='#96b6d2'; setTimeout(()=>{ button1.style.pointerEvents='auto'; button1.onclick=function(e){ e.preventDefault(); blogDB[0][1]='c'; // 連続動作フラグをセット write_DB(); // DB 保存 location.reload(); }}, 500); } setTimeout(()=>{ if(blogDB[0][1]=='c'){ next(); }}, 1000); } // 連続実行のぺージ遷移のタイミング 1sec ⭕ else if(d=='e'){ // 「e」は終了 button1.value='🔵 MAP調査が終了しました'; button1.style.pointerEvents='none'; box.addEventListener('mouseover', function(e){ e.preventDefault(); box.style.background='#ddedf3'; }, false); } if(d=='s' || d=='e'){ button2.onclick=function(e){ // 全データをリセット e.preventDefault(); blogDB=[['00000000000', 's']]; write_DB(); // DB 保存 snap_disp(); button2.value='〔 〕'; span5.textContent=''; input6.value=''; for(let k=0; k< blogMAP.length; k++){ for(let m=1; m<13; m++){ // m=0 の年度表示は残す blogMAP[k][m]=[0, 0, 0]; }} write_MAP(); // MAP 保存 now_year_disp(); // MAPを表示 easy_go(); } button3.onclick=function(e){ e.preventDefault(); let write_json=JSON.stringify(blogMAP); let blob=new Blob([write_json], {type: 'application/json'}); let a_elem=document.createElement('a'); a_elem.href=URL.createObjectURL(blob); a_elem.download='blogMAP.json'; // 保存ファイル名 if(ua==1){ a_elem.target='_blank'; document.body.appendChild(a_elem); } a_elem.click(); if(ua==1){ document.body.removeChild(a_elem); } URL.revokeObjectURL(a_elem.href); } button4.onclick=function(e){ e.preventDefault(); input6.click(); } input6.addEventListener("change", function(){ if(!(input6.value)) return; // ファイルが選択されない場合 let file_list=input6.files; if(!file_list) return; // ファイルリストが選択されない場合 let file=file_list[0]; if(!file) return; // ファイルが無い場合 let file_reader=new FileReader(); file_reader.readAsText(file); file_reader.onload=function(){ if(file_reader.result.slice(0, 14)=='[[["blog_map",'){ // blogMAP.jsonの確認 let data_in=JSON.parse(file_reader.result); blogMAP=data_in; // 読込み上書き処理 write_MAP(); // MAP 保存 button2.value='初期化'; // 初期化後なら読み込んだ事を示す snap_disp(); span5.textContent=file.name; now_year_disp(); // MAPを表示 easy_go(); } else{ alert(" ⛔ 不適合なファイルです blogMAP(n).json ファイルを選択してください"); }} }); } snap_disp(); disp_amb_menu(); } // if(box) } // control_pannel() function snap_disp(){ reg_set(); let span7=document.querySelector('#snap_result'); span7.innerHTML=' 記録件数:<b>' + (blogDB.length -1) + '</b> 全員に公開:<b>' + pub_all + '</b> アメンバー限定公開:<b>' + pub_ame + '</b> 下書き:<b>' + pub_dra; +'</b>'; } function next(){ let win_url; let current; let pageid; let next_url; let pager; let end; entry_id=document.querySelectorAll('input[name="entry_id"]'); if(entry_id.length >0){ snap(); } // 投稿記事がある場合SNAPを実行 無ければスルーする win_url=window.location.search.substring(1,window.location.search.length); current=win_url.slice(-6); if(!current){ current=make_curr(); } if(win_url.indexOf('pageID') ==-1){ // pageIDが無い 月のトップページの場合 pager=document.querySelector('.pagingArea'); if(pager){ // ページャーが有りその末尾でなければ同月次ページへ next_url=['https://blog.ameba.jp/ucs/entry/srventrylist.do?', 'pageID=2&entry_ym=' + current].join(''); window.open( next_url, '_self'); } else{ // ページャーが無ければ次月トップページへ current=make_next(current); if(current!=0){ // 現在を越えないなら次月へ next_url=['https://blog.ameba.jp/ucs/entry/srventrylist.do?', 'entry_ym=' + current].join(''); window.open( next_url, '_self'); } else{ // 現在を越えたら0が戻り停止 when_edge(); }}} else{ // pageIDを含み 月のトップページでない場合 end=document.querySelector('.pagingArea .disabled.next'); if(!end){ // ページャーの末尾でなければ同月次ページへ pageid=parseInt(win_url.slice(7).slice(0, -16), 10) +1; next_url=['https://blog.ameba.jp/ucs/entry/srventrylist.do?', 'pageID=' + pageid + '&entry_ym=' + current].join(''); window.open( next_url, '_self'); } else{ // ページャーの末尾なら次月トップページへ current=make_next(current); if(current!=0){ // 現在を越えないなら次月へ next_url=['https://blog.ameba.jp/ucs/entry/srventrylist.do?', 'entry_ym=' + current].join(''); window.open( next_url, '_self'); } else{ // 現在を越えたら0が戻り停止 when_edge(); }}} function make_next(curr){ let ym; let y; let m; ym=parseInt(curr, 10); // 10進数値化 y=Math.floor(ym/100); // 年は100で割った商 m=ym % 100; // 月は100で割った余り if(m !=12){ ym=100*y + m +1; } else{ ym=100*y + 101; } let now=new Date(); if(ym > 100*now.getFullYear() + now.getMonth() +1){ return 0; } // 現在の月を越える場合は0を返す else{ return ym; }} // 次年月の数値を返す function make_curr(){ let now=new Date(); return 100*now.getFullYear() + now.getMonth() +1 } function when_edge(){ blogDB[0][1]='s'; // 連続動作フラグをリセット write_DB(); // DB 保存 document.querySelector('#div0').remove(); document.querySelector('#div1').remove(); control_pannel('e'); } // SNAP終了時の表示をさせる } // next() function snap(){ // ページ内の「公開設定」をSNAPする let win_url=window.location.search.substring(1,window.location.search.length); let entry_date=parseInt(win_url.slice(-6), 10); // SNAPしている現在の「年月 6桁」 if(!entry_date){ entry_date=make_curr(); } function make_curr(){ let now=new Date(); return 100*now.getFullYear() + now.getMonth() +1 } entry_id=document.querySelectorAll('input[name="entry_id"]'); publish_f=document.querySelectorAll('input[name="publish_flg"]'); for(let k=0; k< entry_id.length; k++){ let index=entry_id_DB.indexOf(entry_id[k].value); if(index==-1){ // IDがblogDBに記録されていない場合 blogDB.push([entry_id[k].value, publish_f[k].value, entry_date]); } // 公開設定の登録を追加 else{ // IDがblogDBに記録されていた場合 blogDB[index]=[entry_id[k].value, publish_f[k].value, entry_date]; }} // 公開設定の登録を更新 let filter_date=blogDB.filter(function(value){ return value[2]==entry_date; }); if(filter_date.length>0){ let filter_open=filter_date.filter(function(value){ return value[1]==0; }); blogMAP[year_index][month][0]=filter_open.length; let filter_close=filter_date.filter(function(value){ return value[1]==1; }); blogMAP[year_index][month][1]=filter_close.length; let filter_amem=filter_date.filter(function(value){ return value[1]==2; }); blogMAP[year_index][month][2]=filter_amem.length; } setTimeout(write_DB, 10); setTimeout(write_MAP, 10); } // snap() function write_MAP(){ // セッションストレージ MAP 保存 let write_map_json=JSON.stringify(blogMAP); sessionStorage.setItem('blogMAP_back', write_map_json); } function write_DB(){ // セッションストレージ DB 保存 let write_json=JSON.stringify(blogDB); sessionStorage.setItem('blogDB_back', write_json); } let div2=document.querySelector('#div2'); div2.onclick=function(e){ e.preventDefault(); let div_add=div2.querySelectorAll('.div_add'); if(div_add.length>1){ now_year_disp(); easy_go(); } else{ all_year_disp(); easy_go(); }} function now_year_disp(){ let box=document.querySelector('#sorting'); if(box){ let now_year_snap= '<div class="div_add">'+ arr_disp(year_index) + '</div>'+ '<style>#sorting { height: auto !important; }</style>'; let div2=box.querySelector('#div2'); if(div2){ div2.innerHTML=now_year_snap; } let mt=box.querySelectorAll('.m .mt'); mt[month-1].style.outline='2px solid #0066cc'; mt[month-1].style.outlineOffset='-4px'; p_color(); }} function all_year_disp(){ let box=document.querySelector('#sorting'); if(box){ let all_year_snap=''; for(let k=0; k<blogMAP.length; k++){ all_year_snap+= '<div class="div_add">'+ arr_disp(k) + '</div>'; } all_year_snap+= '<style>#sorting { height: auto !important; }</style>'; let div2=box.querySelector('#div2'); if(div2){ div2.innerHTML=all_year_snap; } p_color(); }} function arr_disp(y){ if(blogMAP[y][0][1]==1000){ let sw= '<div class="m y_index" style="display: none"><p>1000</p></div>'+ '<div class="m" style="width: auto"><p class="mt" style="display: none">1</p>'+ '<p style="border: none;margin: 2px 0 0">◙ ブログの最初の日付のページを表示する</p></div>'; return sw; } else{ let arr= '<div class="m y_index"><p>'+blogMAP[y][0][1]+'</p></div>'+ '<div class="m"><p class="mt">1月</p><p>'+blogMAP[y][1][0]+'</p><p>'+blogMAP[y][1][1]+'</p><p>'+blogMAP[y][1][2]+'</p></div>'+ '<div class="m"><p class="mt">2月</p><p>'+blogMAP[y][2][0]+'</p><p>'+blogMAP[y][2][1]+'</p><p>'+blogMAP[y][2][2]+'</p></div>'+ '<div class="m"><p class="mt">3月</p><p>'+blogMAP[y][3][0]+'</p><p>'+blogMAP[y][3][1]+'</p><p>'+blogMAP[y][3][2]+'</p></div>'+ '<div class="m"><p class="mt">4月</p><p>'+blogMAP[y][4][0]+'</p><p>'+blogMAP[y][4][1]+'</p><p>'+blogMAP[y][4][2]+'</p></div>'+ '<div class="m"><p class="mt">5月</p><p>'+blogMAP[y][5][0]+'</p><p>'+blogMAP[y][5][1]+'</p><p>'+blogMAP[y][5][2]+'</p></div>'+ '<div class="m"><p class="mt">6月</p><p>'+blogMAP[y][6][0]+'</p><p>'+blogMAP[y][6][1]+'</p><p>'+blogMAP[y][6][2]+'</p></div>'+ '<div class="m"><p class="mt">7月</p><p>'+blogMAP[y][7][0]+'</p><p>'+blogMAP[y][7][1]+'</p><p>'+blogMAP[y][7][2]+'</p></div>'+ '<div class="m"><p class="mt">8月</p><p>'+blogMAP[y][8][0]+'</p><p>'+blogMAP[y][8][1]+'</p><p>'+blogMAP[y][8][2]+'</p></div>'+ '<div class="m"><p class="mt">9月</p><p>'+blogMAP[y][9][0]+'</p><p>'+blogMAP[y][9][1]+'</p><p>'+blogMAP[y][9][2]+'</p></div>'+ '<div class="m"><p class="mt">10月</p><p>'+blogMAP[y][10][0]+'</p><p>'+blogMAP[y][10][1]+'</p><p>'+blogMAP[y][10][2]+'</p></div>'+ '<div class="m"><p class="mt">11月</p><p>'+blogMAP[y][11][0]+'</p><p>'+blogMAP[y][11][1]+'</p><p>'+blogMAP[y][11][2]+'</p></div>'+ '<div class="m"><p class="mt">12月</p><p>'+blogMAP[y][12][0]+'</p><p>'+blogMAP[y][12][1]+'</p><p>'+blogMAP[y][12][2]+'</p></div>'; return arr; } } // arr_disp(y) function p_color(){ let box=document.querySelector('#sorting'); if(box){ let open=box.querySelectorAll('.div_add .m p:nth-child(2)'); for(let k=0; k<open.length; k++){ if(open[k].textContent=='0'){ open[k].style.color='transparent'; }} let close=box.querySelectorAll('.div_add .m p:nth-child(3)'); for(let k=0; k<close.length; k++){ if(close[k].textContent=='0'){ close[k].style.color='transparent'; } else{ close[k].style.background='#d7ecfd'; }} let amem=box.querySelectorAll('.div_add .m p:nth-child(4)'); for(let k=0; k<amem.length; k++){ if(amem[k].textContent=='0'){ amem[k].style.color='transparent'; } else{ amem[k].style.background='#a3d8d4'; }} }} // p_color() function easy_go(){ let add_m=document.querySelectorAll('.div_add .m'); for(let k=0; k<add_m.length; k++){ add_m[k].addEventListener('click', function(e){ if(!add_m[k].classList.contains('y_index')){ e.preventDefault(); e.stopImmediatePropagation(); jump_year(add_m[k]); } }); } function jump_year(m_map){ let div_add=m_map.closest('.div_add'); let to_year=div_add.querySelector('.y_index p').textContent; let to_month=m_map.querySelector('.mt').textContent; to_month=to_month.replace(/[^0-9]/g, ''); if(to_month!='10' && to_month!='11' && to_month!='12'){ to_month='0'+ to_month; } let to_url= 'https://blog.ameba.jp/ucs/entry/srventrylist.do?entry_ym='+ to_year + to_month; location.href=to_url; } } // easy_go() function disp_amb_menu(){ let button8=document.querySelector('#amb_menu'); if(button8){ button8.onclick=function(e){ e.preventDefault(); document.querySelector('#EPS').remove(); document.querySelector('#div0').remove(); document.querySelector('#div1').remove(); document.querySelector('#div2').remove(); document.querySelector('#sorting').style.background='#efefef'; }}} blog_start(); function blog_start(){ let win_url=window.location.search.substring(1,window.location.search.length); let current_year=win_url.slice(-6); if(current_year=='100001'){ let return_sw=document.querySelector('#entryYear a'); if(return_sw){ return_sw.click(); }}} });
「Every Page Map 💢」最新版について
旧いバージョンの JavaScriptツールは、アメーバのページ構成の変更で動作しない場合があり、導入する場合は最新バージョンをお勧めします。
●「Every Page Map 💢」の最新バージョンへのリンクは、以下のページのリンクリストから探せます。