banner
genkaim

genkaim

Darkmode,yes \q(≧▽≦q) 主题来自@birdgg

Hexo Butterfly最適化コレクション - ポップアップの追加 - ローディングアニメーションの変更 - チャットボットの導入 - CSSの美化

cover
原文を表示
内容が多いため、サイドバーの目次を参照することをお勧めします。

右上にポップアップを導入#

プレビューをクリック
  1. .jsファイルを導入

~\themes\butterfly\source\js\textWindow.js ファイルを新規作成し、以下のコードをコピーします。コメントに注意してください

var popup = document.createElement("div");
var button = document.createElement("button");

button.id = "close";
button.textContent = "X";
popup.id = "popup";
popup.className = "popup";
var title = document.createElement("h1");
title.textContent = "<ポップアップのタイトルを入力、下も変更することに注意>";
var content = document.createElement("p");
content.textContent = "<ポップアップの内容を入力、下も変更することに注意>";
popup.appendChild(title);
popup.appendChild(content);
document.body.insertAdjacentHTML("afterbegin", '<div id="popup" class="popup"><h1>ポップアップのタイトルを入力</h1><p>ポップアップの内容を入力</p></div>');
document.body.insertAdjacentElement("afterbegin", button);

var popup = document.getElementById("popup");
var close = document.getElementById("close");

function show() {
    popup.style.opacity = 1;
    popup.animate([
      { transform: 'translateX(110%)' }, 
      { transform: 'translateX(0)' }
    ], {
      duration: 1000,
      fill: 'forwards', 
      easing: 'ease-in-out'
    }); 
}

function hide() {
    popup.animate([
        { transform: 'translateX(0)' }, 
        { transform: 'translateX(110%)' }
      ], {
        duration: 1000, 
        fill: 'forwards', 
        easing: 'ease-in-out'
      });
}

window.onload = function() {
    show()
}//ここでトリガー方法を選択、デフォルトは読み込み完了時にポップアップが表示されます
//ポップアップを表示させるにはshow()を呼び出し、非表示にするにはhide()を呼び出します
popup.insertBefore(close, popup.firstChild);
close.onclick = function() {
     hide();
};

次に、テーマ設定ファイルの bottom 部分に以下を追加します。

     - <script src="/js/textWindow.js"></script>
  1. .cssファイルを導入

~\themes\butterfly\source\css\textWindow.css ファイルを新規作成し、以下のコードをコピーします。コメントに注意してください

[data-theme='light'] #popup {/*サイトの明暗に応じて変更*/
    background-color: #e1e1e1;/*ここで主体の背景色を変更*/
    box-shadow: 0 0 10px rgb(114, 113, 113);
}
[data-theme='dark'] #popup {
    background: #3b443e ;/*ここで主体の背景色を変更*/
    box-shadow: 0 0 10px rgb(29, 29, 29);
}  

#popup {
    position: fixed;
    right: 1vh;
    top: 2vh;
    width: 350px; 
    height: 125px; 
    border: 8px ;
    z-index: 1000000;
    border-radius: 8px;
    opacity: 0;
}
#popup h1 {
    font-size: 20px !important;
    margin-left: 15px;
    margin-top: 10px;
    margin-bottom: 0px;
}
#popup p {
    position: absolute;
    width: 250px;
    font-size: 15px !important;
    margin-left: 15px;
    margin-top: 0px ;
}
  
#close {
    position: absolute;
    width: 50px; 
    height: 110px; 
    margin-left: 292.5px; 
    margin-top: 7.5px; 
    border: none; 
    color: black; 
    border-radius: 8px;
    z-index: 1000001;
    background-color: #6a94b3;/*ここでボタンの背景色を変更*/ 
}

次に、テーマ設定ファイルの head 部分に以下を追加します。

     - <link rel="stylesheet" href="/css/textWindow.css">

ローディングアニメーションの変更(当サイトと同様)#

アニメーションソース 自分のコードをテンプレートとして使用し、このサイトで好きなアニメーションをローディングアニメーションとして選ぶこともできます。

  1. ソースコードを変更

~\themes\butterfly\layout\includes\layout.pug を開き、以下のように約 12 行目を変更します。インデントに注意

-      !=partial('includes/loading/index', {}, {cache: true})
+      !=partial('includes/loading/loaded.ejs', {}, {cache: true})
  1. ~\themes\butterfly\layout\includes\loading\loaded.ejs を新規作成し、以下のコードをコピーします。
<% if (theme.preloader.enable) { %>
    <script>
        document.body.style.overflow = 'hidden';
    </script>
    <section class='loader'>
        <div class='loader-center'>
          <div class='chars'>
            <span class='char brace'>{</span>
            <span class='dots'>
              <span class='char dot _dot-1'>.</span>
              <span class='char dot _dot-2'>.</span>
              <span class='char dot _dot-3'>.</span>
            </span>
            <span class='char brace'>}</span>
          </div>
        </div>
      </section>
      
    <script>
        var endLoading = function () {
            document.body.style.overflow = 'auto';
            var loader = document.querySelector('section.loader');
            loader.classList.add('loading');
            setTimeout(function() {
                loader.style.display = 'none';
            }, 1000);
        }
        setTimeout(function() {
                window.addEventListener('load',endLoading);
        }, 500);
    </script>
    <% } %>
    
  1. ~\themes\butterfly\source\css\loaded.css を新規作成し、以下のコードをコピーします。
