hoppingBot
https://scrapbox.io/files/662c848be1f0690024aa9751.gif
code:export.js
export let hopBot = {};
function hashCode(str) {
let hash = 0;
let i, chr;
if (str.length === 0) return hash;
for (i = 0; i < str.length; i++) {
chr = str.charCodeAt(i);
hash = ((hash << 5) - hash) + chr;
hash |= 0; // Convert to 32bit integer
}
return hash;
}
function hopping() {
let hopBotDom = $('#tzmk_hopBot');
if (hopBotDom.hasClass('tzmk_hopBot_1')) {
hopBotDom.removeClass('tzmk_hopBot_1');
} else {
hopBotDom.addClass('tzmk_hopBot_1');
}
}
function complete() {
let hopBotDom = $('#tzmk_hopBot');
clearInterval(hopBotDom.attr('tzmk_animeId'));
hopBotDom.removeClass('tzmk_hopBot_1');
hopBotDom.addClass('tzmk_hopBot_2');
}
function setHopping() {
let hopBotDom = $('#tzmk_hopBot');
hopBotDom.removeClass('tzmk_hopBot_2');
let id = setInterval(hopping, 500);
hopBotDom.attr('tzmk_animeId', id);
setTimeout(complete, 2000);
}
let hopBotDom = $('<div id="tzmk_hopBot" class="tzmk_hopBot tzmk_hidden"></div>');
$('body').append(hopBotDom);
let hopBotModal = [
'<div id="tzmk_gptLogModal" class="tzmk_gptLogModal tzmk_hidden">',
'<div>askGPT log<button id="tzmk_gptLogModalCloseButton" class="tzmk_closeButton" href="#">close</button></div>',
'<div id="tzmk_gptLogModalInner"></div>',
'<button id="tzmk_gptLogModalResetButton" class="tzmk_resetButton" href="#">clear all log</button>',
'</div>'
].join('\n');
$('body').append(hopBotModal);
$('#tzmk_gptLogModalCloseButton').on('click',function() {
$('.tzmk_customModalBack').addClass('tzmk_hidden');
$('.tzmk_gptLogModal').addClass('tzmk_hidden');
});
$('#tzmk_gptLogModalResetButton').on('click', function() {
if (confirm("Clear all answers?")) {
$('#tzmk_hopBot').addClass('tzmk_hidden');
$('.tzmk_gptLogModal').addClass('tzmk_hidden');
$('.tzmk_customModalBack').addClass('tzmk_hidden');
$('#tzmk_gptLogModalInner').empty();
}
});
hopBotDom.on('click', function(){
$('.tzmk_customModalBack').removeClass('tzmk_hidden');
$('.tzmk_gptLogModal').removeClass('tzmk_hidden');
});
hopBot.startHopping = function() {
$('#tzmk_hopBot').removeClass('tzmk_hidden');
setHopping();
}
hopBot.completePase = function() {
complete();
}
hopBot.addLog = function(query) {
let id = hashCode(query);
let domString = [
<div class="tzmk_gptLog" id="tzmk_gptLog${id}">,
<div class="tzmk_gptQuery">${query}</div>,
' <textarea class="tzmk_gptAnswer">running...</textarea>',
' <button class="tzmk_copyButton">copy</button>',
'</div>',
].join('\n');
$('#tzmk_gptLogModalInner').append(domString);
$(#tzmk_gptLogModalInner #tzmk_gptLog${id} .tzmk_copyButton).on('click', function(){
let text = $(#tzmk_gptLogModalInner #tzmk_gptLog${id} textarea).val();
navigator.clipboard.writeText('chatgpt.icon\n' + text)
.then((success)=>{
$(#tzmk_gptLogModalInner #tzmk_gptLog${id} .tzmk_copyButton)
.text('copied').addClass('tzmk_copyButtonDone');
setTimeout(function(){
$(#tzmk_gptLogModalInner #tzmk_gptLog${id} .tzmk_copyButton)
.text('copy').removeClass('tzmk_copyButtonDone');
}, 1000);
},
(error)=>alert('failed'));
});
return id;
}
hopBot.addAnswer = function(logId, answer) {
$(#tzmk_gptLogModalInner #tzmk_gptLog${logId} textarea).val(answer);
}
let descriptionId = hopBot.addLog('ここにaskGPTのクエリが表示されます');
hopBot.addAnswer(descriptionId, 'ここにaskGPTの結果が表示されます');
code:style.css
.tzmk_hopBot {
height: 48px;
background-size: 200%;
width: 48px;
position: fixed;
bottom: 50px;
left: 10px;
}
.tzmk_hopBot_1 {
background-position-y: 100%;
}
.tzmk_hopBot_2 {
background-position-x: 100%;
background-position-y: 100%;
}
.tzmk_gptLogModal {
z-index: 301;
position:fixed;
top: 50px;
left:10px;
width: 60%;
min-width: 400px;
padding: 20px;
height: 80%;
overflow: scroll;
padding-bottom: 40px;
background-color: white;
}
.tzmk_gptQuery {
margin: 2px;
}
.tzmk_gptAnswer {
width: 80%;
}
.tzmk_gptLog {
padding: 5px;
margin: 2px;
}
.tzmk_copyButton {
text-align:center;
padding: 4px;
}
.tzmk_copyButtonDone {
color: white;
background-color: black;
}
.tzmk_resetButton {
text-align:center;
padding: 4px;
color: white;
position: absolute;
bottom: 5px;
}