「絵文字」タブの初期表示を保持する
これまで、「画像の貼り付け」の方法を保持する機能を作って来ましたが、「絵文字」タブの初期表示にこの機能を応用できます。
絵文字タブを開くと、編集画面を起動時して最初に開いた時は「履歴」の表示になります。 しかし、「気持ち」「記号」など毎回使うパレットが決まっている場合は、そのパレットを最初から表示出来たら便利です。 こういった環境の保持機能は、シンプルなコードで実現可能で、「Editor Keeper ⭐📛」に機能を追加しました。
「絵文字」タブの保持の仕様
保持するのは、「絵文字」タブの「履歴・絵文字」の選択と、「絵文字」のパレットは「気持ち」「記号」「自然・動物」「食べ物」「お出かけ・イベント」「アイテム」の6種がありますが、この選択を保持させます。
これらにより、「絵文字」タブを開くと決まった「絵文字パレット」が直接に開く様に出来ます。「履歴」を含めると、最初に開くパレットは7種です。
最後に開いていた「絵文字パレット」が保持され、編集画面やブラウザを終了させても、次に「絵文字」タブを開いた時に、保持したパレットが表示されます。
なお、「履歴」の選択で終了した場合は、「履歴」のパレットが初期表示になりますが、「絵文字」の中の6種のパレットを開くと、その選択も保持されています。
選択を記録する配列の拡張について
これまでは2個の数の配列で画像の設定を保持して来ましたが、今回2個を追加して、配列の要素数が増えました。 これまでのバージョンのローカルストレージをそのまま互換を保って拡張するため、このバージョンから以下のコードを使っています。
記録用の配列は「aw_preset」ですが、要素が2個から4個に増えます。 このバージョンが、従来の配列をローカルストレージから読んだ場合は、配列の数を4個に増やす必要があります。 これをしないと、スクリプトが停止します。
太字の部分は、読んだ配列の数「aw_preset.length」が必要な4個に満たない場合、4個になるまで「0」の初期値の数を配列に追加するコードです。 ツールの更新で更に配列の数を増やす場合は、「4」を変更するだけで済みます。
環境を記録する関数を独立
編集画面の環境を記録する箇所が増えて来ると、その箇所ごとにローカルストレージの記録を行うコードが追加されます。 記録する部分を関数化しておけば、各箇所でのコードが簡潔に書け、複雑なとりまわしが不要になります。 以下は、新しく導入した関数のコードで、引数の「ele」は配列のインデックス、「val」は記録値です。
「Editor Keeper ⭐📛」ver. 1.9
このツールは Chrome / 新Edge / Firefox の「Tampermonkey」で動作します。
このツールの仕様などについては、以下のページを参照ください。
画像貼り付け設定を記録する「Editor Keeper⭐📛」
ツールの導入方法
以下のコードを「Tampermonkey」の新規スクリプトの作成画面にコピー&ペーストして保存する事で、このツールを利用する事が出来ます。
〔コピー方法〕 軽量シンプルなツール「PreBox Button 」を使うと
コード枠内を「Ctrl+左Click」➔「Copy code 」を「左Click」
の操作で、掲載コードのコピーが可能になります。
〔 Editor Keeper ⭐📛 〕 ver. 1.9
// ==UserScript== // @name Editor Keeper ⭐📛 // @namespace http://tampermonkey.net/ // @version 1.9 // @description 編集画面を閉じず「管理トップ」「ブログトップ」に移動する // @author Ameblo Writer User // @match https://blog.ameba.jp/ucs/entry/srventry* // @exclude https://blog.ameba.jp/ucs/entry/srventrylist.do* // @grant none // ==/UserScript== let retry=0; let interval=setInterval(wait_target, 100); function wait_target(){ retry++; if(retry>10){ // リトライ制限 10回 1sec clearInterval(interval); } let target=document.querySelector('.l-gHeaderLeft__link a'); // 監視 target if(target){ clearInterval(interval); button_disp(); keeper(); photo_set(); }} function button_disp(){ let ua=0; // Chromeの場合のフラグ let agent=window.navigator.userAgent.toLowerCase(); if(agent.indexOf('firefox') > -1){ ua=1; } // Firefoxの場合のフラグ if(agent.indexOf('edg') > -1){ ua=2; } // NEdgeの場合のフラグ // 以下 起動表示CSSを適用 📛 let css; if(ua==0){ css= '.l-gHeaderLeft__link a:before { content: "" !important; }'+ '.l-gHeaderLeft__link a:after { content: "⏏" !important; font-size: 24px !important; '+ 'line-height: 16px !important; top: 2px !important; left: 6px !important; }'+ '.l-gHeaderLeft__link a { text-indent: -6.3em !important; height: 31px !important; padding-top: 3px; }'+ '.l-gHeaderLeft__link a:hover { text-indent: 0.4em !important; background: #fff !important; '+ 'width: calc(28px + 6.7em) !important; box-shadow: -10px 0 1px 0 var(--bgc1) !important; }'+ '#globalHeader #gHeaderLeft { width: 280px; }'; } if(ua==1){ css= '.l-gHeaderLeft__link a:before { content: "" !important; }'+ '.l-gHeaderLeft__link a:after { content: "⏏" !important; font-size: 36px !important; '+ 'line-height: 4px !important; top: 7px !important; left: 2px !important; }'+ '.l-gHeaderLeft__link a { text-indent: -6em !important; height: 30px !important; padding-top: 4px; }'+ '.l-gHeaderLeft__link a:hover { text-indent: 0.7em !important; background: #fff !important; '+ 'width: calc(28px + 6.7em) !important; box-shadow: -10px 0 1px 0 var(--bgc1) !important; }'+ '#globalHeader #gHeaderLeft { width: 280px; }'; } if(ua==2){ css= '.l-gHeaderLeft__link a:before { content: "" !important; }'+ '.l-gHeaderLeft__link a:after { content: "\\EA37" !important; '+ 'font: normal 30px/8px ameba-symbols !important; top: 10px !important; left: 3px !important; }'+ '.l-gHeaderLeft__link a { text-indent: -6.3em !important; height: 31px !important; padding-top: 3px; }'+ '.l-gHeaderLeft__link a:hover { text-indent: 0.4em !important; background: #fff !important; '+ 'width: calc(28px + 6.7em) !important; box-shadow: -10px 0 1px 0 var(--bgc1) !important; }'+ '#globalHeader #gHeaderLeft { width: 280px; }'; } let style_tag=document.createElement("style"); // css設定styleタグ style_tag.type="text/css"; style_tag.appendChild(document.createTextNode(css)); document.querySelector('.l-body').appendChild(style_tag); } // button_disp() function keeper(){ let target=document.querySelector('.l-gHeaderLeft__link a'); target.setAttribute('target', '_blank'); target.onclick=function(){ if(event.shiftKey){ event.preventDefault(); let amebaId=document.querySelector('.amebaId').textContent; if(amebaId){ let blogurl='https://ameblo.jp/' + amebaId + '/'; window.open(blogurl, "_blank"); }}} window.addEventListener('keydown', function(event){ if(event.shiftKey==true){ target.textContent='ブログトップ'; target.style.boxShadow='#00e2ff -14px 0 0 0 inset'; window.addEventListener('keyup', function(event){ target.textContent='管理トップへ'; target.style.boxShadow='#79fbf6 -14px 0 0 0 inset'; });}}); let editor_iframe=document.querySelector('.cke_wysiwyg_frame'); if(editor_iframe){ // iframe読込みが実行条件 let iframe_doc=editor_iframe.contentWindow.document; iframe_doc.addEventListener('keydown', function(event){ if(event.shiftKey==true){ target.textContent='ブログトップ'; target.style.boxShadow='#00e2ff -14px 0 0 0 inset'; iframe_doc.addEventListener('keyup', function(event){ target.textContent='管理トップへ'; target.style.boxShadow='#79fbf6 -14px 0 0 0 inset'; });}}); } } // keeper() function photo_set(){ let aw_preset=[]; // Ameblo Writer のユーザー設定 set_db(); function set_db(){ let read_json=localStorage.getItem('AWriter_Preset'); // ローカルストレージ 保存名 aw_preset=JSON.parse(read_json); if(aw_preset==null){ aw_preset=[0,0,0,0]; } else{ let db_length=aw_preset.length; for(let k=0; k<4-db_length; k++){ //「4」は配列指定数 aw_preset.push(0); }} let write_json=JSON.stringify(aw_preset); localStorage.setItem('AWriter_Preset', write_json); } // ローカルストレージ 保存 photo_size(); function photo_size(){ let ph_size=document.querySelectorAll('.js-photo-paste-size'); if(ph_size.length>0){ ph_size[aw_preset[0]].click(); } // サイズボタンをストレージ記録に従って押す for(let k=0; k<ph_size.length; k++){ // 押されたサイズボタンを記録する ph_size[k].onclick=function(){ storage_w(0, k); }}} // サイズ選択をローカルストレージ 保存 picto_select1(); function picto_select1(){ let pict_nav=document.querySelectorAll('.js-pictograph-nav'); if(pict_nav.length>0){ pict_nav[aw_preset[2]].click(); } for(let k=0; k<pict_nav.length; k++){ pict_nav[k].onclick=function(){ if(k==1){ picto_select2(); } // 絵文字のパレットを記録に従って開く storage_w(2, k); }}} // 履歴・絵文字の選択をローカルストレージ 保存 picto_select2(); function picto_select2(){ let pict_nav2=document.querySelectorAll('.js-pictograph-subNav'); if(pict_nav2.length>0){ pict_nav2[aw_preset[3]].click(); } for(let k=0; k<pict_nav2.length; k++){ pict_nav2[k].onclick=function(){ storage_w(3, k); }}} // 絵文字のパレット選択をローカルストレージ 保存 let p_images=document.querySelector('.p-images-imageList__body'); // 監視 target let monitor=new MutationObserver(photo_pos); monitor.observe(p_images, {childList: true, subtree: true}); // 画像リストの変化を監視開始 function photo_pos(){ let item=document.querySelectorAll('.p-images-imageList__item'); for(let k=0; k<item.length; k++){ set_pos(k); } function set_pos(k){ // 画像の挿入時に配置指定を実行 item[k].addEventListener('mouseup', function(){ let editor_iframe=document.querySelector('.cke_wysiwyg_frame'); if(editor_iframe){ // iframe読込みが実行条件 let iframe_doc=editor_iframe.contentWindow.document; let post_img_p=iframe_doc.getSelection().anchorNode; if(aw_preset[1]==1){ post_img_p.setAttribute("style", "text-align: center;"); } else if(aw_preset[1]==2){ post_img_p.setAttribute("style", "text-align: right;"); } setTimeout(()=>{ dialogue(); }, 20); }}); } // set_pos() } // photo_pos() dialogue(); function dialogue(){ let editor_iframe=document.querySelector('.cke_wysiwyg_frame'); if(editor_iframe){ // iframe読込みが実行条件 let iframe_doc=editor_iframe.contentWindow.document; let post_img=iframe_doc.querySelectorAll('.cke_editable img'); for(let k=0; k<post_img.length; k++){ post_img[k].addEventListener('click', function(){ setTimeout(()=>{ get_set(); }, 20); }); } function get_set(){ // 画像ダイアログのサイズ・位置選択を取得 let size_button=document.querySelectorAll('.js-image-size-button'); for(let k=0; k<size_button.length; k++){ size_button[k].addEventListener('mouseup', function(){ storage_w(0, k); // サイズ選択をローカルストレージ 保存 photo_size(); }); } // 右パレットのサイズボタンを押す let pos_button=document.querySelectorAll('.ck-imgJustify'); for(let k=0; k<pos_button.length; k++){ pos_button[k].addEventListener('mouseup', function(){ if(pos_button[k].classList.contains('ck-imgJustify--active')!=true){ storage_w(1, k); } // 位置選択をローカルストレージ 保存 else { storage_w(1, 0); }}); } // 位置リセットをローカルストレージ 保存 } // get_set() }} // dialogue() function storage_w(ele, val){ // 編集環境のローカルストレージ保存 aw_preset[ele]=val; let write_json=JSON.stringify(aw_preset); localStorage.setItem('AWriter_Preset', write_json); } } // photo_set()
「Editor Keeper ⭐📛」最新版について
旧いバージョンの JavaScriptツールは、アメーバのページ構成の変更で動作しない場合があり、導入する場合は最新バージョンをお勧めします。
●「Editor Keeper ⭐📛」の最新バージョンへのリンクは、以下のページのリンクリストから探せます。