banner
genkaim

genkaim

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

Hexo Butterfly Optimization Collection - Add Popup - Modify Loading Animation - Introduce Chatbot - CSS Beautification

cover
View Original
There is a lot of content, it is recommended to check the directory in the sidebar.

Introduce Popup in the Top Right Corner#

Click to Preview
  1. Introduce .js File

Create a new textWindow.js file in ~\themes\butterfly\source\js\, copy the code below, note the comments

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 = "<Enter Popup Title, remember to change below>";
var content = document.createElement("p");
content.textContent = "<Enter Popup Content, remember to change below>";
popup.appendChild(title);
popup.appendChild(content);
document.body.insertAdjacentHTML("afterbegin", '<div id="popup" class="popup"><h1>Enter Popup Title</h1><p>Enter Popup Content</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()
}//Choose the trigger method here, default is to show popup after loading
//To show the popup call show(), to hide call hide()
popup.insertBefore(close, popup.firstChild);
close.onclick = function() {
     hide();
};

Then include it in the bottom section of the theme configuration file

     - <script src="/js/textWindow.js"></script>
  1. Introduce .css File

Create a new textWindow.css file in ~\themes\butterfly\source\css\, copy the code below, note the comments

[data-theme='light'] #popup {/*Change according to website light and dark mode*/
    background-color: #e1e1e1;/*Change the main background color here*/
    box-shadow: 0 0 10px rgb(114, 113, 113);
}
[data-theme='dark'] #popup {
    background: #3b443e ;/*Change the main background color here*/
    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;/*Change button background color here*/ 
}

Then include it in the head section of the theme configuration file

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

Change Loading Animation (Same as this site)#

Animation Source You can also use my code as a template and choose your favorite animation from this website as the loading animation.

  1. Modify Source Code

Open ~\themes\butterfly\layout\includes\layout.pug and modify as follows, around line twelve, note the indentation

-      !=partial('includes/loading/index', {}, {cache: true})
+      !=partial('includes/loading/loaded.ejs', {}, {cache: true})
  1. Create a new loaded.ejs file in ~\themes\butterfly\layout\includes\loading\, copy the code below
<% 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. Create a new loaded.css file in ~\themes\butterfly\source\css\, copy the code below
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;
}

/* animation starts here */
.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
*/
.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);
}

/*Exit, component in 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);
}

Then include it in the head section of the theme configuration file

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

Integrate AI (ChatGPT) Bot#

😆 Create Bot New Bot#

This time we are using the Chat Thing website, the free version supports GPT-3.

  1. Register and log in, then you will see the dashboard.
  2. Create a bot, note that the free version only allows the creation of one bot.
  3. Set the basic information of the bot, note that the hypnosis part is at the bottom of Advanced settings.

image-20230809203623323

🫤 Set Data Source#

Note that the free version can only have one data source, but generally, this is enough.

image-20230809214044613

There are many different ways, here are two methods:

  1. Website: (because it can use sitemap) as shown, just enter the URL.
image-20230809204349728
  1. RSS Subscription: Click the RSS button on your xlog homepage, copy the URL of the newly opened webpage to the position in the image below.

    image-20230810085810825

image-20230810085956865

Remember to save and sync the data source

image-20230810090147307

Now, the data source is set up.

🥰 Embed Bot#

Open Embed Bot, refer to the image below for translation, choose the way you want to insert it.

image-20230809204552761

If you want to insert it into an article/page, it's very simple, just insert the code you see into the corresponding .md.

If you want a global widget, directly include it in the bottom:

<script src="https://chatthing.ai/chat-widget.js" type="text/javascript" id="<replace with the id you see in the widget code (keep the quotes)>" async defer></script>

The effects are shown in the images below.

image-20230809210531921 image-20230809205358309

Introduce Cherry Blossom Effect#

Create a new sakura.js file in ~\themes\butterfly\source\js\, copy the code below.

if (window.location.pathname === '/') {
    var stop, staticx;
    var img = new Image();
    img.src = "
Loading...
Ownership of this post data is guaranteed by blockchain and smart contracts to the creator alone.