Make Coze Bot looks better!
- // ==UserScript==
- // @name Style for Coze Bot App mode
- // @namespace https://www.velhlkj.com/
- // @version 1.1.5
- // @description Make Coze Bot looks better!
- // @author Velade
- // @match https://www.coze.com/store/bot/*
- // @icon 
- // @grant none
- // @run-at document-body
- // @license Apache 2.0
- // ==/UserScript==
- (function() {
- 'use strict';
- const style = document.createElement('style');
- style.textContent = `
- /*官方阴影*/
- .ULoOs2TMkJkb2BgT_MKa {
- display: none !important;
- }
- /*新对话按钮*/
- .NyvVfPwFXFYvQFyXUtTl {
- padding-left: 0 !important;
- }
- /*标题列*/
- .nZxnu8KzOis7qKnDx66E {
- position: fixed !important;
- top: 5px !important;
- right: 5px !important;
- width: 80px !important;
- height: 40px !important;
- filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.5)) !important;
- }
- .nZxnu8KzOis7qKnDx66E > div:first-child {
- display: none !important;
- }
- .nZxnu8KzOis7qKnDx66E > div:nth-child(2) > div:nth-child(2){
- display: none !important;
- }
- /*对话区域主体*/
- .O4fwdEnt3QgzBjrYtohO {
- -webkit-mask: linear-gradient(180deg,hsla(0,0%,100%,0) 5px, #fff calc(8.11% + 5px), #fff 91.89%, hsla(0,0%,100%,0)) !important;
- mask: linear-gradient(180deg,hsla(0,0%,100%,0) 5px, #fff calc(8.11% + 5px), #fff 91.89%, hsla(0,0%,100%,0)) !important;
- }
- /*底部声明:改为导航栏占位*/
- .pStAbHgTdAlDVUlpMOGP {
- opacity: 0 !important;
- height: 5px !important;
- }
- .pStAbHgTdAlDVUlpMOGP > span {
- display: none;
- }
- /*斜体样式*/
- .flow-markdown-body em.proced{
- display: none !important;
- }
- .flow-markdown-body em.vel-em-action {
- display: block !important;
- clear: both !important;
- color: #FF69B4 !important;
- font-style: normal !important;
- }
- .flow-markdown-body em.vel-em-other {
- display: inline-block !important;
- clear: none !important;
- color: #FF69B4 !important;
- font-style: normal !important;
- }
- `;
- document.head.appendChild(style);
- let pendingNodes = new Array();
- let timer = null;
- let observer = new MutationObserver(mutations=>{
- mutations.forEach(mutation=>{
- if(mutation.type === 'childList' || mutation.type === "characterData"){
- let newPush = false;
- mutation.addedNodes.forEach((node)=>{
- if(node.matches && (node.matches(".vel-em-action") || node.matches(".vel-em-other"))) return;
- pendingNodes.push(node);
- newPush = true;
- })
- if(newPush) PostProc();
- }
- })
- });
- // 获取textnode
- function getTextNodes(ele) {
- if (ele.nodeType == 3) return [ele];
- const nodes = ele.childNodes;
- const textnodes = [];
- for (const i in nodes) {
- if (nodes[i].nodeType == 3) {
- textnodes.push(nodes[i]);
- } else {
- const r = getTextNodes(nodes[i]);
- for (const tn of r) {
- textnodes.push(tn);
- }
- }
- }
- return textnodes;
- }
- // 后处理
- function PostProc(delay = 50) {
- if(timer) clearTimeout(timer);
- timer = setTimeout(()=>{
- const _pendingNodes = [...new Set(pendingNodes)];
- let node;
- while(node = _pendingNodes.shift()) {
- if(!node.querySelectorAll) continue;
- if(node.textContent.match(/\*\([^\)]+?\)\*/)) {
- const nl = getTextNodes(node);
- for(const n of nl) {
- if(n.nodeValue.match(/\*\([^\)]+?\)\*/)){
- const newNode = document.createElement("span");
- newNode.innerHTML = n.nodeValue.replaceAll(/\*\(([^\)]+?)\)\*/g, `<em class="vel-em-action">$1</em>`);
- n.replaceWith(newNode);
- }
- }
- }else if(node.tagName.toLowerCase() == "em") {
- if(node.matches(".proced") || node.matches(".vel-em-action") || node.matches(".vel-em-other")) continue;
- if(node.textContent.match(/^[\((].+?[\))]$/)) {
- const em = document.createElement("em");
- em.textContent = node.textContent.replaceAll(/[\(\)()]/g,"");
- em.classList.add("vel-em-action");
- node.classList.add("proced");
- node.after(em);
- }
- else node.classList.add("vel-em-other");
- }else if(node.matches(".math-inline")){
- if(node.parentElement.querySelector(".vel-em-action")) continue;
- const em = document.createElement("em");
- em.textContent = node.textContent.replaceAll(/[\(\)()]/g,"");
- em.classList.add("vel-em-action");
- node.parentElement.classList.remove("vel-em-other");
- node.parentElement.classList.add("proced");
- node.parentElement.after(em);
- }else{
- node.querySelectorAll(`em:not(.vel-em-action, .vel-em-other)`).forEach(n=>{
- if(n.textContent.match(/^[\((].+?[\))]$/)) {
- if(n.parentElement.querySelector(".vel-em-action")) return;
- const em = document.createElement("em");
- em.textContent = n.textContent.replaceAll(/[\(\)()]/g,"");
- em.classList.add("vel-em-action");
- n.classList.add("proced");
- n.after(em);
- }
- else n.classList.add("vel-em-other");
- })
- }
- }
- }, delay);
- }
- const config = { childList: true, subtree: true,characterData: true };
- const targetNode = document.body;
- observer.observe(targetNode, config);
- })();