var __defProp = Object.defineProperty; var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); import { d as defineComponent, aX as useUserStore, bW as useRouter, ab as ref, c as computed, m as onMounted, o as openBlock, k as createBlock, M as withCtx, H as createBaseVNode, X as toDisplayString, N as createVNode, bX as withKeys, j as unref, av as script, bQ as script$1, bY as script$2, bZ as script$3, aE as createTextVNode, I as createCommentVNode, l as script$4 } from "./index-CJmKJOqY.js"; import { _ as _sfc_main$1 } from "./BaseViewTemplate-B0LQc8op.js"; const _hoisted_1 = { id: "comfy-user-selection", class: "min-w-84 relative rounded-lg bg-[var(--comfy-menu-bg)] p-5 px-10 shadow-lg" }; const _hoisted_2 = /* @__PURE__ */ createBaseVNode("h1", { class: "my-2.5 mb-7 font-normal" }, "ComfyUI", -1); const _hoisted_3 = { class: "flex w-full flex-col items-center" }; const _hoisted_4 = { class: "flex w-full flex-col gap-2" }; const _hoisted_5 = { for: "new-user-input" }; const _hoisted_6 = { class: "flex w-full flex-col gap-2" }; const _hoisted_7 = { for: "existing-user-select" }; const _hoisted_8 = { class: "mt-5" }; const _sfc_main = /* @__PURE__ */ defineComponent({ __name: "UserSelectView", setup(__props) { const userStore = useUserStore(); const router = useRouter(); const selectedUser = ref(null); const newUsername = ref(""); const loginError = ref(""); const createNewUser = computed(() => newUsername.value.trim() !== ""); const newUserExistsError = computed(() => { return userStore.users.find((user) => user.username === newUsername.value) ? `User "${newUsername.value}" already exists` : ""; }); const error = computed(() => newUserExistsError.value || loginError.value); const login = /* @__PURE__ */ __name(async () => { try { const user = createNewUser.value ? await userStore.createUser(newUsername.value) : selectedUser.value; if (!user) { throw new Error("No user selected"); } userStore.login(user); router.push("/"); } catch (err) { loginError.value = err.message ?? JSON.stringify(err); } }, "login"); onMounted(async () => { if (!userStore.initialized) { await userStore.initialize(); } }); return (_ctx, _cache) => { return openBlock(), createBlock(_sfc_main$1, { dark: "" }, { default: withCtx(() => [ createBaseVNode("main", _hoisted_1, [ _hoisted_2, createBaseVNode("div", _hoisted_3, [ createBaseVNode("div", _hoisted_4, [ createBaseVNode("label", _hoisted_5, toDisplayString(_ctx.$t("userSelect.newUser")) + ":", 1), createVNode(unref(script), { id: "new-user-input", modelValue: newUsername.value, "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => newUsername.value = $event), placeholder: _ctx.$t("userSelect.enterUsername"), onKeyup: withKeys(login, ["enter"]) }, null, 8, ["modelValue", "placeholder"]) ]), createVNode(unref(script$1)), createBaseVNode("div", _hoisted_6, [ createBaseVNode("label", _hoisted_7, toDisplayString(_ctx.$t("userSelect.existingUser")) + ":", 1), createVNode(unref(script$2), { modelValue: selectedUser.value, "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => selectedUser.value = $event), class: "w-full", inputId: "existing-user-select", options: unref(userStore).users, "option-label": "username", placeholder: _ctx.$t("userSelect.selectUser"), disabled: createNewUser.value }, null, 8, ["modelValue", "options", "placeholder", "disabled"]), error.value ? (openBlock(), createBlock(unref(script$3), { key: 0, severity: "error" }, { default: withCtx(() => [ createTextVNode(toDisplayString(error.value), 1) ]), _: 1 })) : createCommentVNode("", true) ]), createBaseVNode("footer", _hoisted_8, [ createVNode(unref(script$4), { label: _ctx.$t("userSelect.next"), onClick: login }, null, 8, ["label"]) ]) ]) ]) ]), _: 1 }); }; } }); export { _sfc_main as default }; //# sourceMappingURL=UserSelectView-Z5q8PIoK.js.map