section.loader {
  font-family: Consolas, monaco, monospace;
  position:fixed;
  top:0; left:0; right:0; bottom:0;
  background-color:#232427;
  z-index: 100000;
  color:#FF893A;
  width: 100%;
  height: 100%;
}
section.loader .loader-center {
  width:300px;
  height:100px;
  line-height:100px;
  
  margin:0 auto;
  text-align:center;
  font-size:38px;
  letter-spacing:-6px;
  
  position:absolute;
  top:50%; left:50%;
  margin-left:-150px; margin-top:-50px;
  
}

section.loader .loader-center .chars .dots .char {
  font-size:150%;
  display:inline-block;
}

/* アニメーションはここから始まります */
.dots .dot {
  position:relative;
  top:0; left:0; 
}

.dot._dot-1 {
  animation:dot_1 1s ease-in-out infinite;
  animation-fill-mode: backwards;
  animation-direction: alternate;
}

.dot._dot-2 {
  animation:dot_2 1s ease-in-out infinite;
  animation-fill-mode: backwards;
  animation-direction: alternate;
  animation-delay:1s;
}

.dot._dot-3 {
  animation:dot_3 1s ease-in-out infinite;
  animation-fill-mode: backwards;
  animation-direction: alternate;
  animation-delay:0.5s;
}

@keyframes dot_1 {
  0% {
    top:0;
    left:0;
  }
  
  50% {
    top:30px;
    left:20px;
  }
  
  100% {
    top:0px;
    left:40px;
  }
}

@keyframes dot_2 {
  0% {
    top:0;
    left:0;
  }
  
  50% {
    top:-30px;
    left:20px;
  }
  
  100% {
    top:0px;
    left:40px;
  }
}

@keyframes dot_3 {
  0% {
    top:0;
    left:0;
  }
  
  50% {
    top:-30px;
    left:-40px;
  }
  
  100% {
    top:0px;
    left:-80px;
  }
}

section .author {
  position:fixed;
  top:0; bottom:0;
  left:0px;
  
  font-size:80%;
  transform:rotate(-10deg) translate(50px, 20px);
  
  padding:5px 0;
  text-align:center;
  
  color:#eee;
  opacity:0.8;
}

section .author a {
  color:#78ECB4;
  text-decoration:none;
}

section .author a:hover {
  color:#60D69D;
}
/*
* アフィリエイト
*/
.affiliate-container .the-text {
  background-color: rgba(0,0,0,0.5);
}

.affiliate-container {
  opacity: 0.6;
  position: absolute;
  right: -20px;
  top: 0px;
  transform: scale(.8);
  transition: 0.2s all ease-in-out;
  margin-top: 0;
  justify-content: flex-end;
}

.affiliate-container:hover {
  opacity: 0.8;
  transform: scale(1);
}

/*退出,组件再loaded.ejs*/
.loader {
  opacity: 1;
  transform: scale(1);
  transition: opacity 1s ease-in-out, transform 1s ease-in-out;
}

.loader.loading {
  opacity: 0;
  transform: scale(2);
}

次に、テーマ設定ファイルの head 部分に以下を追加します。

     - <link rel="stylesheet" href="/css/loaded.css" >

AI(ChatGPT)ボットの導入#

😆 ボットを作成する#

今回はChat Thingサイトを利用します。無料版は GPT-3 をサポートしています。

  1. サイトにアクセスし、登録してログインします。ダッシュボードが表示されます。
  2. ボットを作成します。無料版では 1 つのボットしか作成できません。
  3. ボットの基本情報を設定します。催眠の部分はAdvanced settingsの一番下にあります。

image-20230809203623323

🫤 データソースの設定#

注意:無料版では 1 つのデータソースしか持てませんが、通常は十分です。

image-20230809214044613

いくつかの異なる方法がありますが、ここでは 2 つの方法を紹介します。

  1. ウェブサイト:(サイトマップを使用できるため)画像のように、URL を入力するだけです。
image-20230809204349728
  1. RSS 購読:あなたの xlog ホームページの RSS ボタンをクリックし、新しく開いたページの URL を下の図の位置にコピーします。

    image-20230810085810825

image-20230810085956865

データソースを保存して同期することを忘れないでください。

image-20230810090147307

これでデータソースの設定が完了しました。

🥰 ブログにボットを埋め込む#

Embed Bot を開き、下の図を参考にして、挿入したい方法を選択します。

image-20230809204552761

記事やページに挿入する場合は、対応する.mdに見たコードをそのまま挿入すれば簡単です。

全体のウィジェットを希望する場合は、bottom に直接以下を追加します:

<script src="https://chatthing.ai/chat-widget.js" type="text/javascript" id="<見たウィジェットコードのidに置き換え(引用符を保持)>" async defer></script>

効果はそれぞれ以下の図のようになります。

image-20230809210531921 image-20230809205358309

桜のエフェクトを導入#

~\themes\butterfly\source\js\sakura.js ファイルを新規作成し、以下のコードをコピーします。

if (window.location.pathname === '/') {
    var stop, staticx;
    var img = new Image();
    img.src = "
読み込み中...
文章は、創作者によって署名され、ブロックチェーンに安全に保存されています。