Greasy Fork is available in English.

HR助手

这是一个给妹崽使用的 HR 助手

// ==UserScript==
// @name         HR助手
// @namespace    npm/vite-plugin-monkey
// @version      0.0.4
// @author       monkey
// @description  这是一个给妹崽使用的 HR 助手
// @icon         
// @match        https://www.zhipin.com/web/chat/recommend
// @require      https://cdn.jsdelivr.net/npm/vue@3.2.47/dist/vue.global.prod.js
// @grant        GM_getValue
// @grant        GM_setValue
// ==/UserScript==

(n=>{const r=document.createElement("style");r.dataset.source="vite-plugin-monkey",r.textContent=n,document.head.append(r)})(' .mtgd-btn{display:flex;cursor:pointer;align-items:center;white-space:nowrap;border-radius:4px;border-style:none;--un-bg-opacity:1;background-color:rgba(242,244,247,var(--un-bg-opacity));padding:5px 10px}.record-container div:last-child{margin:0}.chat-global-entry{left:-356px}.mtgd .slider{position:absolute;left:0;top:0;height:100%;width:50%;border-radius:8px;background-color:#00a6a7;z-index:10;transition:transform .2s ease-in}.mtgd .nav-item{z-index:50;width:50%;display:flex;cursor:pointer;align-items:center;justify-content:center;grid-gap:10px;gap:10px;padding-top:4px;padding-bottom:4px}.mtgd .nav-wrapper{position:relative;display:flex;overflow:hidden;border-radius:8px;border:1px dashed #ccc}*,:before,:after{--un-rotate:0;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-scale-x:1;--un-scale-y:1;--un-scale-z:1;--un-skew-x:0;--un-skew-y:0;--un-translate-x:0;--un-translate-y:0;--un-translate-z:0;--un-pan-x: ;--un-pan-y: ;--un-pinch-zoom: ;--un-scroll-snap-strictness:proximity;--un-ordinal: ;--un-slashed-zero: ;--un-numeric-figure: ;--un-numeric-spacing: ;--un-numeric-fraction: ;--un-border-spacing-x:0;--un-border-spacing-y:0;--un-ring-offset-shadow:0 0 rgba(0,0,0,0);--un-ring-shadow:0 0 rgba(0,0,0,0);--un-shadow-inset: ;--un-shadow:0 0 rgba(0,0,0,0);--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgba(147,197,253,.5);--un-blur: ;--un-brightness: ;--un-contrast: ;--un-drop-shadow: ;--un-grayscale: ;--un-hue-rotate: ;--un-invert: ;--un-saturate: ;--un-sepia: ;--un-backdrop-blur: ;--un-backdrop-brightness: ;--un-backdrop-contrast: ;--un-backdrop-grayscale: ;--un-backdrop-hue-rotate: ;--un-backdrop-invert: ;--un-backdrop-opacity: ;--un-backdrop-saturate: ;--un-backdrop-sepia: }::backdrop{--un-rotate:0;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-scale-x:1;--un-scale-y:1;--un-scale-z:1;--un-skew-x:0;--un-skew-y:0;--un-translate-x:0;--un-translate-y:0;--un-translate-z:0;--un-pan-x: ;--un-pan-y: ;--un-pinch-zoom: ;--un-scroll-snap-strictness:proximity;--un-ordinal: ;--un-slashed-zero: ;--un-numeric-figure: ;--un-numeric-spacing: ;--un-numeric-fraction: ;--un-border-spacing-x:0;--un-border-spacing-y:0;--un-ring-offset-shadow:0 0 rgba(0,0,0,0);--un-ring-shadow:0 0 rgba(0,0,0,0);--un-shadow-inset: ;--un-shadow:0 0 rgba(0,0,0,0);--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgba(147,197,253,.5);--un-blur: ;--un-brightness: ;--un-contrast: ;--un-drop-shadow: ;--un-grayscale: ;--un-hue-rotate: ;--un-invert: ;--un-saturate: ;--un-sepia: ;--un-backdrop-blur: ;--un-backdrop-brightness: ;--un-backdrop-contrast: ;--un-backdrop-grayscale: ;--un-backdrop-hue-rotate: ;--un-backdrop-invert: ;--un-backdrop-opacity: ;--un-backdrop-saturate: ;--un-backdrop-sepia: }.absolute{position:absolute}.relative{position:relative}.bottom-0{bottom:0}.left-0{left:0}.z-50{z-index:50}.mx-auto,[mx-auto=""]{margin-left:auto;margin-right:auto}.mb-10px,[mb-10px=""]{margin-bottom:10px}.box-border{box-sizing:border-box}.h-\\[calc\\(100vh-180px\\)\\]{height:calc(100vh - 180px)}.h-full,[h-full=""]{height:100%}.w-\\[50\\%\\]{width:50%}[w~="100%"]{width:100%}[w~="3em"]{width:3em}.flex,[flex=""]{display:flex}.flex-col,[flex-col=""]{flex-direction:column}.transform{transform:translate(var(--un-translate-x)) translateY(var(--un-translate-y)) translateZ(var(--un-translate-z)) rotate(var(--un-rotate)) rotateX(var(--un-rotate-x)) rotateY(var(--un-rotate-y)) rotate(var(--un-rotate-z)) skew(var(--un-skew-x)) skewY(var(--un-skew-y)) scaleX(var(--un-scale-x)) scaleY(var(--un-scale-y)) scaleZ(var(--un-scale-z))}.cursor-default,[cursor-default=""]{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;user-select:none}.items-start,[items-start=""]{align-items:flex-start}.items-center{align-items:center}.justify-center,[justify-center=""]{justify-content:center}.gap-10px,[gap-10px=""]{grid-gap:10px;gap:10px}.gap-4px{grid-gap:4px;gap:4px}.gap-8px{grid-gap:8px;gap:8px}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.whitespace-nowrap{white-space:nowrap}.border,[border~="1px"]{border-width:1px}[border~="[#eeeeee]"]{--un-border-opacity:1;border-color:rgba(238,238,238,var(--un-border-opacity))}.focus\\:border-\\[\\#00bebd\\]:focus{--un-border-opacity:1;border-color:rgba(0,190,189,var(--un-border-opacity))}.rounded{border-radius:.25rem}.rounded-4px,[rounded~="4px"]{border-radius:4px}.rounded-8px{border-radius:8px}.border-none{border-style:none}.bg-\\[\\#F2F4F7\\]{--un-bg-opacity:1;background-color:rgba(242,244,247,var(--un-bg-opacity))}.p-10px{padding:10px}.px{padding-left:1rem;padding-right:1rem}.px-10px{padding-left:10px;padding-right:10px}.px-20px,[px-20px=""]{padding-left:20px;padding-right:20px}.px-7px{padding-left:7px;padding-right:7px}.py{padding-top:1rem;padding-bottom:1rem}.py-4px{padding-top:4px;padding-bottom:4px}.py-5px{padding-top:5px;padding-bottom:5px}[px~="8px"]{padding-left:8px;padding-right:8px}[py~="3px"]{padding-top:3px;padding-bottom:3px}.pb-10px{padding-bottom:10px}.text-14px{font-size:14px}.text-16px{font-size:16px}.text-20px{font-size:20px}.text-32px,[text-32px=""]{font-size:32px}.font-bold{font-weight:700}.leading-24px{line-height:24px}.text-\\[\\#00A6A7\\]{--un-text-opacity:1;color:rgba(0,166,167,var(--un-text-opacity))}.text-\\[\\#ffffff\\]{--un-text-opacity:1;color:rgba(255,255,255,var(--un-text-opacity))}[text~="[#999999]"]{--un-text-opacity:1;color:rgba(153,153,153,var(--un-text-opacity))}.shadow{--un-shadow:var(--un-shadow-inset) 0 1px 3px 0 var(--un-shadow-color, rgba(0,0,0,.1)),var(--un-shadow-inset) 0 1px 2px -1px var(--un-shadow-color, rgba(0,0,0,.1));box-shadow:var(--un-ring-offset-shadow),var(--un-ring-shadow),var(--un-shadow)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)} ');

