3048 lines
151 KiB
JavaScript
3048 lines
151 KiB
JavaScript
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 = "";
|
|
const _imports_15 = "";
|
|
const _imports_16 = "" + __buildAssetsURL("edit-icon-white.29b27582.svg");
|
|
const _imports_17 = "" + __buildAssetsURL("view-icon.da7fef35.svg");
|
|
const _imports_18 = "";
|
|
const _imports_19 = "" + __buildAssetsURL("collect-icon-colours.6d2ade7f.svg");
|
|
const _imports_20 = "";
|
|
const _imports_21 = "";
|
|
const _imports_22 = "";
|
|
const _imports_23 = "" + __buildAssetsURL("title.98892974.png");
|
|
const _imports_24 = "";
|
|
const _imports_25 = "";
|
|
const _imports_26 = "";
|
|
const _imports_27 = "" + __buildAssetsURL("menu-icon-gray.d61f02b1.svg");
|
|
const _imports_28 = "" + __buildAssetsURL("comment-icon-gray.2c8779f9.svg");
|
|
const _imports_29 = "";
|
|
const _imports_30 = "";
|
|
const _imports_31 = "" + __buildAssetsURL("tick-no.179037b3.svg");
|
|
const _imports_32 = "" + __buildAssetsURL("tick-option.e092d22f.svg");
|
|
const _imports_33 = "" + __buildAssetsURL("QRCode-icon.a105d5fc.svg");
|
|
const _imports_34 = "" + __buildAssetsURL("delete-icon.4d386dce.svg");
|
|
const _imports_35 = "" + __buildAssetsURL("arrows-icon.271dd0d3.svg");
|
|
const _imports_36 = "" + __buildAssetsURL("tick-orange.233abc69.svg");
|
|
const _imports_37 = "" + __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);
|
|
});
|
|
});
|
|
};
|
|
const $ajaxGET = (url, data) => {
|
|
url = url.indexOf("//") > -1 ? url : baseURL2 + url;
|
|
return new Promise(function(resolve, reject) {
|
|
axios.get(url, data, {
|
|
emulateJSON: true,
|
|
withCredentials: true,
|
|
headers: {
|
|
authorization: "production" !== "production"
|
|
// 头部标记
|
|
// "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";
|
|
openBottom();
|
|
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";
|
|
openBottom();
|
|
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";
|
|
openBottom();
|
|
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";
|
|
closeBottom();
|
|
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
|
|
};
|
|
detailsAreaScrollTop();
|
|
}).finally(() => {
|
|
detailLoading.value = false;
|
|
});
|
|
};
|
|
const detailsAreaScrollTop = () => {
|
|
let detailsArea = document.querySelector(".details-area-box");
|
|
detailsArea.scrollTo({
|
|
top: 0,
|
|
behavior: "smooth"
|
|
});
|
|
};
|
|
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);
|
|
};
|
|
const getAnswerCommentList = (index) => {
|
|
getAnswerCommentPublic(index, 3).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) => {
|
|
getAnswerCommentPublic(index, 1e3).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;
|
|
});
|
|
};
|
|
const getAnswerCommentPublic = (index, limit) => {
|
|
return new Promise((resolve, reject) => {
|
|
$ajax("/api/comment/lists", {
|
|
token: answerList.value[index]["token"],
|
|
// limit: answerCommentLimit,
|
|
limit,
|
|
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"][i]["commentInput"] = "";
|
|
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"]++;
|
|
targetAnswerList[index]["commentList"][ind]["commentInput"] = "";
|
|
} 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]["commentInput"] = "";
|
|
}
|
|
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";
|
|
data.data.forEach((element) => {
|
|
if (element["type"] == "askanswercollection") {
|
|
let content = element["data"]["content"];
|
|
element["data"]["content"] = processHtml(content);
|
|
}
|
|
});
|
|
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 processHtml = (html) => {
|
|
var parser = new DOMParser();
|
|
var doc = parser.parseFromString(html, "text/html");
|
|
var img = doc.querySelector("img");
|
|
if (img) {
|
|
return `<img src="${img.src}">`;
|
|
} else {
|
|
return doc.body.textContent;
|
|
}
|
|
};
|
|
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;
|
|
});
|
|
data.data.forEach((element) => {
|
|
let content = element["content"];
|
|
element["content"] = processHtml(content);
|
|
});
|
|
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 bottomTpsStyle = (index, content) => {
|
|
const newtype = type.value;
|
|
let obj = {};
|
|
if (newtype == "list")
|
|
;
|
|
else {
|
|
obj["width"] = "calc(50vw - 88px)";
|
|
obj["paddingLeft"] = "calc((100vw - 1200px) / 2)";
|
|
obj["borderRight"] = "1px solid #ebebeb";
|
|
}
|
|
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) => {
|
|
$ajaxGET("/api/operate/share?token=" + token);
|
|
};
|
|
const closeDetailMode = () => {
|
|
type.value = "list";
|
|
openBottom();
|
|
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";
|
|
openBottom();
|
|
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"];
|
|
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());
|
|
};
|
|
let avatarState = ref(false);
|
|
const openUserInfo = (index, ind, i) => {
|
|
if (i != null) {
|
|
if (answerList.value[index].commentList[ind]["child"][i]["uin"] > 0)
|
|
answerList.value[index].commentList[ind]["child"][i]["avatarState"] = !answerList.value[index].commentList[ind]["child"][i]["avatarState"];
|
|
} else if (ind != null) {
|
|
if (answerList.value[index].commentList[ind]["uin"] > 0)
|
|
answerList.value[index].commentList[ind]["avatarState"] = !answerList.value[index].commentList[ind]["avatarState"];
|
|
} else if (index != null) {
|
|
if (answerList.value[index]["uin"] > 0)
|
|
answerList.value[index]["avatarState"] = !answerList.value[index]["avatarState"];
|
|
} else {
|
|
if (detailsInfo["uin"] > 0)
|
|
avatarState.value = !avatarState.value;
|
|
}
|
|
};
|
|
const sendMessage = (uin) => {
|
|
redirectToExternalWebsite(`https://bbs.gter.net/home.php?mod=space&showmsg=1&uid=${uin}`);
|
|
};
|
|
const TAHomePage = (uin) => {
|
|
redirectToExternalWebsite(`https://bbs.gter.net/home.php?mod=space&uid=${uin}`);
|
|
};
|
|
const redirectToExternalWebsite = (url) => {
|
|
const link = document.createElement("a");
|
|
link.href = url;
|
|
link.target = "_blank";
|
|
link.click();
|
|
};
|
|
const closeBottom = () => {
|
|
const footer = document.querySelector("body .index-footer");
|
|
if (footer)
|
|
footer.style.display = "none";
|
|
else
|
|
setTimeout(() => closeBottom(), 1e3);
|
|
};
|
|
const openBottom = () => {
|
|
const footer = document.querySelector("body .index-footer");
|
|
if (footer)
|
|
footer.style.display = "block";
|
|
else
|
|
setTimeout(() => openBottom(), 1e3);
|
|
};
|
|
return {
|
|
bottomTpsStyle,
|
|
TAHomePage,
|
|
sendMessage,
|
|
avatarState,
|
|
openUserInfo,
|
|
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" style="${ssrRenderStyle($setup.bottomTpsStyle())}">- 到底了 -</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>`);
|
|
if ($setup.avatarState) {
|
|
_push(`<div class="avatar-box flexflex"><a class="avatar-item flexcenter" target="_blank"><img class="avatar-icon"${ssrRenderAttr("src", _imports_13)}> 发送信息 </a><a class="avatar-item flexcenter" target="_blank"><img class="avatar-icon"${ssrRenderAttr("src", _imports_14)}> TA的主页 </a><div class="avatar-mask"></div></div>`);
|
|
} else {
|
|
_push(`<!---->`);
|
|
}
|
|
_push(`</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_15)}><img class="answer-btn-icon answer-icon-white"${ssrRenderAttr("src", _imports_16)}> 我来回答 </div><div class="operate-list flexacenter"><div class="operate-item flexacenter" style="${ssrRenderStyle({ "cursor": "auto" })}"><img class="operate-icon operate-collect-icon" style="${ssrRenderStyle({ "width": "13px", "height": "8px" })}"${ssrRenderAttr("src", _imports_17)}> ${ssrInterpolate($setup.detailsInfo["viewnum"] || 0)}</div><div class="operate-item flexacenter">`);
|
|
if ($setup.detailsIscollection == 0) {
|
|
_push(`<img class="operate-icon operate-collect-icon"${ssrRenderAttr("src", _imports_18)}>`);
|
|
} else {
|
|
_push(`<img class="operate-icon operate-collect-icon"${ssrRenderAttr("src", _imports_19)}>`);
|
|
}
|
|
_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_20)}> 转发 `);
|
|
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_21)}> 扫码转发该问答 </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_22)}><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_23)}>`);
|
|
} else {
|
|
_push(`<!---->`);
|
|
}
|
|
if (item["avatarState"]) {
|
|
_push(`<div class="avatar-box flexflex"><a class="avatar-item flexcenter" target="_blank"><img class="avatar-icon"${ssrRenderAttr("src", _imports_13)}> 发送信息 </a><a class="avatar-item flexcenter" target="_blank"><img class="avatar-icon"${ssrRenderAttr("src", _imports_14)}> TA的主页 </a><div class="avatar-mask"></div></div>`);
|
|
} 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_15)}></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_24)}>`);
|
|
} else {
|
|
_push(`<img class="operate-icon operate-like-icon"${ssrRenderAttr("src", _imports_25)}>`);
|
|
}
|
|
_push(` ${ssrInterpolate(item["likenum"])}</div><div class="${ssrRenderClass([{ commentnum: item["commentState"] }, "operate-item flexacenter"])}"><img class="operate-icon operate-comment-icon"${ssrRenderAttr("src", _imports_26)}>${ssrInterpolate(item["commentnum"])}</div><div class="operate-item flexacenter">`);
|
|
if (item["iscollection"] == 1) {
|
|
_push(`<img class="operate-icon operate-collect-icon"${ssrRenderAttr("src", _imports_19)}>`);
|
|
} else {
|
|
_push(`<img class="operate-icon operate-collect-icon"${ssrRenderAttr("src", _imports_18)}>`);
|
|
}
|
|
_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_20)}> 转发 `);
|
|
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_21)}> 扫码转发该问答 </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(`<!---->`);
|
|
}
|
|
if (it["avatarState"]) {
|
|
_push(`<div class="avatar-box flexflex"><a class="avatar-item flexcenter" target="_blank"><img class="avatar-icon"${ssrRenderAttr("src", _imports_13)}> 发送信息 </a><a class="avatar-item flexcenter" target="_blank"><img class="avatar-icon"${ssrRenderAttr("src", _imports_14)}> TA的主页 </a><div class="avatar-mask"></div></div>`);
|
|
} else {
|
|
_push(`<!---->`);
|
|
}
|
|
_push(`</div><div class="comments-header-right flexacenter"><div class="menu-box flexacenter"><img class="menu-icon"${ssrRenderAttr("src", _imports_27)}><div class="report-box flexcenter">举报</div></div><img class="comment-icon"${ssrRenderAttr("src", _imports_28)}><div class="flexacenter like-box">`);
|
|
if (it["islike"] == 0) {
|
|
_push(`<img class="like-icon"${ssrRenderAttr("src", _imports_29)}>`);
|
|
} else {
|
|
_push(`<img class="like-icon"${ssrRenderAttr("src", _imports_24)}>`);
|
|
}
|
|
_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(`<!---->`);
|
|
}
|
|
if (ite["avatarState"]) {
|
|
_push(`<div class="avatar-box flexflex"><a class="avatar-item flexcenter" target="_blank"><img class="avatar-icon"${ssrRenderAttr("src", _imports_13)}> 发送信息 </a><a class="avatar-item flexcenter" target="_blank"><img class="avatar-icon"${ssrRenderAttr("src", _imports_14)}> TA的主页 </a><div class="avatar-mask"></div></div>`);
|
|
} else {
|
|
_push(`<!---->`);
|
|
}
|
|
_push(`</div><div class="comments-header-right flexacenter"><div class="menu-box flexacenter"><img class="menu-icon"${ssrRenderAttr("src", _imports_27)}><div class="report-box flexcenter">举报</div></div><img class="comment-icon"${ssrRenderAttr("src", _imports_28)}><div class="flexacenter like-box">`);
|
|
if (ite["islike"] == 0) {
|
|
_push(`<img class="like-icon"${ssrRenderAttr("src", _imports_29)}>`);
|
|
} else {
|
|
_push(`<img class="like-icon"${ssrRenderAttr("src", _imports_24)}>`);
|
|
}
|
|
_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"] > it["child"].length) {
|
|
_push(`<div class="comments-also flexacenter"><div class="">还有${ssrInterpolate(it["childnum"] - 1)}条回复</div><img class="also-icon"${ssrRenderAttr("src", _imports_30)}></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_30)}></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_31)}>`);
|
|
} else {
|
|
_push(`<img class="option-icon"${ssrRenderAttr("src", _imports_32)}>`);
|
|
}
|
|
_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_33)} 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_21)}> 微信扫一扫 </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_34)}></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_34)}></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_35)}>`);
|
|
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_36)}></div><div class="${ssrRenderClass([{ pitch: item["anonymous"] == 1 }, "state-popup-item flexacenter flex1"])}"><div class="">匿名发表</div><img class="state-popup-icon"${ssrRenderAttr("src", _imports_36)}></div></div>`);
|
|
} else {
|
|
_push(`<!---->`);
|
|
}
|
|
_push(`</div><img class="edit-icon"${ssrRenderAttr("src", _imports_15)}></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_35)}>`);
|
|
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_36)}></div><div class="${ssrRenderClass([{ pitch: item["anonymous"] == 1 }, "state-popup-item flexacenter flex1"])}"><div class="">匿名发表</div><img class="state-popup-icon"${ssrRenderAttr("src", _imports_36)}></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_37)}><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_31)}>`);
|
|
} else {
|
|
_push(`<img class="option-icon"${ssrRenderAttr("src", _imports_32)}>`);
|
|
}
|
|
_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_31)}>`);
|
|
} else {
|
|
_push(`<img class="option-icon"${ssrRenderAttr("src", _imports_32)}>`);
|
|
}
|
|
_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_31)}>`);
|
|
} else {
|
|
_push(`<img class="option-icon"${ssrRenderAttr("src", _imports_32)}>`);
|
|
}
|
|
_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
|