import { version, ref, watchEffect, watch, getCurrentInstance, defineComponent, hasInjectionContext, unref, inject, useSSRContext, createApp, effectScope, reactive, onUnmounted, nextTick, defineAsyncComponent, provide, onErrorCaptured, onServerPrefetch, createVNode, resolveDynamicComponent, toRef, h, isReadonly, isRef, isShallow, isReactive, toRaw, withCtx, createTextVNode, toDisplayString, mergeProps } from 'vue';
import { d as useRuntimeConfig$1, $ as $fetch, w as withQuery, l as hasProtocol, p as parseURL, m as isScriptProtocol, j as joinURL, h as createError$1, n as sanitizeStatusCode, o as createHooks, q as isEqual, r as stringifyParsedURL, t as stringifyQuery, v as parseQuery } from '../nitro/node-server.mjs';
import { getActiveHead } from 'unhead';
import { defineHeadPlugin, composableNames } from '@unhead/shared';
import { ssrRenderSuspense, ssrRenderComponent, ssrRenderVNode, ssrInterpolate, ssrRenderAttr, ssrRenderList, ssrRenderClass, ssrRenderStyle, ssrIncludeBooleanAttr } from 'vue/server-renderer';
import axios from 'axios';
import 'node:http';
import 'node:https';
import 'fs';
import 'path';
import 'node:fs';
import 'node:url';

function createContext$1(opts = {}) {
  let currentInstance;
  let isSingleton = false;
  const checkConflict = (instance) => {
    if (currentInstance && currentInstance !== instance) {
      throw new Error("Context conflict");
    }
  };
  let als;
  if (opts.asyncContext) {
    const _AsyncLocalStorage = opts.AsyncLocalStorage || globalThis.AsyncLocalStorage;
    if (_AsyncLocalStorage) {
      als = new _AsyncLocalStorage();
    } else {
      console.warn("[unctx] `AsyncLocalStorage` is not provided.");
    }
  }
  const _getCurrentInstance = () => {
    if (als && currentInstance === void 0) {
      const instance = als.getStore();
      if (instance !== void 0) {
        return instance;
      }
    }
    return currentInstance;
  };
  return {
    use: () => {
      const _instance = _getCurrentInstance();
      if (_instance === void 0) {
        throw new Error("Context is not available");
      }
      return _instance;
    },
    tryUse: () => {
      return _getCurrentInstance();
    },
    set: (instance, replace) => {
      if (!replace) {
        checkConflict(instance);
      }
      currentInstance = instance;
      isSingleton = true;
    },
    unset: () => {
      currentInstance = void 0;
      isSingleton = false;
    },
    call: (instance, callback) => {
      checkConflict(instance);
      currentInstance = instance;
      try {
        return als ? als.run(instance, callback) : callback();
      } finally {
        if (!isSingleton) {
          currentInstance = void 0;
        }
      }
    },
    async callAsync(instance, callback) {
      currentInstance = instance;
      const onRestore = () => {
        currentInstance = instance;
      };
      const onLeave = () => currentInstance === instance ? onRestore : void 0;
      asyncHandlers$1.add(onLeave);
      try {
        const r = als ? als.run(instance, callback) : callback();
        if (!isSingleton) {
          currentInstance = void 0;
        }
        return await r;
      } finally {
        asyncHandlers$1.delete(onLeave);
      }
    }
  };
}
function createNamespace$1(defaultOpts = {}) {
  const contexts = {};
  return {
    get(key, opts = {}) {
      if (!contexts[key]) {
        contexts[key] = createContext$1({ ...defaultOpts, ...opts });
      }
      contexts[key];
      return contexts[key];
    }
  };
}
const _globalThis$1 = typeof globalThis !== "undefined" ? globalThis : typeof self !== "undefined" ? self : typeof global !== "undefined" ? global : {};
const globalKey$2 = "__unctx__";
const defaultNamespace = _globalThis$1[globalKey$2] || (_globalThis$1[globalKey$2] = createNamespace$1());
const getContext = (key, opts = {}) => defaultNamespace.get(key, opts);
const asyncHandlersKey$1 = "__unctx_async_handlers__";
const asyncHandlers$1 = _globalThis$1[asyncHandlersKey$1] || (_globalThis$1[asyncHandlersKey$1] = /* @__PURE__ */ new Set());

