Style for Coze Bot App mode

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);
})();