(function (vue) {
  'use strict';

  var _GM_getValue = /* @__PURE__ */ (() => typeof GM_getValue != "undefined" ? GM_getValue : void 0)();
  var _GM_setValue = /* @__PURE__ */ (() => typeof GM_setValue != "undefined" ? GM_setValue : void 0)();
  const useChat = () => {
    const content = vue.ref("");
    const apiKey = _GM_getValue("apiKey");
    const messages = vue.ref([]);
    function generatePayload(messages2) {
      return {
        headers: {
          "Content-Type": "application/json",
          "Authorization": `Bearer ${apiKey}`
        },
        method: "POST",
        body: JSON.stringify({
          model: "gpt-3.5-turbo",
          messages: messages2,
          temperature: 0.6,
          stream: true
        })
      };
    }
    async function send(message) {
      messages.value.push({ role: "user", content: message });
      const initOptions = generatePayload(messages.value);
      await fetch("https://api.openai.com/v1/chat/completions", initOptions).then((response) => {
        var _a;
        messages.value.push({ role: "assistant", content: "" });
        content.value = "";
        const reader = (_a = response.body) == null ? void 0 : _a.getReader();
        let isClose = false;
        return new ReadableStream({
          start(controller) {
            updateContent();
            function updateContent() {
              const decoder = new TextDecoder();
              reader == null ? void 0 : reader.read().then(({ done, value }) => {
                const text = decoder.decode(value);
                const match = text.match(/data: (.*)/g);
                match == null ? void 0 : match.forEach((item) => {
                  var _a2, _b, _c;
                  const data = (_a2 = /data: (.*)/.exec(item)) == null ? void 0 : _a2[1];
                  if (data === "[DONE]") {
                    isClose = true;
                    controller.close();
                    return;
                  }
                  const json = JSON.parse(data || "{}");
                  messages.value[messages.value.length - 1].content += ((_b = json.choices[0].delta) == null ? void 0 : _b.content) || "";
                  content.value += ((_c = json.choices[0].delta) == null ? void 0 : _c.content) || "";
                });
                if (isClose)
                  return;
                updateContent();
              });
            }
          }
        });
      });
    }
    return { content, send, messages };
  };
  const _hoisted_1 = { class: "mtgd" };
  const _hoisted_2 = { class: "nav px-10px" };
  const _hoisted_3 = { class: "nav-wrapper" };
  const _hoisted_4 = /* @__PURE__ */ vue.createElementVNode("span", { class: "text-16px" }, "🤖", -1);
  const _hoisted_5 = /* @__PURE__ */ vue.createElementVNode("span", { class: "text-16px" }, "🐻", -1);
  const _hoisted_6 = {
    key: 0,
    class: "record-container h-[calc(100vh-180px)] overflow-auto p-10px"
  };
  const _hoisted_7 = /* @__PURE__ */ vue.createStaticVNode('<div class="flex flex-col justify-center items-start gap-10px h-full"><div class="text-32px mx-auto mb-10px"> 🤖 </div><div class="mtgd-btn cursor-default mx-auto">我是 Chatgpt,来聊天吧!</div><div class="mx-auto">✨ 使用步骤如下:</div><div class="px-20px">1. 请在下方输入框填写你的 openai key</div><div class="px-20px">2. 点击确定后即可开始聊天</div></div>', 1);
  const _hoisted_8 = [
    _hoisted_7
  ];
  const _hoisted_9 = {
    key: 1,
    class: "record-container h-[calc(100vh-180px)] overflow-auto p-10px"
  };
  const _hoisted_10 = /* @__PURE__ */ vue.createStaticVNode('<div class="flex flex-col justify-center items-start gap-10px h-full"><div class="text-32px mx-auto mb-10px"> 🤖 </div><div class="mtgd-btn cursor-default mx-auto">我是 Chatgpt,来聊天吧!</div><div class="mx-auto">✨ 你可以跟我聊啥:</div><div class="px-20px">1. 你想不到的,想得到的,都可以问我</div><div class="px-20px">2. 我猜测你应该是一个 HR,你可以问我招聘相关的知识</div></div>', 1);
  const _hoisted_11 = [
    _hoisted_10
  ];
  const _hoisted_12 = { class: "message-container h-[calc(100vh-180px)] overflow-auto p-10px" };
  const _hoisted_13 = { class: "shadow rounded-8px overflow-hidden mb-10px px-7px py-4px" };
  const _hoisted_14 = { class: "text-20px leading-24px select-none" };
  const _hoisted_15 = /* @__PURE__ */ vue.createElementVNode("span", { class: "font-bold select-none" }, ": ", -1);
  const _hoisted_16 = { class: "text-14px leading-24px" };
  const _hoisted_17 = {
    key: 2,
    class: "absolute left-0 bottom-0 box-border"
  };
  const _hoisted_18 = { class: "flex items-center gap-8px px-10px pb-10px" };
  const _hoisted_19 = {
    key: 3,
    class: "absolute left-0 bottom-0 box-border"
  };
  const _hoisted_20 = { class: "flex items-center gap-8px px-10px pb-10px" };
  const _hoisted_21 = ["onKeyup"];
  const _hoisted_22 = /* @__PURE__ */ vue.createElementVNode("button", { class: "mtgd-btn" }, " Clear ", -1);
  const _hoisted_23 = {
    key: 0,
    class: "flex flex-col justify-center items-start gap-10px h-full"
  };
  const _hoisted_24 = /* @__PURE__ */ vue.createElementVNode("div", { class: "text-32px mx-auto mb-10px" }, " 🐻 ", -1);
  const _hoisted_25 = /* @__PURE__ */ vue.createElementVNode("div", { class: "mx-auto" }, "✨ 使用步骤如下:", -1);
  const _hoisted_26 = /* @__PURE__ */ vue.createElementVNode("div", { class: "px-20px" }, "1. 左输入框设置需要本熊打的招呼数,默认是20", -1);
  const _hoisted_27 = /* @__PURE__ */ vue.createElementVNode("div", { class: "px-20px" }, "2. 右输入框可以设置关键词,如需设置多个关键词请用、分隔", -1);
  const _hoisted_28 = /* @__PURE__ */ vue.createElementVNode("div", { class: "px-20px" }, "3. 点击 Greet,熊熊将为你做牛做马(指打招呼 🙈)!", -1);
  const _hoisted_29 = { class: "shadow rounded-8px overflow-hidden mb-10px px-7px py-4px" };
  const _hoisted_30 = /* @__PURE__ */ vue.createElementVNode("span", { class: "text-20px leading-24px select-none" }, "🐻", -1);
  const _hoisted_31 = /* @__PURE__ */ vue.createElementVNode("span", { class: "font-bold select-none" }, ": ", -1);
  const _hoisted_32 = {
    key: 0,
    class: "text-14px leading-24px"
  };
  const _hoisted_33 = { key: 1 };
  const _hoisted_34 = { class: "flex items-center gap-4px" };
  const _hoisted_35 = ["onClick"];
  const _hoisted_36 = { class: "absolute left-0 bottom-0 box-border" };
  const _hoisted_37 = { class: "px-10px mb-10px" };
  const _hoisted_38 = { class: "flex items-center gap-8px px-10px pb-10px" };
  const _hoisted_39 = ["onKeyup"];
  const _sfc_main = /* @__PURE__ */ vue.defineComponent({
    __name: "App",
    setup(__props) {
      const message = vue.ref("");
      const mutuguangda = vue.ref("一键打招呼 by mutuguangda");
      const isHasApiKey = vue.computed(() => !!_GM_getValue("apiKey"));
      const apiKey = vue.ref();
      const greetParams = vue.reactive({
        num: 20,
        keywords: ""
      });
      const greetRecord = vue.ref([]);
      const greetRecordWrapper = vue.ref();
      vue.watch(() => greetRecord, () => {
        var _a;
        console.log("greetRecordWrapper.value", greetRecordWrapper.value);
        (_a = greetRecordWrapper.value) == null ? void 0 : _a.scrollTo({ top: greetRecordWrapper.value.scrollHeight, behavior: "smooth" });
      }, { deep: true });
      const greetPerson = vue.ref([]);
      const { content, send, messages } = useChat();
      const isGreet = vue.ref(false);
      const activeIndex = vue.ref(1);
      function sendMessage() {
        send(message.value);
        message.value = "";
      }
      async function greet() {
        var _a, _b;
        let currentGreetNum = 0;
        let prevListLength = 0;
        isGreet.value = true;
        greetRecord.value.push("开始打招呼");
        while (isGreet.value) {
          const recommentList = (_b = (_a = document.querySelector("iframe")) == null ? void 0 : _a.contentDocument) == null ? void 0 : _b.querySelectorAll("#recommend-list ul li");
          if (!recommentList) {
            return;
          }
          for (let i = prevListLength; i < recommentList.length && isGreet.value; i++) {
            const curr = recommentList[i];
            scroll(curr.offsetTop);
            await sleep(0.2 * i);
            const html = curr.innerHTML;
            let keywords = greetParams.keywords.split("、");
            keywords = keywords.filter((keyword) => {
              return html.indexOf(keyword) !== -1;
            });
            if (keywords.length !== 0) {
              const button = curr.querySelector("button.btn.btn-greet:not(.overdue-tip)");
              if (!button)
                continue;
              if (!isGreet.value) {
                greetRecord.value.push("打招呼已结束 💕");
                greetRecord.value.push(greetPerson.value);
                return;
              }
              const nameWrapper = curr.querySelector(".name");
              const name = nameWrapper == null ? void 0 : nameWrapper.innerHTML;
              greetRecord.value.push(`${name}符合${keywords.join("、")}${keywords.length > 1 ? "等" : ""}关键字,正在打招呼 🙏 中...`);
              setStyle2(curr, {
                border: "2px solid #00bebd",
                borderRadius: "8px"
              });
              try {
                button.click();
                await sleep(0.3 * i);
                const dialog = document.querySelector('div.dialog-wrap.active[data-type="boss-dialog"]');
                if (dialog) {
                  greetRecord.value.push("招呼数已达上限!");
                  greetRecord.value.push("打招呼已结束 💕");
                  greetRecord.value.push(greetPerson.value);
                  return;
                }
              } catch (error) {
                greetRecord.value.push("我只是一个熊熊,什么都不知道,也许这是一个 BUG 🐛?");
                return;
              }
              const resumeWrapper = curr.querySelector("div > div");
              greetPerson.value.push({ keywords, element: curr, name, event: resumeWrapper.click, index: i, resumeWrapper });
              currentGreetNum++;
              if (currentGreetNum >= greetParams.num) {
                console.log("打招呼结束");
                isGreet.value = false;
                greetRecord.value.push("打招呼已结束 💕");
                greetRecord.value.push(greetPerson.value);
                return;
              }
            }
          }
          prevListLength = recommentList.length;
          if (!isGreet.value) {
            greetRecord.value.push("打招呼已结束 💕");
            greetRecord.value.push(greetPerson.value);
            return;
          }
        }
      }
      function scroll(top) {
        var _a, _b;
        const html = (_b = (_a = document.querySelector("iframe")) == null ? void 0 : _a.contentDocument) == null ? void 0 : _b.querySelector("html");
        html == null ? void 0 : html.scrollTo({ top, left: 0, behavior: "smooth" });
      }
      function sleep(t, fn = void 0) {
        return new Promise((resolve) => {
          setTimeout(() => {
            fn && fn();
            resolve();
          }, t * 1e3);
        });
      }
      function setStyle2(element, style) {
        Object.keys(style).forEach((key) => {
          element.style[key] = style[key];
        });
      }
      return (_ctx, _cache) => {
        return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
          vue.createElementVNode("div", _hoisted_2, [
            vue.createElementVNode("div", _hoisted_3, [
              vue.createElementVNode("div", {
                class: vue.normalizeClass(["nav-item", { "text-[#ffffff]": activeIndex.value === 0 }]),
                onClick: _cache[0] || (_cache[0] = ($event) => activeIndex.value = 0)
              }, [
                _hoisted_4,
                vue.createTextVNode("Chatgpt")
              ], 2),
              vue.createElementVNode("div", {
                class: vue.normalizeClass(["nav-item", { "text-[#ffffff]": activeIndex.value === 1 }]),
                onClick: _cache[1] || (_cache[1] = ($event) => activeIndex.value = 1)
              }, [
                _hoisted_5,
                vue.createTextVNode("打招呼")
              ], 2),
              vue.createElementVNode("div", {
                class: "slider",
                style: vue.normalizeStyle({ "transform": `translateX(${activeIndex.value === 0 ? "0" : "100%"})` })
              }, null, 4)
            ])
          ]),
          vue.withDirectives(vue.createElementVNode("div", null, [
            !vue.unref(isHasApiKey) && vue.unref(messages).length === 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6, _hoisted_8)) : vue.createCommentVNode("", true),
            vue.unref(isHasApiKey) && vue.unref(messages).length === 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_9, _hoisted_11)) : vue.createCommentVNode("", true),
            vue.createElementVNode("div", _hoisted_12, [
              (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(messages), (message2) => {
                return vue.openBlock(), vue.createElementBlock("div", _hoisted_13, [
                  vue.createElementVNode("div", null, [
                    vue.createElementVNode("span", _hoisted_14, vue.toDisplayString(message2.role === "user" ? "😀" : "🤖"), 1),
                    _hoisted_15,
                    vue.createElementVNode("span", _hoisted_16, vue.toDisplayString(message2.content), 1)
                  ])
                ]);
              }), 256))
            ]),
            !vue.unref(isHasApiKey) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_17, [
              vue.createElementVNode("div", _hoisted_18, [
                vue.withDirectives(vue.createElementVNode("input", {
                  "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => apiKey.value = $event),
                  class: "focus:border-[#00bebd]",
                  w: "100%",
                  px: "8px",
                  py: "3px",
                  rounded: "4px",
                  text: "[#999999]",
                  border: "1px [#eeeeee]",
                  onKeyup: _cache[3] || (_cache[3] = vue.withKeys(($event) => vue.unref(_GM_setValue)("apiKey", apiKey.value), ["enter"]))
                }, null, 544), [
                  [vue.vModelText, apiKey.value]
                ]),
                vue.createElementVNode("button", {
                  class: "mtgd-btn",
                  onClick: _cache[4] || (_cache[4] = ($event) => vue.unref(_GM_setValue)("apiKey", apiKey.value))
                }, " Confirm ")
              ])
            ])) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_19, [
              vue.createElementVNode("div", _hoisted_20, [
                vue.withDirectives(vue.createElementVNode("input", {
                  "onUpdate:modelValue": _cache[5] || (_cache[5] = ($event) => message.value = $event),
                  class: "focus:border-[#00bebd]",
                  w: "100%",
                  px: "8px",
                  py: "3px",
                  rounded: "4px",
                  text: "[#999999]",
                  border: "1px [#eeeeee]",
                  onKeyup: vue.withKeys(sendMessage, ["enter"])
                }, null, 40, _hoisted_21), [
                  [vue.vModelText, message.value]
                ]),
                vue.createElementVNode("button", {
                  class: "mtgd-btn",
                  onClick: sendMessage
                }, " Send "),
                _hoisted_22
              ])
            ]))
          ], 512), [
            [vue.vShow, activeIndex.value === 0]
          ]),
          vue.withDirectives(vue.createElementVNode("div", null, [
            vue.createElementVNode("div", {
              class: "record-container h-[calc(100vh-180px)] overflow-auto p-10px",
              ref_key: "greetRecordWrapper",
              ref: greetRecordWrapper
            }, [
              greetRecord.value.length === 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_23, [
                _hoisted_24,
                vue.createElementVNode("div", {
                  class: "mtgd-btn cursor-default mx-auto",
                  onMouseleave: _cache[6] || (_cache[6] = ($event) => mutuguangda.value = "一键打招呼"),
                  onMouseover: _cache[7] || (_cache[7] = ($event) => mutuguangda.value = "一键打招呼 by mutuguangda")
                }, vue.toDisplayString(mutuguangda.value), 33),
                _hoisted_25,
                _hoisted_26,
                _hoisted_27,
                _hoisted_28
              ])) : (vue.openBlock(true), vue.createElementBlock(vue.Fragment, { key: 1 }, vue.renderList(greetRecord.value, (message2) => {
                return vue.openBlock(), vue.createElementBlock("div", _hoisted_29, [
                  vue.createElementVNode("div", null, [
                    _hoisted_30,
                    _hoisted_31,
                    typeof message2 === "string" ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_32, vue.toDisplayString(message2), 1)) : vue.createCommentVNode("", true),
                    typeof message2 !== "string" ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_33, "总计打了" + vue.toDisplayString(greetPerson.value.length) + "个招呼,以下是人选记录:" + vue.toDisplayString(greetPerson.value.length ? "" : "无"), 1)) : vue.createCommentVNode("", true),
                    typeof message2 !== "string" ? (vue.openBlock(true), vue.createElementBlock(vue.Fragment, { key: 2 }, vue.renderList(message2, (person) => {
                      return vue.openBlock(), vue.createElementBlock("div", _hoisted_34, [
                        vue.createElementVNode("span", null, vue.toDisplayString(person.name), 1),
                        vue.createElementVNode("span", null, vue.toDisplayString(person.keywords.join("、")), 1),
                        vue.createElementVNode("span", {
                          onClick: ($event) => person.resumeWrapper.click(),
                          class: "text-[#00A6A7] cursor-pointer"
                        }, "点击查看简历信息", 8, _hoisted_35)
                      ]);
                    }), 256)) : vue.createCommentVNode("", true)
                  ])
                ]);
              }), 256))
            ], 512),
            vue.createElementVNode("div", _hoisted_36, [
              vue.withDirectives(vue.createElementVNode("div", _hoisted_37, [
                vue.createElementVNode("button", {
                  class: "mtgd-btn",
                  onClick: _cache[8] || (_cache[8] = ($event) => isGreet.value = false)
                }, "Stop")
              ], 512), [
                [vue.vShow, isGreet.value]
              ]),
              vue.createElementVNode("div", _hoisted_38, [
                vue.withDirectives(vue.createElementVNode("input", {
                  "onUpdate:modelValue": _cache[9] || (_cache[9] = ($event) => greetParams.num = $event),
                  type: "text",
                  class: "focus:border-[#00bebd]",
                  w: "3em",
                  px: "8px",
                  py: "3px",
                  rounded: "4px",
                  text: "[#999999]",
                  border: "1px [#eeeeee]"
                }, null, 512), [
                  [vue.vModelText, greetParams.num]
                ]),
                vue.withDirectives(vue.createElementVNode("input", {
                  "onUpdate:modelValue": _cache[10] || (_cache[10] = ($event) => greetParams.keywords = $event),
                  type: "text",
                  class: "focus:border-[#00bebd]",
                  w: "100%",
                  px: "8px",
                  py: "3px",
                  rounded: "4px",
                  text: "[#999999]",
                  border: "1px [#eeeeee]",
                  placeholder: "请输入关键词",
                  onKeyup: vue.withKeys(greet, ["enter"])
                }, null, 40, _hoisted_39), [
                  [vue.vModelText, greetParams.keywords]
                ]),
                vue.createElementVNode("button", {
                  class: "mtgd-btn",
                  onClick: greet
                }, "Greet")
              ])
            ])
          ], 512), [
            [vue.vShow, activeIndex.value === 1]
          ])
        ]);
      };
    }
  });
  setTimeout(() => {
    vue.createApp(_sfc_main).mount(
      (() => {
        const app = createElement("div", {
          width: "300px",
          position: "relative",
          overflow: "hidden"
          // padding: '10px',
        });
        const frame = document.querySelector("div.alive-frame-wrap.visible");
        const content = document.querySelector("#recommendContent");
        setStyle(frame, { display: "flex" });
        setStyle(content, { width: "calc(100% - 300px)" });
        frame.append(app);
        return app;
      })()
    );
  }, 5e3);
  function setStyle(element, style) {
    Object.keys(style).forEach((key) => {
      element.style[key] = style[key];
    });
  }
  function createElement(tagName, style = void 0) {
    const element = document.createElement(tagName);
    if (style)
      setStyle(element, style);
    return element;
  }

})(Vue);