const appConfig = useRuntimeConfig$1().app;
const baseURL = () => appConfig.baseURL;
if (!globalThis.$fetch) {
  globalThis.$fetch = $fetch.create({
    baseURL: baseURL()
  });
}
const nuxtAppCtx = /* @__PURE__ */ getContext("nuxt-app", {
  asyncContext: false
});
const NuxtPluginIndicator = "__nuxt_plugin";
function createNuxtApp(options) {
  let hydratingCount = 0;
  const nuxtApp = {
    _scope: effectScope(),
    provide: void 0,
    globalName: "nuxt",
    versions: {
      get nuxt() {
        return "3.8.2";
      },
      get vue() {
        return nuxtApp.vueApp.version;
      }
    },
    payload: reactive({
      data: {},
      state: {},
      _errors: {},
      ...{ serverRendered: true }
    }),
    static: {
      data: {}
    },
    runWithContext: (fn) => nuxtApp._scope.run(() => callWithNuxt(nuxtApp, fn)),
    isHydrating: false,
    deferHydration() {
      if (!nuxtApp.isHydrating) {
        return () => {
        };
      }
      hydratingCount++;
      let called = false;
      return () => {
        if (called) {
          return;
        }
        called = true;
        hydratingCount--;
        if (hydratingCount === 0) {
          nuxtApp.isHydrating = false;
          return nuxtApp.callHook("app:suspense:resolve");
        }
      };
    },
    _asyncDataPromises: {},
    _asyncData: {},
    _payloadRevivers: {},
    ...options
  };
  nuxtApp.hooks = createHooks();
  nuxtApp.hook = nuxtApp.hooks.hook;
  {
    const contextCaller = async function(hooks, args) {
      for (const hook of hooks) {
        await nuxtApp.runWithContext(() => hook(...args));
      }
    };
    nuxtApp.hooks.callHook = (name, ...args) => nuxtApp.hooks.callHookWith(contextCaller, name, ...args);
  }
  nuxtApp.callHook = nuxtApp.hooks.callHook;
  nuxtApp.provide = (name, value) => {
    const $name = "$" + name;
    defineGetter(nuxtApp, $name, value);
    defineGetter(nuxtApp.vueApp.config.globalProperties, $name, value);
  };
  defineGetter(nuxtApp.vueApp, "$nuxt", nuxtApp);
  defineGetter(nuxtApp.vueApp.config.globalProperties, "$nuxt", nuxtApp);
  {
    if (nuxtApp.ssrContext) {
      nuxtApp.ssrContext.nuxt = nuxtApp;
      nuxtApp.ssrContext._payloadReducers = {};
      nuxtApp.payload.path = nuxtApp.ssrContext.url;
    }
    nuxtApp.ssrContext = nuxtApp.ssrContext || {};
    if (nuxtApp.ssrContext.payload) {
      Object.assign(nuxtApp.payload, nuxtApp.ssrContext.payload);
    }
    nuxtApp.ssrContext.payload = nuxtApp.payload;
    nuxtApp.ssrContext.config = {
      public: options.ssrContext.runtimeConfig.public,
      app: options.ssrContext.runtimeConfig.app
    };
  }
  const runtimeConfig = options.ssrContext.runtimeConfig;
  nuxtApp.provide("config", runtimeConfig);
  return nuxtApp;
}
async function applyPlugin(nuxtApp, plugin) {
  if (plugin.hooks) {
    nuxtApp.hooks.addHooks(plugin.hooks);
  }
  if (typeof plugin === "function") {
    const { provide: provide2 } = await nuxtApp.runWithContext(() => plugin(nuxtApp)) || {};
    if (provide2 && typeof provide2 === "object") {
      for (const key in provide2) {
        nuxtApp.provide(key, provide2[key]);
      }
    }
  }
}
async function applyPlugins(nuxtApp, plugins2) {
  var _a, _b;
  const parallels = [];
  const errors = [];
  for (const plugin of plugins2) {
    if (((_a = nuxtApp.ssrContext) == null ? void 0 : _a.islandContext) && ((_b = plugin.env) == null ? void 0 : _b.islands) === false) {
      continue;
    }
    const promise = applyPlugin(nuxtApp, plugin);
    if (plugin.parallel) {
      parallels.push(promise.catch((e) => errors.push(e)));
    } else {
      await promise;
    }
  }
  await Promise.all(parallels);
  if (errors.length) {
    throw errors[0];
  }
}
/*! @__NO_SIDE_EFFECTS__ */
// @__NO_SIDE_EFFECTS__
function defineNuxtPlugin(plugin) {
  if (typeof plugin === "function") {
    return plugin;
  }
  delete plugin.name;
  return Object.assign(plugin.setup || (() => {
  }), plugin, { [NuxtPluginIndicator]: true });
}
function callWithNuxt(nuxt, setup, args) {
  const fn = () => args ? setup(...args) : setup();
  {
    return nuxt.vueApp.runWithContext(() => nuxtAppCtx.callAsync(nuxt, fn));
  }
}
/*! @__NO_SIDE_EFFECTS__ */
// @__NO_SIDE_EFFECTS__
function useNuxtApp() {
  var _a;
  let nuxtAppInstance;
  if (hasInjectionContext()) {
    nuxtAppInstance = (_a = getCurrentInstance()) == null ? void 0 : _a.appContext.app.$nuxt;
  }
  nuxtAppInstance = nuxtAppInstance || nuxtAppCtx.tryUse();
  if (!nuxtAppInstance) {
    {
      throw new Error("[nuxt] instance unavailable");
    }
  }
  return nuxtAppInstance;
}
/*! @__NO_SIDE_EFFECTS__ */
// @__NO_SIDE_EFFECTS__
function useRuntimeConfig() {
  return (/* @__PURE__ */ useNuxtApp()).$config;
}
function defineGetter(obj, key, val) {
  Object.defineProperty(obj, key, { get: () => val });
}
version.startsWith("3");
function resolveUnref(r) {
  return typeof r === "function" ? r() : unref(r);
}
function resolveUnrefHeadInput(ref2, lastKey = "") {
  if (ref2 instanceof Promise)
    return ref2;
  const root = resolveUnref(ref2);
  if (!ref2 || !root)
    return root;
  if (Array.isArray(root))
    return root.map((r) => resolveUnrefHeadInput(r, lastKey));
  if (typeof root === "object") {
    return Object.fromEntries(
      Object.entries(root).map(([k, v]) => {
        if (k === "titleTemplate" || k.startsWith("on"))
          return [k, unref(v)];
        return [k, resolveUnrefHeadInput(v, k)];
      })
    );
  }
  return root;
}
defineHeadPlugin({
  hooks: {
    "entries:resolve": function(ctx) {
      for (const entry2 of ctx.entries)
        entry2.resolvedInput = resolveUnrefHeadInput(entry2.input);
    }
  }
});
const headSymbol = "usehead";
const _global = typeof globalThis !== "undefined" ? globalThis : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
const globalKey$1 = "__unhead_injection_handler__";
function setHeadInjectionHandler(handler) {
  _global[globalKey$1] = handler;
}
function injectHead() {
  if (globalKey$1 in _global) {
    return _global[globalKey$1]();
  }
  const head = inject(headSymbol);
  if (!head && "production" !== "production")
    console.warn("Unhead is missing Vue context, falling back to shared context. This may have unexpected results.");
  return head || getActiveHead();
}
function useHead(input, options = {}) {
  const head = options.head || injectHead();
  if (head) {
    if (!head.ssr)
      return clientUseHead(head, input, options);
    return head.push(input, options);
  }
}
function clientUseHead(head, input, options = {}) {
  const deactivated = ref(false);
  const resolvedInput = ref({});
  watchEffect(() => {
    resolvedInput.value = deactivated.value ? {} : resolveUnrefHeadInput(input);
  });
  const entry2 = head.push(resolvedInput.value, options);
  watch(resolvedInput, (e) => {
    entry2.patch(e);
  });
  getCurrentInstance();
  return entry2;
}
const coreComposableNames = [
  "injectHead"
];
({
  "@unhead/vue": [...coreComposableNames, ...composableNames]
});
const unhead_KgADcZ0jPj = /* @__PURE__ */ defineNuxtPlugin({
  name: "nuxt:head",
  enforce: "pre",
  setup(nuxtApp) {
    const head = nuxtApp.ssrContext.head;
    setHeadInjectionHandler(
      // need a fresh instance of the nuxt app to avoid parallel requests interfering with each other
      () => (/* @__PURE__ */ useNuxtApp()).vueApp._context.provides.usehead
    );
    nuxtApp.vueApp.use(head);
  }
});
const PageRouteSymbol = Symbol("route");
const useRouter = () => {
  var _a;
  return (_a = /* @__PURE__ */ useNuxtApp()) == null ? void 0 : _a.$router;
};
const useRoute = () => {
  if (hasInjectionContext()) {
    return inject(PageRouteSymbol, (/* @__PURE__ */ useNuxtApp())._route);
  }
  return (/* @__PURE__ */ useNuxtApp())._route;
};
/*! @__NO_SIDE_EFFECTS__ */
// @__NO_SIDE_EFFECTS__
function defineNuxtRouteMiddleware(middleware) {
  return middleware;
}
const isProcessingMiddleware = () => {
  try {
    if ((/* @__PURE__ */ useNuxtApp())._processingMiddleware) {
      return true;
    }
  } catch {
    return true;
  }
  return false;
};
const navigateTo = (to, options) => {
  if (!to) {
    to = "/";
  }
  const toPath = typeof to === "string" ? to : withQuery(to.path || "/", to.query || {}) + (to.hash || "");
  if (options == null ? void 0 : options.open) {
    return Promise.resolve();
  }
  const isExternal = (options == null ? void 0 : options.external) || hasProtocol(toPath, { acceptRelative: true });
  if (isExternal) {
    if (!(options == null ? void 0 : options.external)) {
      throw new Error("Navigating to an external URL is not allowed by default. Use `navigateTo(url, { external: true })`.");
    }
    const protocol = parseURL(toPath).protocol;
    if (protocol && isScriptProtocol(protocol)) {
      throw new Error(`Cannot navigate to a URL with '${protocol}' protocol.`);
    }
  }
  const inMiddleware = isProcessingMiddleware();
  const router = useRouter();
  const nuxtApp = /* @__PURE__ */ useNuxtApp();
  {
    if (nuxtApp.ssrContext) {
      const fullPath = typeof to === "string" || isExternal ? toPath : router.resolve(to).fullPath || "/";
      const location2 = isExternal ? toPath : joinURL((/* @__PURE__ */ useRuntimeConfig()).app.baseURL, fullPath);
      const redirect = async function(response) {
        await nuxtApp.callHook("app:redirected");
        const encodedLoc = location2.replace(/"/g, "%22");
        nuxtApp.ssrContext._renderResponse = {
          statusCode: sanitizeStatusCode((options == null ? void 0 : options.redirectCode) || 302, 302),
          body: `<!DOCTYPE html><html><head><meta http-equiv="refresh" content="0; url=${encodedLoc}"></head></html>`,
          headers: { location: location2 }
        };
        return response;
      };
      if (!isExternal && inMiddleware) {
        router.afterEach((final) => final.fullPath === fullPath ? redirect(false) : void 0);
        return to;
      }
      return redirect(!inMiddleware ? void 0 : (
        /* abort route navigation */
        false
      ));
    }
  }
  if (isExternal) {
    nuxtApp._scope.stop();
    if (options == null ? void 0 : options.replace) {
      location.replace(toPath);
    } else {
      location.href = toPath;
    }
    if (inMiddleware) {
      if (!nuxtApp.isHydrating) {
        return false;
      }
      return new Promise(() => {
      });
    }
    return Promise.resolve();
  }
  return (options == null ? void 0 : options.replace) ? router.replace(to) : router.push(to);
};
const useError = () => toRef((/* @__PURE__ */ useNuxtApp()).payload, "error");
const showError = (_err) => {
  const err = createError(_err);
  try {
    const nuxtApp = /* @__PURE__ */ useNuxtApp();
    const error = useError();
    if (false)
      ;
    error.value = error.value || err;
  } catch {
    throw err;
  }
  return err;
};
const isNuxtError = (err) => !!(err && typeof err === "object" && "__nuxt_error" in err);
const createError = (err) => {
  const _err = createError$1(err);
  _err.__nuxt_error = true;
  return _err;
};
function createContext(opts = {}) {
  let currentInstance;
  let isSingleton = false;
  const checkConflict = (instance) => {
    if (currentInstance && currentInstance !== instance) {
      throw new Error("Context conflict");
    }
  };
  let als;
  if (opts.asyncContext) {
    const _AsyncLocalStorage = opts.AsyncLocalStorage || globalThis.AsyncLocalStorage;
    if (_AsyncLocalStorage) {
      als = new _AsyncLocalStorage();
    } else {
      console.warn("[unctx] `AsyncLocalStorage` is not provided.");
    }
  }
  const _getCurrentInstance = () => {
    if (als && currentInstance === void 0) {
      const instance = als.getStore();
      if (instance !== void 0) {
        return instance;
      }
    }
    return currentInstance;
  };
  return {
    use: () => {
      const _instance = _getCurrentInstance();
      if (_instance === void 0) {
        throw new Error("Context is not available");
      }
      return _instance;
    },
    tryUse: () => {
      return _getCurrentInstance();
    },
    set: (instance, replace) => {
      if (!replace) {
        checkConflict(instance);
      }
      currentInstance = instance;
      isSingleton = true;
    },
    unset: () => {
      currentInstance = void 0;
      isSingleton = false;
    },
    call: (instance, callback) => {
      checkConflict(instance);
      currentInstance = instance;
      try {
        return als ? als.run(instance, callback) : callback();
      } finally {
        if (!isSingleton) {
          currentInstance = void 0;
        }
      }
    },
    async callAsync(instance, callback) {
      currentInstance = instance;
      const onRestore = () => {
        currentInstance = instance;
      };
      const onLeave = () => currentInstance === instance ? onRestore : void 0;
      asyncHandlers.add(onLeave);
      try {
        const r = als ? als.run(instance, callback) : callback();
        if (!isSingleton) {
          currentInstance = void 0;
        }
        return await r;
      } finally {
        asyncHandlers.delete(onLeave);
      }
    }
  };
}
function createNamespace(defaultOpts = {}) {
  const contexts = {};
  return {
    get(key, opts = {}) {
      if (!contexts[key]) {
        contexts[key] = createContext({ ...defaultOpts, ...opts });
      }
      contexts[key];
      return contexts[key];
    }
  };
}
const _globalThis = typeof globalThis !== "undefined" ? globalThis : typeof self !== "undefined" ? self : typeof global !== "undefined" ? global : {};
const globalKey = "__unctx__";
_globalThis[globalKey] || (_globalThis[globalKey] = createNamespace());
const asyncHandlersKey = "__unctx_async_handlers__";
const asyncHandlers = _globalThis[asyncHandlersKey] || (_globalThis[asyncHandlersKey] = /* @__PURE__ */ new Set());
const manifest_45route_45rule = /* @__PURE__ */ defineNuxtRouteMiddleware(async (to) => {
  {
    return;
  }
});
const globalMiddleware = [
  manifest_45route_45rule
];
function getRouteFromPath(fullPath) {
  if (typeof fullPath === "object") {
    fullPath = stringifyParsedURL({
      pathname: fullPath.path || "",
      search: stringifyQuery(fullPath.query || {}),
      hash: fullPath.hash || ""
    });
  }
  const url = parseURL(fullPath.toString());
  return {
    path: url.pathname,
    fullPath,
    query: parseQuery(url.search),
    hash: url.hash,
    // stub properties for compat with vue-router
    params: {},
    name: void 0,
    matched: [],
    redirectedFrom: void 0,
    meta: {},
    href: fullPath
  };
}
const router_CaKIoANnI2 = /* @__PURE__ */ defineNuxtPlugin({
  name: "nuxt:router",
  enforce: "pre",
  setup(nuxtApp) {
    const initialURL = nuxtApp.ssrContext.url;
    const routes = [];
    const hooks = {
      "navigate:before": [],
      "resolve:before": [],
      "navigate:after": [],
      error: []
    };
    const registerHook = (hook, guard) => {
      hooks[hook].push(guard);
      return () => hooks[hook].splice(hooks[hook].indexOf(guard), 1);
    };
    (/* @__PURE__ */ useRuntimeConfig()).app.baseURL;
    const route = reactive(getRouteFromPath(initialURL));
    async function handleNavigation(url, replace) {
      try {
        const to = getRouteFromPath(url);
        for (const middleware of hooks["navigate:before"]) {
          const result = await middleware(to, route);
          if (result === false || result instanceof Error) {
            return;
          }
          if (typeof result === "string" && result.length) {
            return handleNavigation(result, true);
          }
        }
        for (const handler of hooks["resolve:before"]) {
          await handler(to, route);
        }
        Object.assign(route, to);
        if (false)
          ;
        for (const middleware of hooks["navigate:after"]) {
          await middleware(to, route);
        }
      } catch (err) {
        for (const handler of hooks.error) {
          await handler(err);
        }
      }
    }
    const router = {
      currentRoute: route,
      isReady: () => Promise.resolve(),
      // These options provide a similar API to vue-router but have no effect
      options: {},
      install: () => Promise.resolve(),
      // Navigation
      push: (url) => handleNavigation(url),
      replace: (url) => handleNavigation(url),
      back: () => window.history.go(-1),
      go: (delta) => window.history.go(delta),
      forward: () => window.history.go(1),
      // Guards
      beforeResolve: (guard) => registerHook("resolve:before", guard),
      beforeEach: (guard) => registerHook("navigate:before", guard),
      afterEach: (guard) => registerHook("navigate:after", guard),
      onError: (handler) => registerHook("error", handler),
      // Routes
      resolve: getRouteFromPath,
      addRoute: (parentName, route2) => {
        routes.push(route2);
      },
      getRoutes: () => routes,
      hasRoute: (name) => routes.some((route2) => route2.name === name),
      removeRoute: (name) => {
        const index = routes.findIndex((route2) => route2.name === name);
        if (index !== -1) {
          routes.splice(index, 1);
        }
      }
    };
    nuxtApp.vueApp.component("RouterLink", {
      functional: true,
      props: {
        to: String,
        custom: Boolean,
        replace: Boolean,
        // Not implemented
        activeClass: String,
        exactActiveClass: String,
        ariaCurrentValue: String
      },
      setup: (props, { slots }) => {
        const navigate = () => handleNavigation(props.to, props.replace);
        return () => {
          var _a;
          const route2 = router.resolve(props.to);
          return props.custom ? (_a = slots.default) == null ? void 0 : _a.call(slots, { href: props.to, navigate, route: route2 }) : h("a", { href: props.to, onClick: (e) => {
            e.preventDefault();
            return navigate();
          } }, slots);
        };
      }
    });
    nuxtApp._route = route;
    nuxtApp._middleware = nuxtApp._middleware || {
      global: [],
      named: {}
    };
    const initialLayout = nuxtApp.payload.state._layout;
    nuxtApp.hooks.hookOnce("app:created", async () => {
      router.beforeEach(async (to, from) => {
        var _a;
        to.meta = reactive(to.meta || {});
        if (nuxtApp.isHydrating && initialLayout && !isReadonly(to.meta.layout)) {
          to.meta.layout = initialLayout;
        }
        nuxtApp._processingMiddleware = true;
        if (!((_a = nuxtApp.ssrContext) == null ? void 0 : _a.islandContext)) {
          const middlewareEntries = /* @__PURE__ */ new Set([...globalMiddleware, ...nuxtApp._middleware.global]);
          for (const middleware of middlewareEntries) {
            const result = await nuxtApp.runWithContext(() => middleware(to, from));
            {
              if (result === false || result instanceof Error) {
                const error = result || createError$1({
                  statusCode: 404,
                  statusMessage: `Page Not Found: ${initialURL}`
                });
                delete nuxtApp._processingMiddleware;
                return nuxtApp.runWithContext(() => showError(error));
              }
            }
            if (result === true) {
              continue;
            }
            if (result || result === false) {
              return result;
            }
          }
        }
      });
      router.afterEach(() => {
        delete nuxtApp._processingMiddleware;
      });
      await router.replace(initialURL);
      if (!isEqual(route.fullPath, initialURL)) {
        await nuxtApp.runWithContext(() => navigateTo(route.fullPath));
      }
    });
    return {
      provide: {
        route,
        router
      }
    };
  }
});
function definePayloadReducer(name, reduce) {
  {
    (/* @__PURE__ */ useNuxtApp()).ssrContext._payloadReducers[name] = reduce;
  }
}
const reducers = {
  NuxtError: (data) => isNuxtError(data) && data.toJSON(),
  EmptyShallowRef: (data) => isRef(data) && isShallow(data) && !data.value && (typeof data.value === "bigint" ? "0n" : JSON.stringify(data.value) || "_"),
  EmptyRef: (data) => isRef(data) && !data.value && (typeof data.value === "bigint" ? "0n" : JSON.stringify(data.value) || "_"),
  ShallowRef: (data) => isRef(data) && isShallow(data) && data.value,
  ShallowReactive: (data) => isReactive(data) && isShallow(data) && toRaw(data),
  Ref: (data) => isRef(data) && data.value,
  Reactive: (data) => isReactive(data) && toRaw(data)
};
const revive_payload_server_eJ33V7gbc6 = /* @__PURE__ */ defineNuxtPlugin({
  name: "nuxt:revive-payload:server",
  setup() {
    for (const reducer in reducers) {
      definePayloadReducer(reducer, reducers[reducer]);
    }
  }
});
const components_plugin_KR1HBZs4kY = /* @__PURE__ */ defineNuxtPlugin({
  name: "nuxt:global-components"
});
const plugins = [
  unhead_KgADcZ0jPj,
  router_CaKIoANnI2,
  revive_payload_server_eJ33V7gbc6,
  components_plugin_KR1HBZs4kY
];
const removeUndefinedProps = (props) => Object.fromEntries(Object.entries(props).filter(([, value]) => value !== void 0));
const setupForUseMeta = (metaFactory, renderChild) => (props, ctx) => {
  useHead(() => metaFactory({ ...removeUndefinedProps(props), ...ctx.attrs }, ctx));
  return () => {
    var _a, _b;
    return renderChild ? (_b = (_a = ctx.slots).default) == null ? void 0 : _b.call(_a) : null;
  };
};
const globalProps = {
  accesskey: String,
  autocapitalize: String,
  autofocus: {
    type: Boolean,
    default: void 0
  },
  class: [String, Object, Array],
  contenteditable: {
    type: Boolean,
    default: void 0
  },
  contextmenu: String,
  dir: String,
  draggable: {
    type: Boolean,
    default: void 0
  },
  enterkeyhint: String,
  exportparts: String,
  hidden: {
    type: Boolean,
    default: void 0
  },
  id: String,
  inputmode: String,
  is: String,
  itemid: String,
  itemprop: String,
  itemref: String,
  itemscope: String,
  itemtype: String,
  lang: String,
  nonce: String,
  part: String,
  slot: String,
  spellcheck: {
    type: Boolean,
    default: void 0
  },
  style: String,
  tabindex: String,
  title: String,
  translate: String
};
defineComponent({
  name: "NoScript",
  inheritAttrs: false,
  props: {
    ...globalProps,
    title: String,
    body: Boolean,
    renderPriority: [String, Number]
  },
  setup: setupForUseMeta((props, { slots }) => {
    var _a;
    const noscript = { ...props };
    const textContent = (((_a = slots.default) == null ? void 0 : _a.call(slots)) || []).filter(({ children }) => children).map(({ children }) => children).join("");
    if (textContent) {
      noscript.children = textContent;
    }
    return {
      noscript: [noscript]
    };
  })
});
defineComponent({
  // eslint-disable-next-line vue/no-reserved-component-names
  name: "Link",
  inheritAttrs: false,
  props: {
    ...globalProps,
    as: String,
    crossorigin: String,
    disabled: Boolean,
    fetchpriority: String,
    href: String,
    hreflang: String,
    imagesizes: String,
    imagesrcset: String,
    integrity: String,
    media: String,
    prefetch: {
      type: Boolean,
      default: void 0
    },
    referrerpolicy: String,
    rel: String,
    sizes: String,
    title: String,
    type: String,
    /** @deprecated **/
    methods: String,
    /** @deprecated **/
    target: String,
    body: Boolean,
    renderPriority: [String, Number]
  },
  setup: setupForUseMeta((link) => ({
    link: [link]
  }))
});
defineComponent({
  // eslint-disable-next-line vue/no-reserved-component-names
  name: "Base",
  inheritAttrs: false,
  props: {
    ...globalProps,
    href: String,
    target: String
  },
  setup: setupForUseMeta((base) => ({
    base
  }))
});
const Title = defineComponent({
  // eslint-disable-next-line vue/no-reserved-component-names
  name: "Title",
  inheritAttrs: false,
  setup: setupForUseMeta((_, { slots }) => {
    var _a, _b, _c;
    return {
      title: ((_c = (_b = (_a = slots.default) == null ? void 0 : _a.call(slots)) == null ? void 0 : _b[0]) == null ? void 0 : _c.children) || null
    };
  })
});
const Meta = defineComponent({
  // eslint-disable-next-line vue/no-reserved-component-names
  name: "Meta",
  inheritAttrs: false,
  props: {
    ...globalProps,
    charset: String,
    content: String,
    httpEquiv: String,
    name: String,
    body: Boolean,
    renderPriority: [String, Number]
  },
  setup: setupForUseMeta((props) => {
    const meta = { ...props };
    if (meta.httpEquiv) {
      meta["http-equiv"] = meta.httpEquiv;
      delete meta.httpEquiv;
    }
    return {
      meta: [meta]
    };
  })
});
defineComponent({
  // eslint-disable-next-line vue/no-reserved-component-names
  name: "Style",
  inheritAttrs: false,
  props: {
    ...globalProps,
    type: String,
    media: String,
    nonce: String,
    title: String,
    /** @deprecated **/
    scoped: {
      type: Boolean,
      default: void 0
    },
    body: Boolean,
    renderPriority: [String, Number]
  },
  setup: setupForUseMeta((props, { slots }) => {
    var _a, _b, _c;
    const style = { ...props };
    const textContent = (_c = (_b = (_a = slots.default) == null ? void 0 : _a.call(slots)) == null ? void 0 : _b[0]) == null ? void 0 : _c.children;
    if (textContent) {
      style.children = textContent;
    }
    return {
      style: [style]
    };
  })
});
const Head = defineComponent({
  // eslint-disable-next-line vue/no-reserved-component-names
  name: "Head",
  inheritAttrs: false,
  setup: (_props, ctx) => () => {
    var _a, _b;
    return (_b = (_a = ctx.slots).default) == null ? void 0 : _b.call(_a);
  }
});
defineComponent({
  // eslint-disable-next-line vue/no-reserved-component-names
  name: "Html",
  inheritAttrs: false,
  props: {
    ...globalProps,
    manifest: String,
    version: String,
    xmlns: String,
    renderPriority: [String, Number]
  },
  setup: setupForUseMeta((htmlAttrs) => ({ htmlAttrs }), true)
});
defineComponent({
  // eslint-disable-next-line vue/no-reserved-component-names
  name: "Body",
  inheritAttrs: false,
  props: {
    ...globalProps,
    renderPriority: [String, Number]
  },
  setup: setupForUseMeta((bodyAttrs) => ({ bodyAttrs }), true)
});
const _imports_0 = "" + __buildAssetsURL("logo.6622f82d.png");
const _imports_1 = "";
const _imports_2 = "";
const _imports_3 = "" + __buildAssetsURL("add-icon.0b0b5313.svg");
const _imports_4 = "";
const _imports_5 = "" + __buildAssetsURL("dot.1026a040.svg");
const _imports_6 = "";
const _imports_7 = "" + __buildAssetsURL("dot-yellow.4b5e135b.svg");
const _imports_8 = "" + __buildAssetsURL("dot-gray.86cdd7b5.svg");
const _imports_9 = "" + __buildAssetsURL("empty-icon.24a01ae2.svg");
const _imports_10 = "" + __buildAssetsURL("close-icon.86743366.svg");
const _imports_11 = "";
const _imports_12 = "";
const _imports_13 = "";
const _imports_14 = "" + __buildAssetsURL("edit-icon-white.29b27582.svg");
const _imports_15 = "";
const _imports_16 = "" + __buildAssetsURL("collect-icon-colours.6d2ade7f.svg");
const _imports_17 = "";
const _imports_18 = "";
const _imports_19 = "";
const _imports_20 = "" + __buildAssetsURL("title.98892974.png");
const _imports_21 = "";
const _imports_22 = "";
const _imports_23 = "";
const _imports_24 = "" + __buildAssetsURL("menu-icon-gray.d61f02b1.svg");
const _imports_25 = "" + __buildAssetsURL("comment-icon-gray.2c8779f9.svg");
const _imports_26 = "";
const _imports_27 = "";
const _imports_28 = "" + __buildAssetsURL("tick-no.179037b3.svg");
const _imports_29 = "" + __buildAssetsURL("tick-option.e092d22f.svg");
const _imports_30 = "" + __buildAssetsURL("QRCode-icon.a105d5fc.svg");
const _imports_31 = "" + __buildAssetsURL("delete-icon.4d386dce.svg");
const _imports_32 = "" + __buildAssetsURL("arrows-icon.271dd0d3.svg");
const _imports_33 = "" + __buildAssetsURL("tick-orange.233abc69.svg");
const _imports_34 = "" + __buildAssetsURL("issue-bj.44adad8c.svg");
const _export_sfc = (sfc, props) => {
  const target = sfc.__vccOpts || sfc;
  for (const [key, val] of props) {
    target[key] = val;
  }
  return target;
};
const _sfc_main$2 = {
  name: "#answer-app",
  async setup() {
    const $ajax = (url, data) => {
      url = url.indexOf("//") > -1 ? url : baseURL2 + url;
      return new Promise(function(resolve, reject) {
        axios.post(url, data, {
          emulateJSON: true,
          withCredentials: true,
          headers: {
            // authorization: "production" !== "production" && "9c92af854f552bbd2aab43230bcf8438", // 头部标记
            authorization: "production" !== "production" 
            // 头部标记 ada
            // authorization: "2e25ccc21d5f86b670e7476f3b58ea5d", // 头部标记
            // "Cache-Control": "no-cache",
            // Pragma: "no-cache",
          }
        }).then(function(res) {
          var data2 = null;
          try {
            data2 = typeof res.data == "string" ? JSON.parse(res.data) : res.data;
            if (data2["code"] == 401)
              isNeedLogin.value = true;
            if (data2["code"] != 200)
              handleMsg("error", data2["message"] || "报错了,请重试!!!");
          } catch (error) {
          }
          resolve(data2);
        }).catch((err) => {
          if (err.response.status == 401)
            isNeedLogin.value = true;
          resolve(err.response.data);
        });
      });
    };
    let isNeedLogin = ref(true);
    const goLogin = () => ajax_login();
    const route = useRoute();
    const baseURL2 = "https://ask.gter.net";
    let type = ref("list");
    let originUrl = ref("");
    onUnmounted(() => {
      window.removeEventListener("keydown", handleKeydown);
      window.removeEventListener("scroll", handleScroll);
    });
    const getCurrentUrl = () => {
      return window.location.href;
    };
    let myCount = ref({});
    const getUserData = (key) => {
      $ajax("/api/user").then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        myCount.value = data.count;
        handleMy(key);
      });
    };
    let isSearchMode = ref(false);
    const setHistoricalSearchList = () => {
      if (!keyword.value)
        return;
      historicalSearchList.value.unshift(keyword.value);
      historicalSearchList.value = [...new Set(historicalSearchList.value)];
      historicalSearchList.value = historicalSearchList.value.slice(0, 10);
      localStorage.setItem("historical-Search", JSON.stringify(historicalSearchList.value));
    };
    const searchClick = () => {
      setHistoricalSearchList();
      page = 1;
      list.value = [];
      type.value = "list";
      pitchIndex.value = null;
      replaceState({
        keyword: keyword.value
      });
      searchBlur();
      getList();
    };
    const searchFocus = () => {
      if (historicalSearchList.value.length == 0)
        return;
      historicalSearchState.value = true;
    };
    const searchBlur = () => {
      setTimeout(() => historicalSearchState.value = false, 300);
    };
    const handleClickHistoricalItem = (value) => {
      keyword.value = value;
      searchClick();
    };
    const handleClickClear = () => {
      keyword.value = "";
      page = 1;
      list.value = [];
      type.value = "list";
      pitchIndex.value = null;
      getList();
    };
    let historicalSearchState = ref(false);
    let historicalSearchList = ref([]);
    let tabListFixeState = ref(false);
    const handleScroll = () => {
      const scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
      const scrollHeight = document.documentElement.scrollHeight;
      const clientHeight = document.documentElement.clientHeight;
      if (scrollTop + clientHeight >= scrollHeight - 40 && type.value == "list")
        getList();
      if (scrollTop > 115)
        tabListFixeState.value = true;
      else
        tabListFixeState.value = false;
    };
    let keyword = ref("");
    let keywordText = ref("");
    let list = ref([]);
    let page = 1;
    let total = ref(0);
    let loading = ref(false);
    let inTheEndState = ref(false);
    let isListEmptyState = ref();
    const getList = () => {
      if (page == 0 || loading.value)
        return;
      loading.value = true;
      $ajax("/api/lists", {
        page,
        limit: 20,
        keyword: keyword.value,
        type: typePitch.value
      }).then((res) => {
        if (res.code == 401)
          goLogin();
        if (res.code != 200)
          return;
        let data = res.data;
        list.value = list.value.concat(data.data || []);
        total.value = data.count || 0;
        keywordText.value = keyword.value || "";
        if (list.value.length >= data["count"])
          page = 0;
        else
          page++;
        if (page == 0 && list.value.length != 0)
          inTheEndState.value = true;
        else
          inTheEndState.value = false;
        if (list.value.length == 0)
          isListEmptyState.value = true;
        else
          isListEmptyState.value = false;
        if (keyword.value)
          isSearchMode.value = true;
        else
          isSearchMode.value = false;
      }).finally(() => loading.value = false);
    };
    let typeList = ref([]);
    let typePitch = ref(null);
    let pageHeaderHeight = ref(0);
    let pageListHeight = ref(0);
    let detailsInfo = ref({});
    let detailsIsanswered = ref(0);
    let detailsIscollection = ref(0);
    let detailsIsmyself = ref(0);
    let detailsToken = "";
    let detailShare = ref({});
    let detailLoading = ref(false);
    const getDetails = (uniqid, index, isOpenAnswer) => {
      if (detailLoading.value)
        return;
      detailLoading.value = true;
      detailsInfo.value = {};
      answerList.value = [];
      answerPage.value = 0;
      $ajax("/api/details", { uniqid }).then((res) => {
        if (res.code != 200) {
          type.value = "list";
          pitchIndex.value = null;
          return;
        }
        let data = res.data;
        detailsInfo.value = data["info"] || {};
        detailsIsanswered.value = data["isanswered"] || 0;
        detailsIscollection.value = data["iscollection"] || 0;
        detailsIsmyself.value = data["ismyself"] || 0;
        detailsToken = data["token"] || "";
        detailShare.value = data["share"] || {};
        type.value = "details";
        if (index !== null && index !== void 0)
          cut(index);
        else
          calculateListIndex(data.info, uniqid);
        answerList.value = [];
        answerPage.value = 1;
        getAnswerList();
        closeAllTransmitState();
        if (isOpenAnswer)
          openIAnswer();
        seo.value = data.seo;
        yourAnswer.value = {
          text: "",
          anonymous: 0
        };
      }).finally(() => {
        detailLoading.value = false;
      });
    };
    const calculateListIndex = (info, uniqid) => {
      let targetList = [...list.value];
      if (targetList.length == 0 && isSearchMode.value == false) {
        setTimeout(() => calculateListIndex(info, uniqid), 200);
        return;
      }
      let valve = false;
      targetList.forEach((element, index) => {
        if (element["uniqid"] == uniqid) {
          cut(index);
          valve = true;
        }
      });
      if (!valve) {
        let content = "";
        if (info["content"].indexOf("<img") == -1)
          content = info["content"];
        list.value.unshift({
          answers: info["answers"],
          content,
          publicationdate: info["publicationdate"],
          title: info["title"],
          typename: info["typename"],
          uniqid
        });
        cut(0);
      }
    };
    let answerList = ref([]);
    let answerPage = ref(1);
    let answerLoading = false;
    const getAnswerList = () => {
      if (answerLoading || answerPage.value == 0)
        return;
      answerLoading = true;
      $ajax("/api/details/answerList", {
        token: detailsToken,
        limit: 20,
        page: answerPage.value
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        data.data.forEach((element) => {
          element["commentList"] = [];
        });
        answerList.value = answerList.value.concat(data.data);
        if (answerList.value.length == data["count"])
          answerPage.value = 0;
        else
          answerPage.value++;
        detailsInfo.value["answers"] = data["count"];
        if (pitchIndex.value !== null)
          list.value[pitchIndex.value]["answers"] = data["count"];
      }).finally(() => answerLoading = false);
    };
    const operateLike = (token, index) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      $ajax("/api/operate/like", {
        token
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        answerList.value[index]["islike"] = data["status"];
        answerList.value[index]["likenum"] = data["count"];
        handleMsg("success", res["message"] || "操作成功");
      });
    };
    const operateCollect = (token = detailsToken, index) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      $ajax("/api/operate/collect", {
        token
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        myCollectionPage = 1;
        myCollectionList.value = [];
        if (data["type"] == "askquestioncollection") {
          detailsIscollection.value = data["status"];
          detailsInfo.value["collectionnum"] = data["count"];
        } else {
          answerList.value[index]["iscollection"] = data["status"];
          answerList.value[index]["collectionnum"] = data["count"];
        }
        handleMsg("success", res["message"] || "操作成功");
        if (data["status"])
          myCount.value["collect"]++;
        else
          myCount.value["collect"]--;
      });
    };
    let IAnswerState = ref(false);
    let IAnswerEditState = ref(false);
    let IAnswerInfo = ref({});
    const openIAnswer = (index, type2) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      if (index == null) {
        IAnswerInfo.value = {
          title: detailsInfo.value["title"],
          content: detailsInfo.value["content"],
          anonymous: 0
        };
        IAnswerState.value = true;
        nextTick(() => handleInput());
      } else {
        if (type2 == "my") {
          IAnswerInfo.value = {
            title: detailsInfo.value["title"],
            ...myAnswerList.value[index],
            text: myAnswerList.value[index]["content"],
            content: detailsInfo.value["content"]
          };
          myType.value = "";
        } else {
          IAnswerInfo.value = {
            title: detailsInfo.value["title"],
            ...answerList.value[index],
            text: answerList.value[index]["content"],
            content: detailsInfo.value["content"]
          };
        }
        IAnswerEditState.value = true;
        nextTick(() => handleInput());
      }
    };
    const closeIAnswer = () => {
      IAnswerState.value = false;
      IAnswerEditState.value = false;
      isDirectlyListIAnswer = false;
    };
    const amendIAnswer = () => {
      IAnswerInfo.value["anonymous"] = IAnswerInfo.value["anonymous"] == 0 ? 1 : 0;
    };
    const submitAnswer = (type2) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      let questionTextarea = null;
      if (type2 == "you")
        questionTextarea = document.querySelector(".your-answer-textarea");
      else
        questionTextarea = document.querySelector(".question-textarea");
      if (questionTextarea)
        IAnswerInfo.value["text"] = questionTextarea.innerHTML;
      $ajax("/api/publish/answerSubmit", {
        token: IAnswerInfo.value["token"] || detailsToken,
        anonymous: IAnswerInfo.value["anonymous"] || 0,
        content: IAnswerInfo.value["text"]
      }).then((res) => {
        if (res.code != 200)
          return;
        if (isDirectlyListIAnswer) {
          getDetails(IAnswerInfo.value["uniqid"], IAnswerInfo.value["index"]);
          IAnswerState.value = false;
        } else {
          answerList.value = [];
          answerPage.value = 1;
          getAnswerList();
          closeIAnswer();
          if (!IAnswerInfo.value["token"])
            myCount.value["answer"]++;
          if (type2 == "you")
            questionTextarea.innerHTML = "";
        }
        handleMsg("success", res["message"] || "操作成功");
      });
    };
    const openCommentState = (index) => {
      if (answerList.value[index]["commentState"])
        answerList.value[index]["commentState"] = false;
      else
        answerList.value[index]["commentState"] = true;
      if (answerList.value[index]["commentList"].length == 0 && answerList.value[index]["commentnum"] != 0)
        getAnswerCommentList(index);
    };
    let answerCommentLimit = 3;
    const getAnswerCommentList = (index) => {
      getAnswerCommentPublic(index).then((res) => {
        let data = res.data;
        answerList.value[index]["commentList"] = answerList.value[index]["commentList"].concat(data.data);
        answerList.value[index]["commentCount"] = data["count"];
      });
    };
    const handleAllComment = (index) => {
      answerCommentLimit = 1e3;
      getAnswerCommentPublic(index).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        let slice3 = data.data.slice(3);
        let merged1 = [...answerList.value[index]["commentList"], ...slice3.filter((item2) => !answerList.value[index]["commentList"].find((item1) => item1.id == item2.id))];
        answerList.value[index]["commentList"] = merged1;
        handleMsg("success", res["message"] || "操作成功");
      });
    };
    const getAnswerCommentPublic = (index) => {
      return new Promise((resolve, reject) => {
        $ajax("/api/comment/lists", {
          token: answerList.value[index]["token"],
          limit: answerCommentLimit,
          childlimit: 1
        }).then((res) => {
          if (res.code != 200)
            return;
          resolve(res);
        });
      });
    };
    const submitAnswerComments = (index, ind, i) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      const targetAnswerList = [...answerList.value];
      let content = "";
      let parentid = null;
      let token = targetAnswerList[index]["token"];
      if (i != null) {
        content = targetAnswerList[index]["commentList"][ind]["child"][i]["commentInput"];
        parentid = targetAnswerList[index]["commentList"][ind]["child"][i]["id"];
      } else if (ind != null) {
        content = targetAnswerList[index]["commentList"][ind]["commentInput"];
        parentid = targetAnswerList[index]["commentList"][ind]["id"];
      } else
        content = targetAnswerList[index]["commentInput"];
      $ajax("/api/comment/submit", {
        content,
        token,
        parentid
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        if (i != null) {
          let targetData = {
            id: data["commentid"],
            content,
            isauthor: 1,
            islike: 0,
            likenum: 0,
            reply: {
              nickname: targetAnswerList[index]["commentList"][ind]["child"][i]["nickname"]
            },
            ...data
          };
          targetAnswerList[index]["commentList"][ind]["child"].unshift(targetData);
          targetAnswerList[index]["commentList"][ind]["childnum"]++;
        } else if (ind != null) {
          let targetData = {
            id: data["commentid"],
            content,
            isauthor: 1,
            islike: 0,
            likenum: 0,
            reply: [],
            ...data
          };
          targetAnswerList[index]["commentList"][ind]["child"].unshift(targetData);
          targetAnswerList[index]["commentList"][ind]["childnum"]++;
        } else {
          let targetData = {
            id: data["commentid"],
            content,
            isauthor: 1,
            islike: 0,
            likenum: 0,
            ...data,
            child: []
          };
          targetAnswerList[index]["commentList"].unshift(targetData);
          targetAnswerList[index]["commentCount"]++;
        }
        targetAnswerList[index]["commentnum"] = data["count"];
        closeAnswerCommentsChild();
        handleMsg("success", res["message"] || "操作成功");
      });
    };
    const operateAnswerCommentsLike = (token, index, ind, i) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      $ajax("/api/comment/like", {
        token
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        const targetAnswerList = [...answerList.value];
        if (i == null) {
          targetAnswerList[index]["commentList"][ind]["islike"] = data["status"];
          targetAnswerList[index]["commentList"][ind]["likenum"] = data["likenum"];
        } else {
          targetAnswerList[index]["commentList"][ind]["child"][i]["islike"] = data["status"];
          targetAnswerList[index]["commentList"][ind]["child"][i]["likenum"] = data["likenum"];
        }
        answerList.value = targetAnswerList;
        handleMsg("success", res["message"] || "操作成功");
      });
    };
    const openAnswerCommentsChild = (index, ind, i) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      closeAnswerCommentsChild();
      if (i == null)
        answerList.value[index].commentList[ind]["childState"] = true;
      else
        answerList.value[index].commentList[ind]["child"][i]["childState"] = true;
    };
    const closeAnswerCommentsChild = (index, ind, i) => {
      const targetAnswerList = [...answerList.value];
      targetAnswerList.forEach((element) => {
        if (element["commentList"] && element["commentList"].length != 0) {
          element["commentList"].forEach((ele) => {
            ele["childState"] = false;
            if (ele["child"] && ele["child"].length != 0) {
              ele["child"].forEach((el) => {
                el["childState"] = false;
              });
            }
          });
        }
      });
      answerList.value = targetAnswerList;
    };
    const alsoCommentsData = (index, ind) => {
      const targetAnswerList = [...answerList.value];
      const parentid = targetAnswerList[index]["commentList"][ind]["id"];
      const token = targetAnswerList[index]["token"];
      $ajax("/api/comment/childrenList", {
        token,
        parentid,
        limit: 20,
        page: 1,
        childlimit: 1
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        let merged1 = [...targetAnswerList[index]["commentList"][ind]["child"], ...data.data.filter((item2) => !targetAnswerList[index]["commentList"][ind]["child"].find((item1) => item1.id == item2.id))];
        targetAnswerList[index]["commentList"][ind]["child"] = merged1;
        answerList.value = targetAnswerList;
      });
    };
    let myType = ref("");
    const handleMy = (key) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      if (Object.keys(myCount.value).length === 0) {
        getUserData(key);
        return;
      }
      if (key == "collect") {
        myCollectionList.value = [];
        myCollectionPage = 1;
        getMyCollection();
      } else if (key == "answers") {
        myAnswerList.value = [];
        myAnswerPage = 1;
        getMyAnswer();
      } else if (key == "questions") {
        myQuestionsList.value = [];
        myQuestionsPage = 1;
        getMyQuestions();
      }
    };
    let myCollectionList = ref([]);
    let myCollectionCount = ref(0);
    let myCollectionPage = 1;
    let myCollectionLading = false;
    const getMyCollection = () => {
      if (myCollectionPage == 0 || myCollectionLading)
        return;
      myCollectionLading = true;
      $ajax("/api/user/collect", {
        limit: 20,
        page: myCollectionPage
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        myType.value = "collect";
        myCollectionList.value = myCollectionList.value.concat(data.data);
        myCollectionCount.value = data.count;
        if (myCollectionList.value.length != data["count"])
          myCollectionPage++;
        else
          myCollectionPage = 0;
      }).finally(() => myCollectionLading = false);
    };
    const cancelCollection = (token, index) => {
      $ajax("/api/user/deleteCollect", {
        token
      }).then((res) => {
        if (res.code == 200) {
          myCollectionList.value.splice(index, 1);
          myCollectionCount.value--;
          myCount.value["collect"]--;
          handleMsg("success", res["message"] || "操作成功");
        }
      });
    };
    const handleCollectionScroll = (e) => {
      const el = e.target;
      if (el.scrollHeight - el.scrollTop >= el.clientHeight + 10)
        return;
      getMyCollection();
    };
    let myAnswerList = ref([]);
    let myAnswerCount = ref(0);
    let myAnswerPage = 1;
    let myAnswerloadimg = false;
    const getMyAnswer = () => {
      if (myAnswerPage == 0 || myAnswerloadimg)
        return;
      myAnswerloadimg = true;
      $ajax("/api/user/answer", {
        limit: 20,
        page: myAnswerPage
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        data.data.forEach((element) => {
          element["popupState"] = false;
        });
        myAnswerList.value = myAnswerList.value.concat(data.data);
        myAnswerCount.value = data.count;
        if (myAnswerList.value.length != data["count"])
          myAnswerPage++;
        else
          myAnswerPage = 0;
        myType.value = "answers";
      }).finally(() => myAnswerloadimg = false);
    };
    const handleAnswersScroll = (e) => {
      const el = e.target;
      if (el.scrollHeight - el.scrollTop >= el.clientHeight + 10)
        return;
      getMyAnswer();
    };
    let answerIndexOld = null;
    const cutAnswerPopupState = (index) => {
      myAnswerList.value[index]["popupState"] = true;
      if (answerIndexOld == index) {
        myAnswerList.value[index]["popupState"] = false;
        answerIndexOld = null;
      } else {
        myAnswerList.value[index]["popupState"] = true;
        if (answerIndexOld != null)
          myAnswerList.value[answerIndexOld]["popupState"] = false;
        answerIndexOld = index;
      }
    };
    const changeAnonymous = (token, anonymous, index) => {
      $ajax("/api/publish/changeAnonymous", {
        token,
        anonymous
      }).then((res) => {
        if (res.code != 200)
          return;
        res.data;
        myAnswerList.value[index]["anonymous"] = anonymous;
        cutAnswerPopupState(index);
        handleMsg("success", res["message"] || "操作成功");
      });
    };
    let myQuestionsList = ref([]);
    let myQuestionsCount = ref(0);
    let myQuestionsPage = 0;
    let myQuestionsloading = false;
    const getMyQuestions = () => {
      if (myQuestionsPage == 0 || myQuestionsloading)
        return;
      myQuestionsloading = true;
      $ajax("/api/user/questions", {
        limit: 20,
        page: myQuestionsPage
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        myQuestionsList.value = myQuestionsList.value.concat(data.data);
        myQuestionsCount.value = data.count;
        myType.value = "questions";
        if (myQuestionsList.value.length != data["count"])
          myQuestionsPage++;
        else
          myQuestionsPage = 0;
      }).finally(() => myQuestionsloading = false);
    };
    const handleQuestionsScroll = (e) => {
      const el = e.target;
      if (el.scrollHeight - el.scrollTop >= el.clientHeight + 10)
        return;
      getMyQuestions();
    };
    let questionsIndexOld = null;
    const cutQuestionsPopupState = (index) => {
      myQuestionsList.value[index]["popupState"] = true;
      if (questionsIndexOld == index) {
        myQuestionsList.value[index]["popupState"] = false;
        questionsIndexOld = null;
      } else {
        myQuestionsList.value[index]["popupState"] = true;
        if (questionsIndexOld != null)
          myQuestionsList.value[questionsIndexOld]["popupState"] = false;
        questionsIndexOld = index;
      }
    };
    const changeAnonymousQuestions = (token, anonymous, index) => {
      $ajax("/api/publish/changeAnonymous", {
        token,
        anonymous
      }).then((res) => {
        if (res.code != 200)
          return;
        res.data;
        myQuestionsList.value[index]["anonymous"] = anonymous;
        cutQuestionsPopupState(index);
        handleMsg("success", res["message"] || "操作成功");
      });
    };
    let questionsSetp = ref(0);
    const cutQuestionsSetp = (value) => questionsSetp.value = value;
    let questionsTypeList = ref([]);
    let questionsObj = ref({
      // 提问的内容
      token: "",
      title: "",
      content: "",
      tags: "",
      tid: "",
      anonymous: 0
    });
    const questionsInit = () => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      $ajax("/api/publish/questions").then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        questionsObj.value["token"] = data["token"];
        questionsTypeList.value = data["typeList"] || [];
        cutQuestionsSetp(1);
      });
    };
    const choosingTheme = (id) => {
      questionsObj.value.tid = id;
      cutQuestionsSetp(2);
    };
    const cutAnonymous = () => {
      questionsObj.value.anonymous = questionsObj.value.anonymous == 0 ? 1 : 0;
    };
    const postingIssue = () => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      $ajax("/api/publish/questionsSubmit", questionsObj.value).then((res) => {
        if (res.code == 200) {
          myCount.value["questions"]++;
          questionsSetp.value = 0;
          questionsObj.value = {
            token: "",
            title: "",
            content: "",
            tags: "",
            tid: "",
            anonymous: 0
          };
          handleMsg("success", res["message"] || "操作成功");
          let data = res.data;
          getDetails(data["uniqid"]);
          return;
        }
        handleMsg("error", res["message"] || "刷新重试!!!");
      });
    };
    let pitchIndex = ref(null);
    const cut = (index) => {
      pitchIndex.value = index;
      setTimeout(() => scrollLeftInMiddle(), 350);
    };
    const scrollLeftInMiddle = () => {
      {
        return;
      }
    };
    const listStyle = () => {
      const newtype = type.value;
      let width = "";
      let margin = "";
      let height = "";
      if (newtype == "list") {
        width = "1200px";
        margin = "0 auto";
        height = Math.ceil(list.value.length / 2) * 128 + "px";
      } else {
        width = "calc((100vw - 1200px) / 2 + 512px)";
        margin = "initial";
        height = list.value.length * 128 + "px";
      }
      return {
        width,
        margin,
        height
      };
    };
    const itemStyle = (index, content) => {
      const newtype = type.value;
      let obj = {};
      if (newtype == "list") {
        let top = Math.floor(index / 2) * 128 + "px";
        obj["top"] = top;
        if (index % 2 == 0)
          obj["left"] = 0;
        else
          obj["left"] = "649px";
      } else {
        obj["top"] = index * 128 + "px";
        obj["left"] = 0;
        obj["width"] = "100%";
        obj["paddingLeft"] = "calc((100vw - 1200px) / 2)";
      }
      return obj;
    };
    const listBoxStyle = () => {
      const newtype = type.value;
      let obj = {};
      if (newtype == "list")
        obj["overflow"] = "visible";
      else
        obj["height"] = pageListHeight.value + "px";
      return obj;
    };
    const handleDate = (dateTimeStamp = /* @__PURE__ */ new Date()) => {
      dateTimeStamp = dateTimeStamp ? dateTimeStamp : null;
      var timestamp = new Date(dateTimeStamp);
      timestamp = timestamp.getTime();
      var minute = 1e3 * 60;
      var hour = minute * 60;
      var day = hour * 24;
      var now = (/* @__PURE__ */ new Date()).getTime();
      var diffValue = now - timestamp;
      var result;
      if (diffValue < 0)
        return;
      var dayC = diffValue / day;
      var hourC = diffValue / (hour + 1);
      var minC = diffValue / minute;
      if (dayC >= 7) {
        let date = new Date(timestamp);
        let Y = date.getFullYear() + "-";
        let M = (date.getMonth() + 1 < 10 ? "0" + (date.getMonth() + 1) : date.getMonth() + 1) + "-";
        let D = (date.getDate() < 10 ? "0" + date.getDate() : date.getDate()) + " ";
        let h2 = (date.getHours() < 10 ? "0" + date.getHours() : date.getHours()) + ":";
        let m = date.getMinutes() < 10 ? "0" + date.getMinutes() : date.getMinutes();
        result = "" + Y + M + D + h2 + m;
      } else if (dayC >= 1)
        result = "" + Math.round(dayC) + "天前";
      else if (hourC >= 1)
        result = "" + Math.round(hourC) + "小时前";
      else if (minC >= 1)
        result = "" + Math.round(minC) + "分钟前";
      else
        result = "刚刚";
      return result;
    };
    let questionsTransmitState = ref(false);
    let questionsTransmitMaskState = ref(false);
    const closeTransmitState = () => {
      questionsTransmitState.value = true;
      questionsTransmitMaskState.value = true;
      countForwardingTimes(detailsToken);
    };
    const closeAllTransmitState = () => {
      answerList.value.forEach((element) => {
        element["transmitState"] = false;
      });
      questionsTransmitState.value = false;
      questionsTransmitMaskState.value = false;
    };
    const handleAnswerTransmitList = (Iindex, type2) => {
      answerList.value[Iindex]["transmitState"] = true;
      questionsTransmitMaskState.value = true;
      countForwardingTimes(answerList.value[Iindex]["token"]);
    };
    const countForwardingTimes = (token) => {
      $ajax("/api/operate/share", {
        token
      });
    };
    const closeDetailMode = () => {
      type.value = "list";
      pitchIndex.value = null;
      seo.value = {};
    };
    const handleListScroll = (e) => {
      const el = e.target;
      if (el.scrollHeight - el.scrollTop >= el.clientHeight + 40)
        return;
      getList();
    };
    const handlePaste = (event, type2) => {
      const items = (event.clipboardData || event.originalEvent.clipboardData).items;
      for (const item of items) {
        if (item.type.indexOf("image") === 0) {
          event.preventDefault();
          handleMsg("warning", "上传图片中");
          const file = item.getAsFile();
          const reader = new FileReader();
          reader.onload = (e) => {
            const base64 = e.target.result;
            uploadImg(base64).then((res) => {
              let questionTextarea = null;
              if (type2 == "you")
                questionTextarea = document.querySelector(".your-answer-textarea");
              else
                questionTextarea = document.querySelector(".question-textarea");
              let imgNode = document.createElement("img");
              imgNode.setAttribute("src", res.url);
              imgNode.setAttribute("data-aid", res.aid);
              questionTextarea.appendChild(imgNode);
              if (type2 == "you")
                handleInputYou();
              else
                handleInput();
              handleMsg("success", "上传成功");
            });
          };
          reader.readAsDataURL(file);
        }
      }
    };
    const uploadImg = (base64) => {
      return new Promise((resolve, reject) => {
        $ajax("/api/common/upload", {
          data: base64
        }).then((res) => {
          if (res.code != 200)
            return;
          let data = res.data;
          resolve(data);
        });
      });
    };
    let questionPlaceholderState = ref(false);
    let yourAnswerPlaceholderState = ref(true);
    const handleInput = () => {
      const questionTextarea = document.querySelector(".question-textarea");
      const html = questionTextarea.innerHTML;
      if (html)
        questionPlaceholderState.value = false;
      else
        questionPlaceholderState.value = true;
    };
    const handleInputYou = () => {
      const questionTextarea = document.querySelector(".your-answer-textarea");
      const html = questionTextarea.innerHTML;
      if (html)
        yourAnswerPlaceholderState.value = false;
      else
        yourAnswerPlaceholderState.value = true;
    };
    let msg = ref({});
    const handleMsg = (type2, text) => {
      msg.value["state"] = true;
      msg.value["type"] = type2;
      msg.value["text"] = text;
    };
    const boxClass = () => {
      msgShowTimer();
      return type ? `box-item-${msg.value["type"]}` : "";
    };
    let msgTimer = null;
    const msgShowTimer = () => {
      clearTimeout(msgTimer);
      msgTimer = setTimeout(() => {
        msg.value["state"] = false;
      }, 1e3);
    };
    let copyText = (text) => {
      if (navigator.clipboard) {
        copyText = () => {
          navigator.clipboard.writeText(text);
          handleMsg("success", "复制成功");
        };
      } else {
        copyText = () => {
          var tempInput = document.createElement("input");
          tempInput.value = text;
          document.body.appendChild(tempInput);
          tempInput.select();
          document.execCommand("copy");
          document.body.removeChild(tempInput);
          handleMsg("success", "复制成功");
        };
      }
      copyText();
    };
    const replaceState = (obj = {}) => {
      return;
    };
    const myOpenDetails = (uniqid) => {
      if (!uniqid) {
        handleMsg("error", "没有找到相关提问");
        return;
      }
      getDetails(uniqid);
      myType.value = "";
    };
    const handleDetailsScroll = (e) => {
      const el = e.target;
      if (el.scrollHeight - el.scrollTop !== el.clientHeight)
        return;
      getAnswerList();
    };
    let dialogSrc = ref("");
    const handleAnswerText = (e) => {
      if (e.target.tagName === "IMG") {
        var src = e.target.getAttribute("src");
        dialogSrc.value = src;
        window.addEventListener("keydown", handleKeydown);
      }
    };
    const handleKeydown = (event) => {
      if (event.key !== "Escape")
        return;
      dialogSrc.value = "";
      window.removeEventListener("keydown", handleKeydown);
    };
    const cutType = (id) => {
      typePitch.value = id;
      page = 1;
      list.value = [];
      type.value = "list";
      pitchIndex.value = null;
      getList();
    };
    const handleMenuState = (index, ind, i) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      if (i === void 0)
        reportToken = answerList.value[index].commentList[ind]["token"];
      else
        reportToken = answerList.value[index].commentList[ind]["child"][i]["token"];
      alertShow.value = true;
    };
    let reportToken = "";
    const reasonList = ["广告", "辱骂", "重复发送", "不良信息", "其他"];
    let checkList = ref([]);
    let alertShow = ref(false);
    let alertText = ref("");
    const selectRadio = (value) => {
      const index = checkList.value.indexOf(value);
      if (index === -1)
        checkList.value.push(value);
      else
        checkList.value.splice(index, 1);
    };
    const alertSubmit = () => {
      checkList.value.push(alertText.value);
      $ajax("/api/operate/report", {
        message: checkList.value,
        token: reportToken
      }).then((res) => {
        checkList.value = [];
        reportToken = "";
        alertShow.value = false;
        handleMsg("success", "举报成功");
      });
    };
    let seo = ref({});
    try {
      const params = route.query;
      if (params["keyword"])
        keyword.value = params["keyword"];
      if (params["tid"])
        typePitch.value = params["tid"];
      if (params["uniqid"]) {
        await $ajax("/api/details", { uniqid: params["uniqid"] }).then((res) => {
          if (res.code != 200)
            return;
          let data = res.data;
          detailsInfo.value = data["info"] || {};
          detailsIsanswered.value = data["isanswered"] || 0;
          detailsIscollection.value = data["iscollection"] || 0;
          detailsIsmyself.value = data["ismyself"] || 0;
          detailsToken = data["token"] || "";
          detailShare.value = data["share"] || {};
          type.value = "details";
          calculateListIndex(data.info, params["uniqid"]);
          answerList.value = [];
          answerPage.value = 1;
          getAnswerList();
          closeAllTransmitState();
          replaceState({ uniqid: params["uniqid"] });
          seo.value = data.seo;
        });
      }
      await $ajax("/api/lists", {
        page,
        limit: 20,
        keyword: keyword.value,
        type: typePitch.value
      }).then((res) => {
        if (res.code != 200)
          return;
        let data = res.data;
        list.value = list.value.concat(data.data || []);
        total.value = data.count || 0;
        keywordText.value = keyword.value || "";
        if (list.value.length != data["count"])
          page++;
        else
          page = 0;
        if (page == 0 && list.value.length != 0)
          inTheEndState.value = true;
        else
          inTheEndState.value = false;
        if (list.value.length == 0)
          isListEmptyState.value = true;
        else
          isListEmptyState.value = false;
        if (keyword.value)
          isSearchMode.value = true;
        else
          isSearchMode.value = false;
      });
    } catch (error) {
      console.error(error);
    }
    const setItemUrl = (uniqid) => {
      let url = `./index.html?uniqid=${uniqid}`;
      let query = route.query;
      for (const key in query) {
        if (key != "uniqid")
          url += `&${key}=${query[key]}`;
      }
      return url;
    };
    const handleLogo = () => {
      window.location.href = window.location.origin + window.location.pathname;
    };
    let yourAnswer = ref({
      text: "",
      anonymous: 0
    });
    const cutYourAnswerAnonymous = () => {
      yourAnswer.value["anonymous"] = yourAnswer.value["anonymous"] ? 0 : 1;
    };
    const handleYourAnswer = () => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      IAnswerInfo.value = { ...yourAnswer.value };
      submitAnswer("you");
      yourAnswer.value = {
        text: "",
        anonymous: 0
      };
    };
    let isDirectlyListIAnswer = false;
    const openListIAnswer = (index) => {
      if (isNeedLogin.value) {
        goLogin();
        return;
      }
      let targetData = list.value[index];
      IAnswerInfo.value = {
        title: targetData["title"],
        content: targetData["content"],
        token: targetData["token"],
        uniqid: targetData["uniqid"],
        anonymous: 0,
        index
      };
      isDirectlyListIAnswer = true;
      IAnswerState.value = true;
      nextTick(() => handleInput());
    };
    return {
      isNeedLogin,
      handleInputYou,
      openListIAnswer,
      isListEmptyState,
      cutYourAnswerAnonymous,
      handleYourAnswer,
      yourAnswer,
      handleLogo,
      inTheEndState,
      setItemUrl,
      seo,
      originUrl,
      handleMenuState,
      reasonList,
      checkList,
      alertShow,
      alertText,
      selectRadio,
      alertSubmit,
      cutType,
      dialogSrc,
      answerPage,
      handleDetailsScroll,
      replaceState,
      copyText,
      boxClass,
      questionPlaceholderState,
      yourAnswerPlaceholderState,
      handleInput,
      handlePaste,
      itemStyle,
      listStyle,
      listBoxStyle,
      myType,
      type,
      pitchIndex,
      cut,
      list,
      keyword,
      keywordText,
      getList,
      total,
      typeList,
      typePitch,
      getDetails,
      detailsInfo,
      detailsIsanswered,
      detailsIscollection,
      detailsIsmyself,
      detailShare,
      detailLoading,
      answerList,
      operateLike,
      operateCollect,
      IAnswerState,
      IAnswerEditState,
      IAnswerInfo,
      amendIAnswer,
      openIAnswer,
      closeIAnswer,
      submitAnswer,
      openCommentState,
      submitAnswerComments,
      operateAnswerCommentsLike,
      openAnswerCommentsChild,
      closeAnswerCommentsChild,
      alsoCommentsData,
      handleAllComment,
      myCollectionList,
      myCollectionCount,
      myQuestionsList,
      myQuestionsCount,
      myAnswerList,
      myAnswerCount,
      cutAnswerPopupState,
      handleDate,
      handleCollectionScroll,
      handleAnswersScroll,
      handleQuestionsScroll,
      cancelCollection,
      getMyCollection,
      questionsSetp,
      questionsObj,
      cutAnonymous,
      cutQuestionsSetp,
      cutQuestionsPopupState,
      questionsTypeList,
      postingIssue,
      choosingTheme,
      handleMy,
      changeAnonymous,
      changeAnonymousQuestions,
      pageHeaderHeight,
      pageListHeight,
      questionsTransmitState,
      questionsTransmitMaskState,
      closeAllTransmitState,
      closeTransmitState,
      handleAnswerTransmitList,
      closeDetailMode,
      tabListFixeState,
      handleListScroll,
      historicalSearchState,
      historicalSearchList,
      searchFocus,
      searchBlur,
      searchClick,
      handleClickHistoricalItem,
      handleClickClear,
      isSearchMode,
      questionsInit,
      myCount,
      msg,
      myOpenDetails,
      handleAnswerText,
      getCurrentUrl,
      loading
    };
  }
};
function _sfc_ssrRender(_ctx, _push, _parent, _attrs, $props, $setup, $data, $options) {
  const _component_Head = Head;
  const _component_Title = Title;
  const _component_Meta = Meta;
  _push(`<!--[--><div id="append_parent"></div><div id="ajaxwaitid"></div><div>`);
  _push(ssrRenderComponent(_component_Head, null, {
    default: withCtx((_, _push2, _parent2, _scopeId) => {
      if (_push2) {
        _push2(ssrRenderComponent(_component_Title, null, {
          default: withCtx((_2, _push3, _parent3, _scopeId2) => {
            if (_push3) {
              _push3(`${ssrInterpolate(`${$setup.seo["title"] || "问答"} -  寄托天下出国留学网`)}`);
            } else {
              return [
                createTextVNode(toDisplayString(`${$setup.seo["title"] || "问答"} -  寄托天下出国留学网`), 1)
              ];
            }
          }),
          _: 1
        }, _parent2, _scopeId));
        _push2(ssrRenderComponent(_component_Meta, {
          name: "keyword",
          content: $setup.seo["keyword"]
        }, null, _parent2, _scopeId));
        _push2(ssrRenderComponent(_component_Meta, {
          name: "description",
          content: $setup.seo["description"]
        }, null, _parent2, _scopeId));
      } else {
        return [
          createVNode(_component_Title, null, {
            default: withCtx(() => [
              createTextVNode(toDisplayString(`${$setup.seo["title"] || "问答"} -  寄托天下出国留学网`), 1)
            ]),
            _: 1
          }),
          createVNode(_component_Meta, {
            name: "keyword",
            content: $setup.seo["keyword"]
          }, null, 8, ["content"]),
          createVNode(_component_Meta, {
            name: "description",
            content: $setup.seo["description"]
          }, null, 8, ["content"])
        ];
      }
    }),
    _: 1
  }, _parent));
  _push(`<div class="" id="answer-app"><header class="flexacenter" id="pageHeader"><div class="flexacenter top"><a href="./index.html"><img class="logo" alt="寄托问答"${ssrRenderAttr("src", _imports_0)}></a><div class="right flexacenter flex1"><div class="searchInput flexacenter"><input class="input flex1" placeholder="输入搜索关键词"${ssrRenderAttr("value", $setup.keyword)}>`);
  if ($setup.isSearchMode) {
    _push(`<div class="clear-search flexacenter"><img class="cross-circle-black"${ssrRenderAttr("src", _imports_1)}><div class="halving-line"></div></div>`);
  } else {
    _push(`<!---->`);
  }
  _push(`<img class="input-icon"${ssrRenderAttr("src", _imports_2)}>`);
  if ($setup.historicalSearchState) {
    _push(`<div class="history-box"><div class="history-title"> 历史搜索 </div><div class="history-list"><!--[-->`);
    ssrRenderList($setup.historicalSearchList, (item, index) => {
      _push(`<div class="history-item ellipsis">${ssrInterpolate(item)}</div>`);
    });
    _push(`<!--]--></div></div>`);
  } else {
    _push(`<!---->`);
  }
  _push(`</div><div class="btn-list flexacenter"><div class="item flex1"> 我的收藏 </div><div class="item flex1"> 我的提问 </div><div class="item flex1"> 我的回答 </div></div><div class="add-btn flexcenter"><img class="add-icon"${ssrRenderAttr("src", _imports_3)}> 我要提问 </div></div></div><div class="${ssrRenderClass([{ "tab-list-fixed": $setup.tabListFixeState }, "tab-box flexcenter"])}"><div class="tab-list flexacenter"><div class="${ssrRenderClass([{ pitch: $setup.typePitch == null }, "item flexcenter"])}">All</div><!--[-->`);
  ssrRenderList($setup.typeList, (item, index) => {
    _push(`<!--[--><div class="halving-line">|</div><!--[-->`);
    ssrRenderList(item, (it) => {
      _push(`<div class="${ssrRenderClass([{ pitch: $setup.typePitch == it["id"] }, "item flexcenter"])}">${ssrInterpolate(it["name"])}</div>`);
    });
    _push(`<!--]--><!--]-->`);
  });
  _push(`<!--]--></div></div></header><div class="${ssrRenderClass([{ "mode-list": $setup.type == "list" }, "main flexflex"])}"><div class="list-box"><div class="main-header" style="${ssrRenderStyle({ paddingLeft: $setup.type == "list" ? 0 : "calc((100vw - 1200px) / 2)" })}">`);
  if ($setup.isSearchMode) {
    _push(`<!--[--><div class="search-keyword flexacenter"><div class="ellipsis">${ssrInterpolate($setup.keywordText)}</div><img class="search-keyword-cross"${ssrRenderAttr("src", _imports_4)}></div><div class="total grid-item">共 ${ssrInterpolate($setup.total)} 条搜索结果</div><!--]-->`);
  } else {
    _push(`<div class="total grid-item">共 ${ssrInterpolate($setup.total)} 条问答</div>`);
  }
  _push(`</div><div class="list" id="list" style="${ssrRenderStyle($setup.listStyle())}"><!--[-->`);
  ssrRenderList($setup.list, (item, index) => {
    _push(`<a style="${ssrRenderStyle($setup.itemStyle(index, item["content"]))}" class="${ssrRenderClass([{ pitch: index === $setup.pitchIndex, upLevel: index === $setup.pitchIndex - 1 }, "item grid-item flexflex"])}"${ssrRenderAttr("href", $setup.setItemUrl(item["uniqid"]))}><img class="dot"${ssrRenderAttr("src", _imports_5)}><div class="content" style="${ssrRenderStyle({ width: $setup.type == "list" ? "531px" : "430px" })}"><div class="issue-title flexcenter">`);
    if (item["ishot"] == 1) {
      _push(`<img class="hot-icon"${ssrRenderAttr("src", _imports_6)}>`);
    } else {
      _push(`<!---->`);
    }
    _push(`<div class="issue ellipsis flex1">${item["title"]}</div></div><div class="answer ellipsis">${item["content"]}</div><div class="bottom flexacenter">`);
    if (item["typename"]) {
      _push(`<div class="typename">${ssrInterpolate(item["typename"])}</div>`);
    } else {
      _push(`<div></div>`);
    }
    _push(`<div class="flexacenter"><div class="quantity">${ssrInterpolate(item["answers"] == 0 ? "暂无回答" : "共" + item["answers"] + "个回答")}</div>`);
    if ($setup.type == "list") {
      _push(`<!--[--><div class="longString"></div><div class="answer-btn">我来回答</div><!--]-->`);
    } else {
      _push(`<!---->`);
    }
    _push(`</div></div></div></a>`);
  });
  _push(`<!--]--></div>`);
  if ($setup.inTheEndState) {
    _push(`<div class="bottom-tps">- 到底了 -</div>`);
  } else {
    _push(`<!---->`);
  }
  if ($setup.isListEmptyState && $setup.list.length == 0) {
    _push(`<div class="empty-box flexcenter"><div class="dot-list flexacenter"><img class="item"${ssrRenderAttr("src", _imports_7)}><img class="item"${ssrRenderAttr("src", _imports_7)}><img class="item"${ssrRenderAttr("src", _imports_7)}><img class="item"${ssrRenderAttr("src", _imports_8)}><img class="item"${ssrRenderAttr("src", _imports_8)}><img class="item"${ssrRenderAttr("src", _imports_8)}></div><img class="empty-icon"${ssrRenderAttr("src", _imports_9)}>`);
    if ($setup.isSearchMode) {
      _push(`<div class="empty-hint">没有找到相关结果,请更换搜索关键词</div>`);
    } else {
      _push(`<div class="empty-hint">暂无数据</div>`);
    }
    _push(`</div>`);
  } else {
    _push(`<!---->`);
  }
  _push(`</div>`);
  if ($setup.type == "details") {
    _push(`<div class="details-area-box flexflex">`);
    if ($setup.detailLoading) {
      _push(`<div class="loading-bj flexcenter"><svg t="1642133548066" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2597" width="200" height="200"><path d="M512 249.5c-22.5 0-37.5-15-37.5-37.5V99.5c0-22.5 15-37.5 37.5-37.5s37.5 15 37.5 37.5V212c0 22.5-15 37.5-37.5 37.5z m0 712.5c-22.5 0-37.5-15-37.5-37.5V812c0-22.5 15-37.5 37.5-37.5s37.5 15 37.5 37.5v112.5c0 22.5-15 37.5-37.5 37.5zM212 549.5H99.5C77 549.5 62 534.5 62 512s15-37.5 37.5-37.5H212c22.5 0 37.5 15 37.5 37.5s-15 37.5-37.5 37.5z m712.5 0H812c-22.5 0-37.5-15-37.5-37.5s15-37.5 37.5-37.5h112.5c22.5 0 37.5 15 37.5 37.5s-15 37.5-37.5 37.5z m-153.75-150c-11.25 0-26.25-7.5-33.75-18.75-11.25-18.75-3.75-41.25 15-52.5L849.5 272c18.75-11.25 41.25-3.75 52.5 15s3.75 41.25-15 52.5l-97.5 56.25c-3.75 3.75-11.25 3.75-18.75 3.75z m-615 356.25c-11.25 0-26.25-7.5-33.75-18.75-11.25-18.75-3.75-41.25 15-52.5l97.5-56.25c18.75-11.25 41.25-3.75 52.5 15s3.75 41.25-15 52.5L174.5 752c-7.5 3.75-15 3.75-18.75 3.75z m506.25-465c-7.5 0-11.25 0-18.75-3.75-18.75-11.25-22.5-33.75-15-52.5L684.5 137c11.25-18.75 33.75-22.5 52.5-15 18.75 11.25 22.5 33.75 15 52.5L695.75 272c-7.5 11.25-22.5 18.75-33.75 18.75z m-356.25 615c-7.5 0-11.25 0-18.75-3.75-18.75-11.25-22.5-33.75-15-52.5l56.25-97.5c11.25-15 33.75-22.5 52.5-11.25s22.5 33.75 15 52.5L339.5 887c-7.5 11.25-22.5 18.75-33.75 18.75z m-52.5-506.25c-7.5 0-15 0-18.75-3.75L137 339.5c-18.75-11.25-26.25-33.75-15-52.5s33.75-22.5 52.5-15l97.5 56.25c18.75 11.25 22.5 33.75 11.25 52.5-3.75 11.25-18.75 18.75-30 18.75z m615 356.25c-7.5 0-11.25 0-18.75-3.75L752 695.75c-18.75-11.25-22.5-33.75-15-52.5 11.25-18.75 33.75-22.5 52.5-15L887 684.5c18.75 11.25 22.5 33.75 15 52.5-7.5 11.25-18.75 18.75-33.75 18.75zM362 290.75c-11.25 0-26.25-7.5-33.75-18.75L272 174.5c-7.5-18.75-3.75-41.25 15-52.5s41.25-3.75 52.5 15l56.25 97.5c7.5 18.75 3.75 41.25-15 48.75-7.5 3.75-11.25 7.5-18.75 7.5z m356.25 615c-11.25 0-26.25-7.5-33.75-18.75l-56.25-97.5c-11.25-18.75-3.75-41.25 15-52.5s41.25-3.75 52.5 15L752 849.5c11.25 18.75 3.75 41.25-15 52.5-7.5 3.75-11.25 3.75-18.75 3.75z" p-id="2598" fill="#26d79f"></path></svg></div>`);
    } else {
      _push(`<!---->`);
    }
    _push(`<div class="details-box flexflex"><div class="close-box"><div class="close-circle flexcenter"><img class="close-icon"${ssrRenderAttr("src", _imports_10)}><img class="details-cross-icon"${ssrRenderAttr("src", _imports_11)}></div></div><div class="details-issue"><img class="qq"${ssrRenderAttr("src", _imports_12)}><div class="titletitle">${ssrInterpolate($setup.detailsInfo["title"])}</div><div class="hint">${$setup.detailsInfo["content"]}</div><div class="info-box flexacenter"><div class="user-info flexacenter">`);
    if ($setup.detailsInfo["avatar"]) {
      _push(`<img class="avatar"${ssrRenderAttr("src", $setup.detailsInfo["avatar"])}>`);
    } else {
      _push(`<!---->`);
    }
    _push(`<div class="user-name">${ssrInterpolate($setup.detailsInfo["nickname"])}</div></div><div class="time">${ssrInterpolate($setup.handleDate($setup.detailsInfo["publicationdate"]))}</div></div><div class="operate-box flexacenter"><div class="${ssrRenderClass([{ white: $setup.detailsInfo["answers"] == 0 }, "answer-btn flexcenter"])}"><img class="answer-btn-icon answer-icon-edit"${ssrRenderAttr("src", _imports_13)}><img class="answer-btn-icon answer-icon-white"${ssrRenderAttr("src", _imports_14)}> 我来回答 </div><div class="operate-list flexacenter"><div class="operate-item flexacenter">`);
    if ($setup.detailsIscollection == 0) {
      _push(`<img class="operate-icon operate-collect-icon"${ssrRenderAttr("src", _imports_15)}>`);
    } else {
      _push(`<img class="operate-icon operate-collect-icon"${ssrRenderAttr("src", _imports_16)}>`);
    }
    _push(` ${ssrInterpolate($setup.detailsInfo["collectionnum"] > 0 ? $setup.detailsInfo["collectionnum"] : "收藏")}</div><div class="operate-item flexacenter operate-transmit"><img class="operate-icon operate-transmit-icon"${ssrRenderAttr("src", _imports_17)}> 转发 `);
    if ($setup.questionsTransmitState) {
      _push(`<div class="transmit-box flexflex" style="${ssrRenderStyle({ "z-index": "10" })}"><img class="cross-icon"${ssrRenderAttr("src", _imports_11)}><div class="transmit-left transmit-web"><div class="transmit-title">转发网页版</div><div class="transmit-content"><div class="transmit-headline">${ssrInterpolate($setup.detailsInfo["title"])}</div><div class="transmit-url">${ssrInterpolate($setup.getCurrentUrl())}</div></div><div class="transmit-web-btn flexcenter">复制链接</div></div><div class="transmit-right transmit-mini"><div class="transmit-title">转发小程序版</div><div class="transmit-content flexcenter"><img class="transmit-mini-img"${ssrRenderAttr("src", $setup.detailShare["qrcode"])}><div class="flexcenter"><img class="give-sweep"${ssrRenderAttr("src", _imports_18)}> 扫码转发该问答 </div></div></div></div>`);
    } else {
      _push(`<!---->`);
    }
    _push(`</div></div></div></div><div class="answer-total-amount">共 ${ssrInterpolate($setup.detailsInfo["answers"])} 个回答</div><!--[-->`);
    ssrRenderList($setup.answerList, (item, index) => {
      _push(`<div class="answer-box-item"><img class="aa"${ssrRenderAttr("src", _imports_19)}><div class="answer-text">${item["content"]}</div><div class="info-box flexacenter"><div class="user-info flexacenter"><img class="avatar"${ssrRenderAttr("src", item["avatar"])}><div class="user-name">${ssrInterpolate(item["nickname"])}</div>`);
      if (item["groupid"] == 14) {
        _push(`<img class="homeShare"${ssrRenderAttr("src", _imports_20)}>`);
      } else {
        _push(`<!---->`);
      }
      _push(`</div><div class="time">${ssrInterpolate($setup.handleDate(item["publicationdate"]))}</div></div><div class="operate-box flexacenter"><div class="edit-box">`);
      if (item["ismyself"] == 1) {
        _push(`<div class="edit-btn flexcenter"><img class="edit-icon"${ssrRenderAttr("src", _imports_13)}></div>`);
      } else {
        _push(`<!---->`);
      }
      _push(`</div><div class="operate-list flexacenter"><div class="operate-item flexacenter">`);
      if (item["islike"] == 1) {
        _push(`<img class="operate-icon operate-like-icon"${ssrRenderAttr("src", _imports_21)}>`);
      } else {
        _push(`<img class="operate-icon operate-like-icon"${ssrRenderAttr("src", _imports_22)}>`);
      }
      _push(` ${ssrInterpolate(item["likenum"])}</div><div class="${ssrRenderClass([{ commentnum: item["commentState"] }, "operate-item flexacenter"])}"><img class="operate-icon operate-comment-icon"${ssrRenderAttr("src", _imports_23)}> ${ssrInterpolate(item["commentnum"])}</div><div class="operate-item flexacenter">`);
      if (item["iscollection"] == 1) {
        _push(`<img class="operate-icon operate-collect-icon"${ssrRenderAttr("src", _imports_16)}>`);
      } else {
        _push(`<img class="operate-icon operate-collect-icon"${ssrRenderAttr("src", _imports_15)}>`);
      }
      _push(` ${ssrInterpolate(item["collectionnum"] == 0 ? "收藏" : item["collectionnum"])}</div><div class="operate-item operate-transmit flexacenter"><img class="operate-icon operate-transmit-icon"${ssrRenderAttr("src", _imports_17)}> 转发 `);
      if (item["transmitState"]) {
        _push(`<div class="transmit-box flexflex"><img class="cross-icon"${ssrRenderAttr("src", _imports_11)}><div class="transmit-left transmit-web"><div class="transmit-title">转发网页版</div><div class="transmit-content"><div class="transmit-headline">${ssrInterpolate($setup.detailsInfo["title"])}</div><div class="transmit-url">${ssrInterpolate($setup.getCurrentUrl())}</div></div><div class="transmit-web-btn flexcenter">复制链接</div></div><div class="transmit-right transmit-mini"><div class="transmit-title">转发小程序版</div><div class="transmit-content flexcenter"><img class="transmit-mini-img"${ssrRenderAttr("src", item["share"]["qrcode"])}><div class="flexcenter"><img class="give-sweep"${ssrRenderAttr("src", _imports_18)}> 扫码转发该问答 </div></div></div></div>`);
      } else {
        _push(`<!---->`);
      }
      _push(`</div></div></div>`);
      if (item["commentState"]) {
        _push(`<!--[--><div class="post-comment flexacenter"><input class="post-input flex1" placeholder="说点什么…"${ssrRenderAttr("value", item["commentInput"])}><div class="post-ok flexcenter">OK</div></div>`);
        if (item["commentList"] && item["commentList"].length != 0) {
          _push(`<div class="comments-box"><!--[-->`);
          ssrRenderList(item["commentList"], (it, ind) => {
            _push(`<div class="comments-item"><div class="comments-header flexacenter"><div class="comments-header-left flexacenter"><img class="comments-avatar"${ssrRenderAttr("src", it["avatar"])}><div class="comments-username">${ssrInterpolate(it["nickname"])}</div><div class="comments-time">${ssrInterpolate($setup.handleDate(it["timestamp"]))}</div>`);
            if (it["questioner"] == 1) {
              _push(`<div class="comments-identity">提问者</div>`);
            } else if (it["isauthor"] == 1) {
              _push(`<div class="comments-identity">回答者</div>`);
            } else {
              _push(`<!---->`);
            }
            _push(`</div><div class="comments-header-right flexacenter"><div class="menu-box flexacenter"><img class="menu-icon"${ssrRenderAttr("src", _imports_24)}><div class="report-box flexcenter">举报</div></div><img class="comment-icon"${ssrRenderAttr("src", _imports_25)}><div class="flexacenter like-box">`);
            if (it["islike"] == 0) {
              _push(`<img class="like-icon"${ssrRenderAttr("src", _imports_26)}>`);
            } else {
              _push(`<img class="like-icon"${ssrRenderAttr("src", _imports_21)}>`);
            }
            _push(`<div class="like-quantity">${ssrInterpolate(it["likenum"] || 0)}</div></div></div></div><div class="comments-content"><div class="comments-text">${ssrInterpolate(it["content"])}</div>`);
            if (it["childState"]) {
              _push(`<div class="comments-input-box flexacenter"><div class="comments-input flexflex"><textarea class="flex1" placeholder="回复">${ssrInterpolate(it["commentInput"])}</textarea><div class="comments-btn flexcenter">发送</div></div><img class="forkfork"${ssrRenderAttr("src", _imports_11)}></div>`);
            } else {
              _push(`<!---->`);
            }
            _push(`</div>`);
            if (it["child"].length != 0) {
              _push(`<div class="child-comments"><!--[-->`);
              ssrRenderList(it["child"], (ite, i) => {
                _push(`<div class="comments-item"><div class="comments-header flexacenter"><div class="comments-header-left flexacenter"><img class="comments-avatar"${ssrRenderAttr("src", ite["avatar"])}><div class="comments-username">${ssrInterpolate(ite["nickname"])}</div><div class="comments-time">${ssrInterpolate($setup.handleDate(ite["timestamp"]))}</div>`);
                if (ite["questioner"] == 1) {
                  _push(`<div class="comments-identity">提问者</div>`);
                } else if (ite["isauthor"] == 1) {
                  _push(`<div class="comments-identity">回答者</div>`);
                } else {
                  _push(`<!---->`);
                }
                _push(`</div><div class="comments-header-right flexacenter"><div class="menu-box flexacenter"><img class="menu-icon"${ssrRenderAttr("src", _imports_24)}><div class="report-box flexcenter">举报</div></div><img class="comment-icon"${ssrRenderAttr("src", _imports_25)}><div class="flexacenter like-box">`);
                if (ite["islike"] == 0) {
                  _push(`<img class="like-icon"${ssrRenderAttr("src", _imports_26)}>`);
                } else {
                  _push(`<img class="like-icon"${ssrRenderAttr("src", _imports_21)}>`);
                }
                _push(`<div class="like-quantity">${ssrInterpolate(ite["likenum"] || 0)}</div></div></div></div><div class="comments-content"><div class="comments-text">`);
                if (JSON.stringify(ite["reply"]) != "[]") {
                  _push(`<div class="comments-reply">@${ssrInterpolate(ite["reply"]["nickname"])}</div>`);
                } else {
                  _push(`<!---->`);
                }
                _push(` ${ssrInterpolate(ite["content"])}</div>`);
                if (ite["childState"]) {
                  _push(`<div class="comments-input-box flexacenter"><div class="comments-input flexflex"><textarea class="flex1" placeholder="回复">${ssrInterpolate(ite["commentInput"])}</textarea><div class="comments-btn flexcenter">发送</div></div><img class="forkfork"${ssrRenderAttr("src", _imports_11)}></div>`);
                } else {
                  _push(`<!---->`);
                }
                _push(`</div></div>`);
              });
              _push(`<!--]-->`);
              if (it["childnum"] >= 3 && it["childnum"] > it["child"].length) {
                _push(`<div class="comments-also flexacenter"><div class="">还有${ssrInterpolate(it["childnum"] - 1)}条回复</div><img class="also-icon"${ssrRenderAttr("src", _imports_27)}></div>`);
              } else {
                _push(`<!---->`);
              }
              _push(`</div>`);
            } else {
              _push(`<!---->`);
            }
            _push(`</div>`);
          });
          _push(`<!--]-->`);
          if (item["commentCount"] != item["commentList"].length) {
            _push(`<div class="reverl-all flexcenter"> 显示全部 <img class="arrow-circular"${ssrRenderAttr("src", _imports_27)}></div>`);
          } else {
            _push(`<!---->`);
          }
          _push(`</div>`);
        } else {
          _push(`<div class="comments-empty-box flexflex"><div class="empty-box flexcenter"><div class="dot-list flexacenter"><!--[-->`);
          ssrRenderList(3, (item2) => {
            _push(`<img class="dot-item"${ssrRenderAttr("src", _imports_7)}>`);
          });
          _push(`<!--]--><!--[-->`);
          ssrRenderList(3, (item2) => {
            _push(`<img class="dot-item"${ssrRenderAttr("src", _imports_8)}>`);
          });
          _push(`<!--]--></div><img class="empty-icon"${ssrRenderAttr("src", _imports_9)}></div><div class="empty-hint">和我说说你的想法或疑问吧</div></div>`);
        }
        _push(`<!--]-->`);
      } else {
        _push(`<!---->`);
      }
      _push(`</div>`);
    });
    _push(`<!--]-->`);
    if ($setup.answerList.length > 0) {
      _push(`<div class="copyright flexcenter">· 著作权归作者所有 ·</div>`);
    } else {
      _push(`<!---->`);
    }
    if (!$setup.isNeedLogin) {
      _push(`<div class="your-answer-box"><div class="your-answer-header flexacenter">您的答案</div><div class="${ssrRenderClass([{ placeholder: $setup.yourAnswerPlaceholderState }, "your-answer-textarea"])}" contenteditable="true">${$setup.yourAnswer["text"]}</div><div class="flexacenter your-answer-bottom"><div class="option-box flexacenter">`);
      if ($setup.yourAnswer["anonymous"] == 0) {
        _push(`<img class="option-icon"${ssrRenderAttr("src", _imports_28)}>`);
      } else {
        _push(`<img class="option-icon"${ssrRenderAttr("src", _imports_29)}>`);
      }
      _push(` 匿名发表 </div><div class="your-answer-submit flexcenter">提交回答</div></div></div>`);
    } else {
      _push(`<!---->`);
    }
    if ($setup.isNeedLogin && $setup.answerList.length == 0) {
      _push(`<div class="answer-empty-box flexcenter"><div class="empty-box flexcenter"><div class="dot-list flexacenter"><!--[-->`);
      ssrRenderList(3, (item) => {
        _push(`<img class="dot-item"${ssrRenderAttr("src", _imports_7)}>`);
      });
      _push(`<!--]--><!--[-->`);
      ssrRenderList(3, (item) => {
        _push(`<img class="dot-item"${ssrRenderAttr("src", _imports_8)}>`);
      });
      _push(`<!--]--></div><img class="empty-icon"${ssrRenderAttr("src", _imports_9)}></div><div class="empty-hint">我在等待你的回答</div></div>`);
    } else {
      _push(`<!---->`);
    }
    _push(`<div class="mobile-phone-check flexcenter"><img class="QRCode-icon"${ssrRenderAttr("src", _imports_30)} alt=""> 手机查看该问答 <div class="QRCode-pop flexcenter"><img class="offer-mini-QRcode"${ssrRenderAttr("src", $setup.detailShare["qrcode"])}><div class="QRCode-hint flexacenter"><img class="QRCode-img"${ssrRenderAttr("src", _imports_18)}> 微信扫一扫 </div></div></div></div></div>`);
  } else {
    _push(`<!---->`);
  }
  _push(`</div>`);
  if ($setup.myType) {
    _push(`<div class="popover-mask my-popover flexcenter"><div class="popover-box flexflex"><img class="cross-icon"${ssrRenderAttr("src", _imports_11)}><div class="tab-list flexcenter"><div class="${ssrRenderClass([{ pitch: $setup.myType == "collect" }, "tab-item flexacenter"])}"> 我的收藏 <div class="quantity">${ssrInterpolate($setup.myCollectionCount || $setup.myCount["collect"] || 0)}</div></div><div class="long-string"></div><div class="${ssrRenderClass([{ pitch: $setup.myType == "questions" }, "tab-item flexacenter"])}"> 我的提问 <div class="quantity">${ssrInterpolate($setup.myQuestionsCount || $setup.myCount["questions"] || 0)}</div></div><div class="long-string"></div><div class="${ssrRenderClass([{ pitch: $setup.myType == "answers" }, "tab-item flexacenter"])}"> 我的回答 <div class="quantity">${ssrInterpolate($setup.myAnswerCount || $setup.myCount["answer"] || 0)}</div></div></div>`);
    if ($setup.myType == "collect" && $setup.myCollectionList.length == 0 || $setup.myType == "answers" && $setup.myAnswerList.length == 0 || $setup.myType == "questions" && $setup.myQuestionsList.length == 0) {
      _push(`<div class="empty-box flexcenter"><div class="dot-list flexacenter"><img class="item"${ssrRenderAttr("src", _imports_7)}><img class="item"${ssrRenderAttr("src", _imports_7)}><img class="item"${ssrRenderAttr("src", _imports_7)}><img class="item"${ssrRenderAttr("src", _imports_8)}><img class="item"${ssrRenderAttr("src", _imports_8)}><img class="item"${ssrRenderAttr("src", _imports_8)}></div><img class="empty-icon"${ssrRenderAttr("src", _imports_9)}><div class="empty-hint">暂无内容</div></div>`);
    } else {
      _push(`<!---->`);
    }
    if ($setup.myType == "collect" && $setup.myCollectionList.length != 0) {
      _push(`<div class="content-box collect-list"><!--[-->`);
      ssrRenderList($setup.myCollectionList, (item, index) => {
        _push(`<div class="item flexflex">`);
        if (item.type == "askanswercollection") {
          _push(`<!--[--><div class="icon a flexcenter">A</div><div class="centre flexflex flex1"><div class="titletitle ellipsis">${item["data"]["content"]}</div><div class="text ellipsis">提问:${ssrInterpolate(item["data"]["title"])}</div></div><div class="delete-box flexacenter"><img class="delete-icon"${ssrRenderAttr("src", _imports_31)}></div><!--]-->`);
        } else {
          _push(`<!--[--><div class="icon q flexcenter">Q</div><div class="centre flexflex flex1"><div class="titletitle ellipsis">${ssrInterpolate(item["data"]["title"])}</div><div class="text ellipsis">${ssrInterpolate(item["data"]["answers"] > 0 ? "共" + item["data"]["answers"] + "个回答" : "暂无回答")}</div></div><div class="delete-box flexacenter"><img class="delete-icon"${ssrRenderAttr("src", _imports_31)}></div><!--]-->`);
        }
        _push(`</div>`);
      });
      _push(`<!--]--></div>`);
    } else {
      _push(`<!---->`);
    }
    if ($setup.myType == "answers" && $setup.myAnswerList.length != 0) {
      _push(`<div class="content-box answers-list"><!--[-->`);
      ssrRenderList($setup.myAnswerList, (item, index) => {
        _push(`<div class="item flexflex"><div class="icon a flexcenter">A</div><div class="centre flexflex flex1"><div class="info flexacenter"><div class="name">${ssrInterpolate(item["nickname"])}</div><div class="time">${ssrInterpolate($setup.handleDate(item["publicationdate"]))}</div></div><div class="titletitle ellipsis">${item["content"]}</div><div class="text ellipsis">提问:${ssrInterpolate(item["title"])}</div></div><div class="operate-box flexacenter"><div class="state-box flexacenter"><div class="text">${ssrInterpolate(item["anonymous"] == 0 ? "公开" : "匿名")}</div><img class="arrows"${ssrRenderAttr("src", _imports_32)}>`);
        if (item["popupState"]) {
          _push(`<div class="state-popup flexflex"><div class="state-popup-mask"></div><div class="${ssrRenderClass([{ pitch: item["anonymous"] == 0 }, "state-popup-item flexacenter flex1"])}"><div class="">公开发表</div><img class="state-popup-icon"${ssrRenderAttr("src", _imports_33)}></div><div class="${ssrRenderClass([{ pitch: item["anonymous"] == 1 }, "state-popup-item flexacenter flex1"])}"><div class="">匿名发表</div><img class="state-popup-icon"${ssrRenderAttr("src", _imports_33)}></div></div>`);
        } else {
          _push(`<!---->`);
        }
        _push(`</div><img class="edit-icon"${ssrRenderAttr("src", _imports_13)}></div></div>`);
      });
      _push(`<!--]--></div>`);
    } else {
      _push(`<!---->`);
    }
    if ($setup.myType == "questions" && $setup.myQuestionsList.length != 0) {
      _push(`<div class="content-box questions-list"><!--[-->`);
      ssrRenderList($setup.myQuestionsList, (item, index) => {
        _push(`<div class="item flexflex"><div class="icon q flexcenter">Q</div><div class="centre flexflex flex1"><div class="info flexacenter"><div class="name">${ssrInterpolate(item["nickname"])}</div><div class="time">${ssrInterpolate($setup.handleDate(item["publicationdate"]))}</div></div><div class="titletitle ellipsis">${ssrInterpolate(item["title"])}</div><div class="text flexacenter">`);
        if (item["authornewnum"] > 0) {
          _push(`<div class="new-answer flexacenter"> 有${ssrInterpolate(item["authornewnum"])}个新回答 <div class="long-string"></div></div>`);
        } else {
          _push(`<!---->`);
        }
        _push(` ${ssrInterpolate(item["answers"] == 0 ? "暂无回答" : "共" + item["answers"] + "个回答")}</div></div><div class="operate-box flexacenter"><div class="state-box flexacenter"><div class="text">${ssrInterpolate(item["anonymous"] == 0 ? "公开" : "匿名")}</div><img class="arrows"${ssrRenderAttr("src", _imports_32)}>`);
        if (item["popupState"]) {
          _push(`<div class="state-popup flexflex"><div class="${ssrRenderClass([{ pitch: item["anonymous"] == 0 }, "state-popup-item flexacenter flex1"])}"><div class="">公开发表</div><img class="state-popup-icon"${ssrRenderAttr("src", _imports_33)}></div><div class="${ssrRenderClass([{ pitch: item["anonymous"] == 1 }, "state-popup-item flexacenter flex1"])}"><div class="">匿名发表</div><img class="state-popup-icon"${ssrRenderAttr("src", _imports_33)}></div></div>`);
        } else {
          _push(`<!---->`);
        }
        _push(`</div></div></div>`);
      });
      _push(`<!--]--></div>`);
    } else {
      _push(`<!---->`);
    }
    _push(`</div></div>`);
  } else {
    _push(`<!---->`);
  }
  if ($setup.questionsSetp) {
    _push(`<div class="popover-mask flexcenter issue-box">`);
    if ($setup.questionsSetp == 1) {
      _push(`<div class="choosing-theme"><div class="titletitle"> 选择提问所属主题 </div><div class="theme-list flexflex"><!--[-->`);
      ssrRenderList($setup.questionsTypeList, (item, index) => {
        _push(`<div class="theme-stair-box flexflex"><!--[-->`);
        ssrRenderList(item, (item2) => {
          _push(`<div class="theme-item flexcenter">${ssrInterpolate(item2.name)}</div>`);
        });
        _push(`<!--]--></div>`);
      });
      _push(`<!--]--></div></div>`);
    } else {
      _push(`<div class="issue-form"><img class="issue-bj"${ssrRenderAttr("src", _imports_34)}><div class="flexcenter q">Q</div><img class="cross-icon"${ssrRenderAttr("src", _imports_11)}><div class="issue-input"><textarea placeholder="一句话描述问题,以问号结尾">${ssrInterpolate($setup.questionsObj.title)}</textarea></div><textarea class="issue-replenish" placeholder="欢迎补充,清晰表达问题的关键点,可获得更有效的解答(非必填)">${ssrInterpolate($setup.questionsObj.content)}</textarea><div class="issue-bottom flexacenter"><div class="option-box flexacenter" style="${ssrRenderStyle({ "color": "#333" })}">`);
      if ($setup.questionsObj.anonymous == 0) {
        _push(`<img class="option-icon"${ssrRenderAttr("src", _imports_28)}>`);
      } else {
        _push(`<img class="option-icon"${ssrRenderAttr("src", _imports_29)}>`);
      }
      _push(` 匿名发表 <div class="" style="${ssrRenderStyle({ "color": "#aaa" })}">(发布后只能修改是否匿名)</div></div><div class="issue-btn flexcenter">发布问题</div></div></div>`);
    }
    _push(`</div>`);
  } else {
    _push(`<!---->`);
  }
  if ($setup.IAnswerEditState) {
    _push(`<div class="popover-mask flexcenter"><div class="edit-answers"><img class="close-icon"${ssrRenderAttr("src", _imports_11)}><div class="titletitle">编辑回答</div><div class="${ssrRenderClass([{ placeholder: $setup.questionPlaceholderState }, "question-textarea"])}" contenteditable="true">${$setup.IAnswerInfo["text"]}</div><div class="issue-bottom flexacenter"><div class="option-box flexacenter">`);
    if ($setup.IAnswerInfo["anonymous"] == 0) {
      _push(`<img class="option-icon"${ssrRenderAttr("src", _imports_28)}>`);
    } else {
      _push(`<img class="option-icon"${ssrRenderAttr("src", _imports_29)}>`);
    }
    _push(` 匿名发表 </div><div class="issue-btn flexcenter">提交回答</div></div></div></div>`);
  } else {
    _push(`<!---->`);
  }
  if ($setup.IAnswerState) {
    _push(`<div class="popover-mask flexcenter"><div class="i-answer-box flexflex"><img class="close-icon"${ssrRenderAttr("src", _imports_11)}><div class="question-header"><div class="question-title flexflex"><div class="question-icon flexcenter">Q</div><div class="flex1">${$setup.IAnswerInfo["title"]}</div></div>`);
    if ($setup.IAnswerInfo["content"]) {
      _push(`<div class="question-replenish">${$setup.IAnswerInfo["content"]}</div>`);
    } else {
      _push(`<!---->`);
    }
    _push(`</div><div class="question-middle flexflex"><div class="question-icon flexcenter">A</div><div class="${ssrRenderClass([{ placeholder: $setup.questionPlaceholderState }, "question-textarea"])}" contenteditable="true">${$setup.IAnswerInfo["text"]}</div></div><div class="issue-bottom flexacenter"><div class="option-box flexacenter">`);
    if ($setup.IAnswerInfo["anonymous"] == 0) {
      _push(`<img class="option-icon"${ssrRenderAttr("src", _imports_28)}>`);
    } else {
      _push(`<img class="option-icon"${ssrRenderAttr("src", _imports_29)}>`);
    }
    _push(` 匿名发表 </div><div class="issue-btn flexcenter">提交回答</div></div></div></div>`);
  } else {
    _push(`<!---->`);
  }
  _push(`<template><div class="${ssrRenderClass([$setup.boxClass(), "box-item"])}" style="${ssrRenderStyle({ top: "20px" })}"><div class="msg-container">${ssrInterpolate($setup.msg["text"])}</div></div></template>`);
  if ($setup.dialogSrc) {
    _push(`<div class="detail-image-mask flexcenter"><div class="detail-image flexcenter"><img class="detail-img"${ssrRenderAttr("src", $setup.dialogSrc)}></div></div>`);
  } else {
    _push(`<!---->`);
  }
  _push(`<div class="alert-form" style="${ssrRenderStyle($setup.alertShow ? null : { display: "none" })}"><div class="comments reports"><div class="head"><span style="${ssrRenderStyle({ "display": "flex", "align-items": "center" })}"><img style="${ssrRenderStyle({ "width": "25px", "margin-right": "7px" })}" src="//app.gter.net/image/gter/offer/img/exclamationpoint.png?v=4.2.08_331040000">举报投诉</span><div class="close icon-close iconfont"></div></div><div class="form"><div class="radio-area flexacenter"><!--[-->`);
  ssrRenderList($setup.reasonList, (s, i) => {
    _push(`<div class="${ssrRenderClass([{ pitch: $setup.checkList.includes(s) }, "radio-area-item flexacenter"])}"><div class="radio-area-frame"></div> ${ssrInterpolate(s)}</div>`);
  });
  _push(`<!--]--></div><div class="text-box"><textarea placeholder="请输入举报原因" maxlength="200">${ssrInterpolate($setup.alertText)}</textarea><div class="text-num">${ssrInterpolate(200 - $setup.alertText.length)}</div></div><div class="footer"><button type="button">取消</button><button type="submit"${ssrIncludeBooleanAttr($setup.checkList.length == 0) ? " disabled" : ""}>提交</button></div></div></div></div></div></div><!--]-->`);
}
const _sfc_setup$2 = _sfc_main$2.setup;
_sfc_main$2.setup = (props, ctx) => {
  const ssrContext = useSSRContext();
  (ssrContext.modules || (ssrContext.modules = /* @__PURE__ */ new Set())).add("app.vue");
  return _sfc_setup$2 ? _sfc_setup$2(props, ctx) : void 0;
};
const AppComponent = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["ssrRender", _sfc_ssrRender]]);
const _sfc_main$1 = {
  __name: "nuxt-error-page",
  __ssrInlineRender: true,
  props: {
    error: Object
  },
  setup(__props) {
    const props = __props;
    const _error = props.error;
    (_error.stack || "").split("\n").splice(1).map((line) => {
      const text = line.replace("webpack:/", "").replace(".vue", ".js").trim();
      return {
        text,
        internal: line.includes("node_modules") && !line.includes(".cache") || line.includes("internal") || line.includes("new Promise")
      };
    }).map((i) => `<span class="stack${i.internal ? " internal" : ""}">${i.text}</span>`).join("\n");
    const statusCode = Number(_error.statusCode || 500);
    const is404 = statusCode === 404;
    const statusMessage = _error.statusMessage ?? (is404 ? "Page Not Found" : "Internal Server Error");
    const description = _error.message || _error.toString();
    const stack = void 0;
    const _Error404 = defineAsyncComponent(() => import('./static/error-404-b567fef8.mjs').then((r) => r.default || r));
    const _Error = defineAsyncComponent(() => import('./static/error-500-fd968d91.mjs').then((r) => r.default || r));
    const ErrorTemplate = is404 ? _Error404 : _Error;
    return (_ctx, _push, _parent, _attrs) => {
      _push(ssrRenderComponent(unref(ErrorTemplate), mergeProps({ statusCode: unref(statusCode), statusMessage: unref(statusMessage), description: unref(description), stack: unref(stack) }, _attrs), null, _parent));
    };
  }
};
const _sfc_setup$1 = _sfc_main$1.setup;
_sfc_main$1.setup = (props, ctx) => {
  const ssrContext = useSSRContext();
  (ssrContext.modules || (ssrContext.modules = /* @__PURE__ */ new Set())).add("node_modules/nuxt/dist/app/components/nuxt-error-page.vue");
  return _sfc_setup$1 ? _sfc_setup$1(props, ctx) : void 0;
};
const ErrorComponent = _sfc_main$1;
const _sfc_main = {
  __name: "nuxt-root",
  __ssrInlineRender: true,
  setup(__props) {
    const IslandRenderer = defineAsyncComponent(() => import('./static/island-renderer-4de2a5fd.mjs').then((r) => r.default || r));
    const nuxtApp = /* @__PURE__ */ useNuxtApp();
    nuxtApp.deferHydration();
    nuxtApp.ssrContext.url;
    const SingleRenderer = false;
    provide(PageRouteSymbol, useRoute());
    nuxtApp.hooks.callHookWith((hooks) => hooks.map((hook) => hook()), "vue:setup");
    const error = useError();
    onErrorCaptured((err, target, info) => {
      nuxtApp.hooks.callHook("vue:error", err, target, info).catch((hookError) => console.error("[nuxt] Error in `vue:error` hook", hookError));
      {
        const p = nuxtApp.runWithContext(() => showError(err));
        onServerPrefetch(() => p);
        return false;
      }
    });
    const islandContext = nuxtApp.ssrContext.islandContext;
    return (_ctx, _push, _parent, _attrs) => {
      ssrRenderSuspense(_push, {
        default: () => {
          if (unref(error)) {
            _push(ssrRenderComponent(unref(ErrorComponent), { error: unref(error) }, null, _parent));
          } else if (unref(islandContext)) {
            _push(ssrRenderComponent(unref(IslandRenderer), { context: unref(islandContext) }, null, _parent));
          } else if (unref(SingleRenderer)) {
            ssrRenderVNode(_push, createVNode(resolveDynamicComponent(unref(SingleRenderer)), null, null), _parent);
          } else {
            _push(ssrRenderComponent(unref(AppComponent), null, null, _parent));
          }
        },
        _: 1
      });
    };
  }
};
const _sfc_setup = _sfc_main.setup;
_sfc_main.setup = (props, ctx) => {
  const ssrContext = useSSRContext();
  (ssrContext.modules || (ssrContext.modules = /* @__PURE__ */ new Set())).add("node_modules/nuxt/dist/app/components/nuxt-root.vue");
  return _sfc_setup ? _sfc_setup(props, ctx) : void 0;
};
const RootComponent = _sfc_main;
let entry;
{
  entry = async function createNuxtAppServer(ssrContext) {
    const vueApp = createApp(RootComponent);
    const nuxt = createNuxtApp({ vueApp, ssrContext });
    try {
      await applyPlugins(nuxt, plugins);
      await nuxt.hooks.callHook("app:created", vueApp);
    } catch (err) {
      await nuxt.hooks.callHook("app:error", err);
      nuxt.payload.error = nuxt.payload.error || err;
    }
    if (ssrContext == null ? void 0 : ssrContext._renderResponse) {
      throw new Error("skipping render");
    }
    return vueApp;
  };
}
const entry$1 = (ctx) => entry(ctx);

export { _export_sfc as _, useRuntimeConfig as a, useHead as b, createError as c, entry$1 as default, navigateTo as n, useRouter as u };
//# sourceMappingURL=server.mjs.map