mirror of
https://github.com/comfyanonymous/ComfyUI.git
synced 2025-01-11 10:25:16 +00:00
9275 lines
378 KiB
JavaScript
Vendored
Generated
9275 lines
378 KiB
JavaScript
Vendored
Generated
var __defProp = Object.defineProperty;
|
||
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
||
import { d as defineStore, s as shallowRef, a as defineComponent, u as useSettingStore, r as ref, w as watch, L as LGraphGroup, b as app, c as LGraphNode, o as onMounted, e as onUnmounted, f as openBlock, g as createElementBlock, h as createVNode, E as EditableText, n as normalizeStyle, i as createCommentVNode, j as LiteGraph, _ as _export_sfc, B as BaseStyle, k as script$e, l as resolveComponent, m as mergeProps, p as renderSlot, q as computed, t as resolveDirective, v as withDirectives, x as createBlock, y as withCtx, z as unref, A as createBaseVNode, C as normalizeClass, D as script$f, F as useCommandStore, G as useDialogStore, S as SettingDialogHeader, H as SettingDialogContent, I as useI18n, J as useUserStore, K as onBeforeUnmount, M as resolveDynamicComponent, N as useWorkspaceStore, O as useKeybindingStore, P as Fragment, Q as renderList, T as Teleport, R as pushScopeId, U as popScopeId, V as script$g, W as getWidth, X as findSingle, Y as getOuterHeight, Z as getOffset, $ as getOuterWidth, a0 as getHeight, a1 as script$h, a2 as script$i, a3 as Ripple, a4 as getAttribute, a5 as focus, a6 as equals, a7 as useBottomPanelStore, a8 as toDisplayString, a9 as script$j, aa as getVNodeProp, ab as isArray, ac as useSidebarTabStore, ad as vShow, ae as isNotEmpty, af as UniqueComponentId, ag as ZIndex, ah as resolveFieldData, ai as OverlayEventBus, aj as isEmpty, ak as addStyle, al as relativePosition, am as absolutePosition, an as ConnectedOverlayScrollHandler, ao as isTouchDevice, ap as findLastIndex, aq as script$k, ar as script$l, as as script$m, at as script$n, au as script$o, av as script$p, aw as Transition, ax as createSlots, ay as createTextVNode, az as useNodeFrequencyStore, aA as useNodeBookmarkStore, aB as highlightQuery, aC as script$q, aD as formatNumberWithSuffix, aE as NodeSourceType, aF as useNodeDefStore, aG as NodePreview, aH as NodeSearchFilter, aI as script$r, aJ as SearchFilterChip, aK as storeToRefs, aL as watchEffect, aM as useEventListener, aN as isRef, aO as toRaw, aP as LinkReleaseTriggerAction, aQ as nextTick, aR as st, aS as normalizeI18nKey, aT as getColorPalette, aU as BadgePosition, aV as LGraphBadge, aW as _, aX as defaultColorPalette, aY as NodeBadgeMode, aZ as markRaw, a_ as useModelToNodeStore, a$ as CanvasPointer, b0 as useWorkflowStore, b1 as setStorageValue, b2 as api, b3 as usePragmaticDroppable, b4 as ComfyNodeDefImpl, b5 as ComfyModelDef, b6 as LGraph, b7 as LLink, b8 as DragAndScale, b9 as LGraphCanvas, ba as ContextMenu, bb as ChangeTracker, bc as workflowService, bd as showNativeMenu, be as script$s, bf as script$t, bg as script$u, bh as script$v, bi as script$w, bj as normalizeProps, bk as ToastEventBus, bl as setAttribute, bm as TransitionGroup, bn as useToast, bo as useToastStore, bp as useExecutionStore, bq as useTitle, br as withModifiers, bs as script$x, bt as script$y, bu as resolve, bv as script$z, bw as script$A, bx as isPrintableCharacter, by as guardReactiveProps, bz as useMenuItemStore, bA as script$D, bB as nestedPosition, bC as useQueueSettingsStore, bD as script$E, bE as useQueuePendingTaskCountStore, bF as useLocalStorage, bG as useDraggable, bH as watchDebounced, bI as inject, bJ as useElementBounding, bK as lodashExports, bL as useEventBus, bM as provide, bN as script$F, bO as LGraphEventMode, bP as useQueueStore, bQ as showTemplateWorkflowsDialog, bR as showSettingsDialog, bS as i18n, bT as useModelStore } from "./index-DIU5yZe9.js";
|
||
import { s as script$B, a as script$C } from "./index-d698Brhb.js";
|
||
import { u as useServerConfigStore } from "./serverConfigStore-DYv7_Nld.js";
|
||
const useTitleEditorStore = defineStore("titleEditor", () => {
|
||
const titleEditorTarget = shallowRef(null);
|
||
return {
|
||
titleEditorTarget
|
||
};
|
||
});
|
||
const useCanvasStore = defineStore("canvas", () => {
|
||
const canvas = shallowRef(null);
|
||
return {
|
||
canvas
|
||
};
|
||
});
|
||
const _sfc_main$s = /* @__PURE__ */ defineComponent({
|
||
__name: "TitleEditor",
|
||
setup(__props) {
|
||
const settingStore = useSettingStore();
|
||
const showInput = ref(false);
|
||
const editedTitle = ref("");
|
||
const inputStyle = ref({
|
||
position: "fixed",
|
||
left: "0px",
|
||
top: "0px",
|
||
width: "200px",
|
||
height: "20px",
|
||
fontSize: "12px"
|
||
});
|
||
const titleEditorStore = useTitleEditorStore();
|
||
const canvasStore = useCanvasStore();
|
||
const previousCanvasDraggable = ref(true);
|
||
const onEdit = /* @__PURE__ */ __name((newValue) => {
|
||
if (titleEditorStore.titleEditorTarget && newValue.trim() !== "") {
|
||
titleEditorStore.titleEditorTarget.title = newValue.trim();
|
||
app.graph.setDirtyCanvas(true, true);
|
||
}
|
||
showInput.value = false;
|
||
titleEditorStore.titleEditorTarget = null;
|
||
canvasStore.canvas.allow_dragcanvas = previousCanvasDraggable.value;
|
||
}, "onEdit");
|
||
watch(
|
||
() => titleEditorStore.titleEditorTarget,
|
||
(target) => {
|
||
if (target === null) {
|
||
return;
|
||
}
|
||
editedTitle.value = target.title;
|
||
showInput.value = true;
|
||
previousCanvasDraggable.value = canvasStore.canvas.allow_dragcanvas;
|
||
canvasStore.canvas.allow_dragcanvas = false;
|
||
if (target instanceof LGraphGroup) {
|
||
const group = target;
|
||
const [x, y] = group.pos;
|
||
const [w, h] = group.size;
|
||
const [left, top] = app.canvasPosToClientPos([x, y]);
|
||
inputStyle.value.left = `${left}px`;
|
||
inputStyle.value.top = `${top}px`;
|
||
const width = w * app.canvas.ds.scale;
|
||
const height = group.titleHeight * app.canvas.ds.scale;
|
||
inputStyle.value.width = `${width}px`;
|
||
inputStyle.value.height = `${height}px`;
|
||
const fontSize = group.font_size * app.canvas.ds.scale;
|
||
inputStyle.value.fontSize = `${fontSize}px`;
|
||
} else if (target instanceof LGraphNode) {
|
||
const node = target;
|
||
const [x, y] = node.getBounding();
|
||
const canvasWidth = node.width;
|
||
const canvasHeight = LiteGraph.NODE_TITLE_HEIGHT;
|
||
const [left, top] = app.canvasPosToClientPos([x, y]);
|
||
inputStyle.value.left = `${left}px`;
|
||
inputStyle.value.top = `${top}px`;
|
||
const width = canvasWidth * app.canvas.ds.scale;
|
||
const height = canvasHeight * app.canvas.ds.scale;
|
||
inputStyle.value.width = `${width}px`;
|
||
inputStyle.value.height = `${height}px`;
|
||
const fontSize = 12 * app.canvas.ds.scale;
|
||
inputStyle.value.fontSize = `${fontSize}px`;
|
||
}
|
||
}
|
||
);
|
||
const canvasEventHandler = /* @__PURE__ */ __name((event) => {
|
||
if (!settingStore.get("Comfy.Group.DoubleClickTitleToEdit")) {
|
||
return;
|
||
}
|
||
if (event.detail.subType === "group-double-click") {
|
||
const group = event.detail.group;
|
||
const [x, y] = group.pos;
|
||
const e = event.detail.originalEvent;
|
||
const relativeY = e.canvasY - y;
|
||
if (relativeY > group.titleHeight) {
|
||
return;
|
||
}
|
||
titleEditorStore.titleEditorTarget = group;
|
||
}
|
||
}, "canvasEventHandler");
|
||
const extension = {
|
||
name: "Comfy.NodeTitleEditor",
|
||
nodeCreated(node) {
|
||
const originalCallback = node.onNodeTitleDblClick;
|
||
node.onNodeTitleDblClick = function(e, ...args) {
|
||
if (!settingStore.get("Comfy.Node.DoubleClickTitleToEdit")) {
|
||
return;
|
||
}
|
||
titleEditorStore.titleEditorTarget = this;
|
||
if (typeof originalCallback === "function") {
|
||
originalCallback.call(this, e, ...args);
|
||
}
|
||
};
|
||
}
|
||
};
|
||
onMounted(() => {
|
||
document.addEventListener("litegraph:canvas", canvasEventHandler);
|
||
app.registerExtension(extension);
|
||
});
|
||
onUnmounted(() => {
|
||
document.removeEventListener("litegraph:canvas", canvasEventHandler);
|
||
});
|
||
return (_ctx, _cache) => {
|
||
return showInput.value ? (openBlock(), createElementBlock("div", {
|
||
key: 0,
|
||
class: "group-title-editor node-title-editor",
|
||
style: normalizeStyle(inputStyle.value)
|
||
}, [
|
||
createVNode(EditableText, {
|
||
isEditing: showInput.value,
|
||
modelValue: editedTitle.value,
|
||
onEdit
|
||
}, null, 8, ["isEditing", "modelValue"])
|
||
], 4)) : createCommentVNode("", true);
|
||
};
|
||
}
|
||
});
|
||
const TitleEditor = /* @__PURE__ */ _export_sfc(_sfc_main$s, [["__scopeId", "data-v-8a100d5a"]]);
|
||
var theme$8 = /* @__PURE__ */ __name(function theme(_ref) {
|
||
var dt = _ref.dt;
|
||
return "\n.p-overlaybadge {\n position: relative;\n}\n\n.p-overlaybadge .p-badge {\n position: absolute;\n top: 0;\n right: 0;\n transform: translate(50%, -50%);\n transform-origin: 100% 0;\n margin: 0;\n outline-width: ".concat(dt("overlaybadge.outline.width"), ";\n outline-style: solid;\n outline-color: ").concat(dt("overlaybadge.outline.color"), ";\n}\n");
|
||
}, "theme");
|
||
var classes$b = {
|
||
root: "p-overlaybadge"
|
||
};
|
||
var OverlayBadgeStyle = BaseStyle.extend({
|
||
name: "overlaybadge",
|
||
theme: theme$8,
|
||
classes: classes$b
|
||
});
|
||
var script$1$b = {
|
||
name: "OverlayBadge",
|
||
"extends": script$e,
|
||
style: OverlayBadgeStyle,
|
||
provide: /* @__PURE__ */ __name(function provide2() {
|
||
return {
|
||
$pcOverlayBadge: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script$d = {
|
||
name: "OverlayBadge",
|
||
"extends": script$1$b,
|
||
inheritAttrs: false,
|
||
components: {
|
||
Badge: script$e
|
||
}
|
||
};
|
||
function render$j(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _component_Badge = resolveComponent("Badge");
|
||
return openBlock(), createElementBlock("div", mergeProps({
|
||
"class": _ctx.cx("root")
|
||
}, _ctx.ptmi("root")), [renderSlot(_ctx.$slots, "default"), createVNode(_component_Badge, mergeProps(_ctx.$props, {
|
||
pt: _ctx.ptm("pcBadge")
|
||
}), null, 16, ["pt"])], 16);
|
||
}
|
||
__name(render$j, "render$j");
|
||
script$d.render = render$j;
|
||
const _sfc_main$r = /* @__PURE__ */ defineComponent({
|
||
__name: "SidebarIcon",
|
||
props: {
|
||
icon: String,
|
||
selected: Boolean,
|
||
tooltip: {
|
||
type: String,
|
||
default: ""
|
||
},
|
||
class: {
|
||
type: String,
|
||
default: ""
|
||
},
|
||
iconBadge: {
|
||
type: [String, Function],
|
||
default: ""
|
||
}
|
||
},
|
||
emits: ["click"],
|
||
setup(__props, { emit: __emit }) {
|
||
const props = __props;
|
||
const emit = __emit;
|
||
const overlayValue = computed(
|
||
() => typeof props.iconBadge === "function" ? props.iconBadge() || "" : props.iconBadge
|
||
);
|
||
const shouldShowBadge = computed(() => !!overlayValue.value);
|
||
return (_ctx, _cache) => {
|
||
const _directive_tooltip = resolveDirective("tooltip");
|
||
return withDirectives((openBlock(), createBlock(unref(script$f), {
|
||
class: normalizeClass(props.class),
|
||
text: "",
|
||
pt: {
|
||
root: {
|
||
class: `side-bar-button ${props.selected ? "p-button-primary side-bar-button-selected" : "p-button-secondary"}`,
|
||
"aria-label": props.tooltip
|
||
}
|
||
},
|
||
onClick: _cache[0] || (_cache[0] = ($event) => emit("click", $event))
|
||
}, {
|
||
icon: withCtx(() => [
|
||
shouldShowBadge.value ? (openBlock(), createBlock(unref(script$d), {
|
||
key: 0,
|
||
value: overlayValue.value
|
||
}, {
|
||
default: withCtx(() => [
|
||
createBaseVNode("i", {
|
||
class: normalizeClass(props.icon + " side-bar-button-icon")
|
||
}, null, 2)
|
||
]),
|
||
_: 1
|
||
}, 8, ["value"])) : (openBlock(), createElementBlock("i", {
|
||
key: 1,
|
||
class: normalizeClass(props.icon + " side-bar-button-icon")
|
||
}, null, 2))
|
||
]),
|
||
_: 1
|
||
}, 8, ["class", "pt"])), [
|
||
[_directive_tooltip, { value: props.tooltip, showDelay: 300, hideDelay: 300 }]
|
||
]);
|
||
};
|
||
}
|
||
});
|
||
const SidebarIcon = /* @__PURE__ */ _export_sfc(_sfc_main$r, [["__scopeId", "data-v-caa3ee9c"]]);
|
||
const _sfc_main$q = /* @__PURE__ */ defineComponent({
|
||
__name: "SidebarThemeToggleIcon",
|
||
setup(__props) {
|
||
const settingStore = useSettingStore();
|
||
const currentTheme = computed(() => settingStore.get("Comfy.ColorPalette"));
|
||
const icon = computed(
|
||
() => currentTheme.value !== "light" ? "pi pi-moon" : "pi pi-sun"
|
||
);
|
||
const commandStore = useCommandStore();
|
||
const toggleTheme = /* @__PURE__ */ __name(() => {
|
||
commandStore.execute("Comfy.ToggleTheme");
|
||
}, "toggleTheme");
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createBlock(SidebarIcon, {
|
||
icon: icon.value,
|
||
onClick: toggleTheme,
|
||
tooltip: _ctx.$t("sideToolbar.themeToggle"),
|
||
class: "comfy-vue-theme-toggle"
|
||
}, null, 8, ["icon", "tooltip"]);
|
||
};
|
||
}
|
||
});
|
||
const _sfc_main$p = /* @__PURE__ */ defineComponent({
|
||
__name: "SidebarSettingsToggleIcon",
|
||
setup(__props) {
|
||
const dialogStore = useDialogStore();
|
||
const showSetting = /* @__PURE__ */ __name(() => {
|
||
dialogStore.showDialog({
|
||
key: "global-settings",
|
||
headerComponent: SettingDialogHeader,
|
||
component: SettingDialogContent
|
||
});
|
||
}, "showSetting");
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createBlock(SidebarIcon, {
|
||
icon: "pi pi-cog",
|
||
class: "comfy-settings-btn",
|
||
onClick: showSetting,
|
||
tooltip: _ctx.$t("g.settings")
|
||
}, null, 8, ["tooltip"]);
|
||
};
|
||
}
|
||
});
|
||
const _sfc_main$o = /* @__PURE__ */ defineComponent({
|
||
__name: "SidebarLogoutIcon",
|
||
setup(__props) {
|
||
const { t } = useI18n();
|
||
const userStore = useUserStore();
|
||
const tooltip = computed(
|
||
() => `${t("sideToolbar.logout")} (${userStore.currentUser?.username})`
|
||
);
|
||
const logout = /* @__PURE__ */ __name(() => {
|
||
userStore.logout();
|
||
window.location.reload();
|
||
}, "logout");
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createBlock(SidebarIcon, {
|
||
icon: "pi pi-sign-out",
|
||
tooltip: tooltip.value,
|
||
onClick: logout
|
||
}, null, 8, ["tooltip"]);
|
||
};
|
||
}
|
||
});
|
||
const _sfc_main$n = /* @__PURE__ */ defineComponent({
|
||
__name: "ExtensionSlot",
|
||
props: {
|
||
extension: {}
|
||
},
|
||
setup(__props) {
|
||
const props = __props;
|
||
const mountCustomExtension = /* @__PURE__ */ __name((extension, el) => {
|
||
extension.render(el);
|
||
}, "mountCustomExtension");
|
||
onBeforeUnmount(() => {
|
||
if (props.extension.type === "custom" && props.extension.destroy) {
|
||
props.extension.destroy();
|
||
}
|
||
});
|
||
return (_ctx, _cache) => {
|
||
return _ctx.extension.type === "vue" ? (openBlock(), createBlock(resolveDynamicComponent(_ctx.extension.component), { key: 0 })) : (openBlock(), createElementBlock("div", {
|
||
key: 1,
|
||
ref: /* @__PURE__ */ __name((el) => {
|
||
if (el)
|
||
mountCustomExtension(
|
||
props.extension,
|
||
el
|
||
);
|
||
}, "ref")
|
||
}, null, 512));
|
||
};
|
||
}
|
||
});
|
||
const _withScopeId$5 = /* @__PURE__ */ __name((n) => (pushScopeId("data-v-7851c166"), n = n(), popScopeId(), n), "_withScopeId$5");
|
||
const _hoisted_1$n = { class: "side-tool-bar-end" };
|
||
const _hoisted_2$k = {
|
||
key: 0,
|
||
class: "sidebar-content-container h-full overflow-y-auto overflow-x-hidden"
|
||
};
|
||
const _sfc_main$m = /* @__PURE__ */ defineComponent({
|
||
__name: "SideToolbar",
|
||
setup(__props) {
|
||
const workspaceStore = useWorkspaceStore();
|
||
const settingStore = useSettingStore();
|
||
const userStore = useUserStore();
|
||
const teleportTarget = computed(
|
||
() => settingStore.get("Comfy.Sidebar.Location") === "left" ? ".comfyui-body-left" : ".comfyui-body-right"
|
||
);
|
||
const isSmall = computed(
|
||
() => settingStore.get("Comfy.Sidebar.Size") === "small"
|
||
);
|
||
const tabs = computed(() => workspaceStore.getSidebarTabs());
|
||
const selectedTab = computed(() => workspaceStore.sidebarTab.activeSidebarTab);
|
||
const onTabClick = /* @__PURE__ */ __name((item3) => {
|
||
workspaceStore.sidebarTab.toggleSidebarTab(item3.id);
|
||
}, "onTabClick");
|
||
const keybindingStore = useKeybindingStore();
|
||
const getTabTooltipSuffix = /* @__PURE__ */ __name((tab) => {
|
||
const keybinding = keybindingStore.getKeybindingByCommandId(
|
||
`Workspace.ToggleSidebarTab.${tab.id}`
|
||
);
|
||
return keybinding ? ` (${keybinding.combo.toString()})` : "";
|
||
}, "getTabTooltipSuffix");
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock(Fragment, null, [
|
||
(openBlock(), createBlock(Teleport, { to: teleportTarget.value }, [
|
||
createBaseVNode("nav", {
|
||
class: normalizeClass("side-tool-bar-container" + (isSmall.value ? " small-sidebar" : ""))
|
||
}, [
|
||
(openBlock(true), createElementBlock(Fragment, null, renderList(tabs.value, (tab) => {
|
||
return openBlock(), createBlock(SidebarIcon, {
|
||
key: tab.id,
|
||
icon: tab.icon,
|
||
iconBadge: tab.iconBadge,
|
||
tooltip: tab.tooltip + getTabTooltipSuffix(tab),
|
||
selected: tab.id === selectedTab.value?.id,
|
||
class: normalizeClass(tab.id + "-tab-button"),
|
||
onClick: /* @__PURE__ */ __name(($event) => onTabClick(tab), "onClick")
|
||
}, null, 8, ["icon", "iconBadge", "tooltip", "selected", "class", "onClick"]);
|
||
}), 128)),
|
||
createBaseVNode("div", _hoisted_1$n, [
|
||
unref(userStore).isMultiUserServer ? (openBlock(), createBlock(_sfc_main$o, { key: 0 })) : createCommentVNode("", true),
|
||
createVNode(_sfc_main$q),
|
||
createVNode(_sfc_main$p)
|
||
])
|
||
], 2)
|
||
], 8, ["to"])),
|
||
selectedTab.value ? (openBlock(), createElementBlock("div", _hoisted_2$k, [
|
||
createVNode(_sfc_main$n, { extension: selectedTab.value }, null, 8, ["extension"])
|
||
])) : createCommentVNode("", true)
|
||
], 64);
|
||
};
|
||
}
|
||
});
|
||
const SideToolbar = /* @__PURE__ */ _export_sfc(_sfc_main$m, [["__scopeId", "data-v-7851c166"]]);
|
||
var classes$a = {
|
||
root: "p-tablist",
|
||
content: /* @__PURE__ */ __name(function content(_ref) {
|
||
var instance = _ref.instance;
|
||
return ["p-tablist-content", {
|
||
"p-tablist-viewport": instance.$pcTabs.scrollable
|
||
}];
|
||
}, "content"),
|
||
tabList: "p-tablist-tab-list",
|
||
activeBar: "p-tablist-active-bar",
|
||
prevButton: "p-tablist-prev-button p-tablist-nav-button",
|
||
nextButton: "p-tablist-next-button p-tablist-nav-button"
|
||
};
|
||
var TabListStyle = BaseStyle.extend({
|
||
name: "tablist",
|
||
classes: classes$a
|
||
});
|
||
var script$1$a = {
|
||
name: "BaseTabList",
|
||
"extends": script$g,
|
||
props: {},
|
||
style: TabListStyle,
|
||
provide: /* @__PURE__ */ __name(function provide3() {
|
||
return {
|
||
$pcTabList: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script$c = {
|
||
name: "TabList",
|
||
"extends": script$1$a,
|
||
inheritAttrs: false,
|
||
inject: ["$pcTabs"],
|
||
data: /* @__PURE__ */ __name(function data() {
|
||
return {
|
||
isPrevButtonEnabled: false,
|
||
isNextButtonEnabled: true
|
||
};
|
||
}, "data"),
|
||
resizeObserver: void 0,
|
||
watch: {
|
||
showNavigators: /* @__PURE__ */ __name(function showNavigators(newValue) {
|
||
newValue ? this.bindResizeObserver() : this.unbindResizeObserver();
|
||
}, "showNavigators"),
|
||
activeValue: {
|
||
flush: "post",
|
||
handler: /* @__PURE__ */ __name(function handler() {
|
||
this.updateInkBar();
|
||
}, "handler")
|
||
}
|
||
},
|
||
mounted: /* @__PURE__ */ __name(function mounted() {
|
||
var _this = this;
|
||
this.$nextTick(function() {
|
||
_this.updateInkBar();
|
||
});
|
||
if (this.showNavigators) {
|
||
this.updateButtonState();
|
||
this.bindResizeObserver();
|
||
}
|
||
}, "mounted"),
|
||
updated: /* @__PURE__ */ __name(function updated() {
|
||
this.showNavigators && this.updateButtonState();
|
||
}, "updated"),
|
||
beforeUnmount: /* @__PURE__ */ __name(function beforeUnmount() {
|
||
this.unbindResizeObserver();
|
||
}, "beforeUnmount"),
|
||
methods: {
|
||
onScroll: /* @__PURE__ */ __name(function onScroll(event) {
|
||
this.showNavigators && this.updateButtonState();
|
||
event.preventDefault();
|
||
}, "onScroll"),
|
||
onPrevButtonClick: /* @__PURE__ */ __name(function onPrevButtonClick() {
|
||
var content2 = this.$refs.content;
|
||
var width = getWidth(content2);
|
||
var pos = content2.scrollLeft - width;
|
||
content2.scrollLeft = pos <= 0 ? 0 : pos;
|
||
}, "onPrevButtonClick"),
|
||
onNextButtonClick: /* @__PURE__ */ __name(function onNextButtonClick() {
|
||
var content2 = this.$refs.content;
|
||
var width = getWidth(content2) - this.getVisibleButtonWidths();
|
||
var pos = content2.scrollLeft + width;
|
||
var lastPos = content2.scrollWidth - width;
|
||
content2.scrollLeft = pos >= lastPos ? lastPos : pos;
|
||
}, "onNextButtonClick"),
|
||
bindResizeObserver: /* @__PURE__ */ __name(function bindResizeObserver() {
|
||
var _this2 = this;
|
||
this.resizeObserver = new ResizeObserver(function() {
|
||
return _this2.updateButtonState();
|
||
});
|
||
this.resizeObserver.observe(this.$refs.list);
|
||
}, "bindResizeObserver"),
|
||
unbindResizeObserver: /* @__PURE__ */ __name(function unbindResizeObserver() {
|
||
var _this$resizeObserver;
|
||
(_this$resizeObserver = this.resizeObserver) === null || _this$resizeObserver === void 0 || _this$resizeObserver.unobserve(this.$refs.list);
|
||
this.resizeObserver = void 0;
|
||
}, "unbindResizeObserver"),
|
||
updateInkBar: /* @__PURE__ */ __name(function updateInkBar() {
|
||
var _this$$refs = this.$refs, content2 = _this$$refs.content, inkbar = _this$$refs.inkbar, tabs = _this$$refs.tabs;
|
||
var activeTab = findSingle(content2, '[data-pc-name="tab"][data-p-active="true"]');
|
||
if (this.$pcTabs.isVertical()) {
|
||
inkbar.style.height = getOuterHeight(activeTab) + "px";
|
||
inkbar.style.top = getOffset(activeTab).top - getOffset(tabs).top + "px";
|
||
} else {
|
||
inkbar.style.width = getOuterWidth(activeTab) + "px";
|
||
inkbar.style.left = getOffset(activeTab).left - getOffset(tabs).left + "px";
|
||
}
|
||
}, "updateInkBar"),
|
||
updateButtonState: /* @__PURE__ */ __name(function updateButtonState() {
|
||
var _this$$refs2 = this.$refs, list = _this$$refs2.list, content2 = _this$$refs2.content;
|
||
var scrollLeft = content2.scrollLeft, scrollTop = content2.scrollTop, scrollWidth = content2.scrollWidth, scrollHeight = content2.scrollHeight, offsetWidth = content2.offsetWidth, offsetHeight = content2.offsetHeight;
|
||
var _ref = [getWidth(content2), getHeight(content2)], width = _ref[0], height = _ref[1];
|
||
if (this.$pcTabs.isVertical()) {
|
||
this.isPrevButtonEnabled = scrollTop !== 0;
|
||
this.isNextButtonEnabled = list.offsetHeight >= offsetHeight && parseInt(scrollTop) !== scrollHeight - height;
|
||
} else {
|
||
this.isPrevButtonEnabled = scrollLeft !== 0;
|
||
this.isNextButtonEnabled = list.offsetWidth >= offsetWidth && parseInt(scrollLeft) !== scrollWidth - width;
|
||
}
|
||
}, "updateButtonState"),
|
||
getVisibleButtonWidths: /* @__PURE__ */ __name(function getVisibleButtonWidths() {
|
||
var _this$$refs3 = this.$refs, prevBtn = _this$$refs3.prevBtn, nextBtn = _this$$refs3.nextBtn;
|
||
return [prevBtn, nextBtn].reduce(function(acc, el) {
|
||
return el ? acc + getWidth(el) : acc;
|
||
}, 0);
|
||
}, "getVisibleButtonWidths")
|
||
},
|
||
computed: {
|
||
templates: /* @__PURE__ */ __name(function templates() {
|
||
return this.$pcTabs.$slots;
|
||
}, "templates"),
|
||
activeValue: /* @__PURE__ */ __name(function activeValue() {
|
||
return this.$pcTabs.d_value;
|
||
}, "activeValue"),
|
||
showNavigators: /* @__PURE__ */ __name(function showNavigators2() {
|
||
return this.$pcTabs.scrollable && this.$pcTabs.showNavigators;
|
||
}, "showNavigators"),
|
||
prevButtonAriaLabel: /* @__PURE__ */ __name(function prevButtonAriaLabel() {
|
||
return this.$primevue.config.locale.aria ? this.$primevue.config.locale.aria.previous : void 0;
|
||
}, "prevButtonAriaLabel"),
|
||
nextButtonAriaLabel: /* @__PURE__ */ __name(function nextButtonAriaLabel() {
|
||
return this.$primevue.config.locale.aria ? this.$primevue.config.locale.aria.next : void 0;
|
||
}, "nextButtonAriaLabel")
|
||
},
|
||
components: {
|
||
ChevronLeftIcon: script$h,
|
||
ChevronRightIcon: script$i
|
||
},
|
||
directives: {
|
||
ripple: Ripple
|
||
}
|
||
};
|
||
var _hoisted_1$m = ["aria-label", "tabindex"];
|
||
var _hoisted_2$j = ["aria-orientation"];
|
||
var _hoisted_3$g = ["aria-label", "tabindex"];
|
||
function render$i(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _directive_ripple = resolveDirective("ripple");
|
||
return openBlock(), createElementBlock("div", mergeProps({
|
||
ref: "list",
|
||
"class": _ctx.cx("root")
|
||
}, _ctx.ptmi("root")), [$options.showNavigators && $data.isPrevButtonEnabled ? withDirectives((openBlock(), createElementBlock("button", mergeProps({
|
||
key: 0,
|
||
ref: "prevButton",
|
||
"class": _ctx.cx("prevButton"),
|
||
"aria-label": $options.prevButtonAriaLabel,
|
||
tabindex: $options.$pcTabs.tabindex,
|
||
onClick: _cache[0] || (_cache[0] = function() {
|
||
return $options.onPrevButtonClick && $options.onPrevButtonClick.apply($options, arguments);
|
||
})
|
||
}, _ctx.ptm("prevButton"), {
|
||
"data-pc-group-section": "navigator"
|
||
}), [(openBlock(), createBlock(resolveDynamicComponent($options.templates.previcon || "ChevronLeftIcon"), mergeProps({
|
||
"aria-hidden": "true"
|
||
}, _ctx.ptm("prevIcon")), null, 16))], 16, _hoisted_1$m)), [[_directive_ripple]]) : createCommentVNode("", true), createBaseVNode("div", mergeProps({
|
||
ref: "content",
|
||
"class": _ctx.cx("content"),
|
||
onScroll: _cache[1] || (_cache[1] = function() {
|
||
return $options.onScroll && $options.onScroll.apply($options, arguments);
|
||
})
|
||
}, _ctx.ptm("content")), [createBaseVNode("div", mergeProps({
|
||
ref: "tabs",
|
||
"class": _ctx.cx("tabList"),
|
||
role: "tablist",
|
||
"aria-orientation": $options.$pcTabs.orientation || "horizontal"
|
||
}, _ctx.ptm("tabList")), [renderSlot(_ctx.$slots, "default"), createBaseVNode("span", mergeProps({
|
||
ref: "inkbar",
|
||
"class": _ctx.cx("activeBar"),
|
||
role: "presentation",
|
||
"aria-hidden": "true"
|
||
}, _ctx.ptm("activeBar")), null, 16)], 16, _hoisted_2$j)], 16), $options.showNavigators && $data.isNextButtonEnabled ? withDirectives((openBlock(), createElementBlock("button", mergeProps({
|
||
key: 1,
|
||
ref: "nextButton",
|
||
"class": _ctx.cx("nextButton"),
|
||
"aria-label": $options.nextButtonAriaLabel,
|
||
tabindex: $options.$pcTabs.tabindex,
|
||
onClick: _cache[2] || (_cache[2] = function() {
|
||
return $options.onNextButtonClick && $options.onNextButtonClick.apply($options, arguments);
|
||
})
|
||
}, _ctx.ptm("nextButton"), {
|
||
"data-pc-group-section": "navigator"
|
||
}), [(openBlock(), createBlock(resolveDynamicComponent($options.templates.nexticon || "ChevronRightIcon"), mergeProps({
|
||
"aria-hidden": "true"
|
||
}, _ctx.ptm("nextIcon")), null, 16))], 16, _hoisted_3$g)), [[_directive_ripple]]) : createCommentVNode("", true)], 16);
|
||
}
|
||
__name(render$i, "render$i");
|
||
script$c.render = render$i;
|
||
var classes$9 = {
|
||
root: /* @__PURE__ */ __name(function root(_ref) {
|
||
var instance = _ref.instance, props = _ref.props;
|
||
return ["p-tab", {
|
||
"p-tab-active": instance.active,
|
||
"p-disabled": props.disabled
|
||
}];
|
||
}, "root")
|
||
};
|
||
var TabStyle = BaseStyle.extend({
|
||
name: "tab",
|
||
classes: classes$9
|
||
});
|
||
var script$1$9 = {
|
||
name: "BaseTab",
|
||
"extends": script$g,
|
||
props: {
|
||
value: {
|
||
type: [String, Number],
|
||
"default": void 0
|
||
},
|
||
disabled: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
as: {
|
||
type: [String, Object],
|
||
"default": "BUTTON"
|
||
},
|
||
asChild: {
|
||
type: Boolean,
|
||
"default": false
|
||
}
|
||
},
|
||
style: TabStyle,
|
||
provide: /* @__PURE__ */ __name(function provide4() {
|
||
return {
|
||
$pcTab: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script$b = {
|
||
name: "Tab",
|
||
"extends": script$1$9,
|
||
inheritAttrs: false,
|
||
inject: ["$pcTabs", "$pcTabList"],
|
||
methods: {
|
||
onFocus: /* @__PURE__ */ __name(function onFocus() {
|
||
this.$pcTabs.selectOnFocus && this.changeActiveValue();
|
||
}, "onFocus"),
|
||
onClick: /* @__PURE__ */ __name(function onClick() {
|
||
this.changeActiveValue();
|
||
}, "onClick"),
|
||
onKeydown: /* @__PURE__ */ __name(function onKeydown(event) {
|
||
switch (event.code) {
|
||
case "ArrowRight":
|
||
this.onArrowRightKey(event);
|
||
break;
|
||
case "ArrowLeft":
|
||
this.onArrowLeftKey(event);
|
||
break;
|
||
case "Home":
|
||
this.onHomeKey(event);
|
||
break;
|
||
case "End":
|
||
this.onEndKey(event);
|
||
break;
|
||
case "PageDown":
|
||
this.onPageDownKey(event);
|
||
break;
|
||
case "PageUp":
|
||
this.onPageUpKey(event);
|
||
break;
|
||
case "Enter":
|
||
case "NumpadEnter":
|
||
case "Space":
|
||
this.onEnterKey(event);
|
||
break;
|
||
}
|
||
}, "onKeydown"),
|
||
onArrowRightKey: /* @__PURE__ */ __name(function onArrowRightKey(event) {
|
||
var nextTab = this.findNextTab(event.currentTarget);
|
||
nextTab ? this.changeFocusedTab(event, nextTab) : this.onHomeKey(event);
|
||
event.preventDefault();
|
||
}, "onArrowRightKey"),
|
||
onArrowLeftKey: /* @__PURE__ */ __name(function onArrowLeftKey(event) {
|
||
var prevTab = this.findPrevTab(event.currentTarget);
|
||
prevTab ? this.changeFocusedTab(event, prevTab) : this.onEndKey(event);
|
||
event.preventDefault();
|
||
}, "onArrowLeftKey"),
|
||
onHomeKey: /* @__PURE__ */ __name(function onHomeKey(event) {
|
||
var firstTab = this.findFirstTab();
|
||
this.changeFocusedTab(event, firstTab);
|
||
event.preventDefault();
|
||
}, "onHomeKey"),
|
||
onEndKey: /* @__PURE__ */ __name(function onEndKey(event) {
|
||
var lastTab = this.findLastTab();
|
||
this.changeFocusedTab(event, lastTab);
|
||
event.preventDefault();
|
||
}, "onEndKey"),
|
||
onPageDownKey: /* @__PURE__ */ __name(function onPageDownKey(event) {
|
||
this.scrollInView(this.findLastTab());
|
||
event.preventDefault();
|
||
}, "onPageDownKey"),
|
||
onPageUpKey: /* @__PURE__ */ __name(function onPageUpKey(event) {
|
||
this.scrollInView(this.findFirstTab());
|
||
event.preventDefault();
|
||
}, "onPageUpKey"),
|
||
onEnterKey: /* @__PURE__ */ __name(function onEnterKey(event) {
|
||
this.changeActiveValue();
|
||
event.preventDefault();
|
||
}, "onEnterKey"),
|
||
findNextTab: /* @__PURE__ */ __name(function findNextTab(tabElement) {
|
||
var selfCheck = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : false;
|
||
var element = selfCheck ? tabElement : tabElement.nextElementSibling;
|
||
return element ? getAttribute(element, "data-p-disabled") || getAttribute(element, "data-pc-section") === "inkbar" ? this.findNextTab(element) : findSingle(element, '[data-pc-name="tab"]') : null;
|
||
}, "findNextTab"),
|
||
findPrevTab: /* @__PURE__ */ __name(function findPrevTab(tabElement) {
|
||
var selfCheck = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : false;
|
||
var element = selfCheck ? tabElement : tabElement.previousElementSibling;
|
||
return element ? getAttribute(element, "data-p-disabled") || getAttribute(element, "data-pc-section") === "inkbar" ? this.findPrevTab(element) : findSingle(element, '[data-pc-name="tab"]') : null;
|
||
}, "findPrevTab"),
|
||
findFirstTab: /* @__PURE__ */ __name(function findFirstTab() {
|
||
return this.findNextTab(this.$pcTabList.$refs.content.firstElementChild, true);
|
||
}, "findFirstTab"),
|
||
findLastTab: /* @__PURE__ */ __name(function findLastTab() {
|
||
return this.findPrevTab(this.$pcTabList.$refs.content.lastElementChild, true);
|
||
}, "findLastTab"),
|
||
changeActiveValue: /* @__PURE__ */ __name(function changeActiveValue() {
|
||
this.$pcTabs.updateValue(this.value);
|
||
}, "changeActiveValue"),
|
||
changeFocusedTab: /* @__PURE__ */ __name(function changeFocusedTab(event, element) {
|
||
focus(element);
|
||
this.scrollInView(element);
|
||
}, "changeFocusedTab"),
|
||
scrollInView: /* @__PURE__ */ __name(function scrollInView(element) {
|
||
var _element$scrollIntoVi;
|
||
element === null || element === void 0 || (_element$scrollIntoVi = element.scrollIntoView) === null || _element$scrollIntoVi === void 0 || _element$scrollIntoVi.call(element, {
|
||
block: "nearest"
|
||
});
|
||
}, "scrollInView")
|
||
},
|
||
computed: {
|
||
active: /* @__PURE__ */ __name(function active() {
|
||
var _this$$pcTabs;
|
||
return equals((_this$$pcTabs = this.$pcTabs) === null || _this$$pcTabs === void 0 ? void 0 : _this$$pcTabs.d_value, this.value);
|
||
}, "active"),
|
||
id: /* @__PURE__ */ __name(function id() {
|
||
var _this$$pcTabs2;
|
||
return "".concat((_this$$pcTabs2 = this.$pcTabs) === null || _this$$pcTabs2 === void 0 ? void 0 : _this$$pcTabs2.id, "_tab_").concat(this.value);
|
||
}, "id"),
|
||
ariaControls: /* @__PURE__ */ __name(function ariaControls() {
|
||
var _this$$pcTabs3;
|
||
return "".concat((_this$$pcTabs3 = this.$pcTabs) === null || _this$$pcTabs3 === void 0 ? void 0 : _this$$pcTabs3.id, "_tabpanel_").concat(this.value);
|
||
}, "ariaControls"),
|
||
attrs: /* @__PURE__ */ __name(function attrs() {
|
||
return mergeProps(this.asAttrs, this.a11yAttrs, this.ptmi("root", this.ptParams));
|
||
}, "attrs"),
|
||
asAttrs: /* @__PURE__ */ __name(function asAttrs() {
|
||
return this.as === "BUTTON" ? {
|
||
type: "button",
|
||
disabled: this.disabled
|
||
} : void 0;
|
||
}, "asAttrs"),
|
||
a11yAttrs: /* @__PURE__ */ __name(function a11yAttrs() {
|
||
return {
|
||
id: this.id,
|
||
tabindex: this.active ? this.$pcTabs.tabindex : -1,
|
||
role: "tab",
|
||
"aria-selected": this.active,
|
||
"aria-controls": this.ariaControls,
|
||
"data-pc-name": "tab",
|
||
"data-p-disabled": this.disabled,
|
||
"data-p-active": this.active,
|
||
onFocus: this.onFocus,
|
||
onKeydown: this.onKeydown
|
||
};
|
||
}, "a11yAttrs"),
|
||
ptParams: /* @__PURE__ */ __name(function ptParams() {
|
||
return {
|
||
context: {
|
||
active: this.active
|
||
}
|
||
};
|
||
}, "ptParams")
|
||
},
|
||
directives: {
|
||
ripple: Ripple
|
||
}
|
||
};
|
||
function render$h(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _directive_ripple = resolveDirective("ripple");
|
||
return !_ctx.asChild ? withDirectives((openBlock(), createBlock(resolveDynamicComponent(_ctx.as), mergeProps({
|
||
key: 0,
|
||
"class": _ctx.cx("root"),
|
||
onClick: $options.onClick
|
||
}, $options.attrs), {
|
||
"default": withCtx(function() {
|
||
return [renderSlot(_ctx.$slots, "default")];
|
||
}),
|
||
_: 3
|
||
}, 16, ["class", "onClick"])), [[_directive_ripple]]) : renderSlot(_ctx.$slots, "default", {
|
||
key: 1,
|
||
"class": normalizeClass(_ctx.cx("root")),
|
||
active: $options.active,
|
||
a11yAttrs: $options.a11yAttrs,
|
||
onClick: $options.onClick
|
||
});
|
||
}
|
||
__name(render$h, "render$h");
|
||
script$b.render = render$h;
|
||
const _hoisted_1$l = { class: "flex flex-col h-full" };
|
||
const _hoisted_2$i = { class: "w-full flex justify-between" };
|
||
const _hoisted_3$f = { class: "tabs-container" };
|
||
const _hoisted_4$6 = { class: "font-bold" };
|
||
const _hoisted_5$4 = { class: "flex-grow h-0" };
|
||
const _sfc_main$l = /* @__PURE__ */ defineComponent({
|
||
__name: "BottomPanel",
|
||
setup(__props) {
|
||
const bottomPanelStore = useBottomPanelStore();
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock("div", _hoisted_1$l, [
|
||
createVNode(unref(script$j), {
|
||
value: unref(bottomPanelStore).activeBottomPanelTabId,
|
||
"onUpdate:value": _cache[1] || (_cache[1] = ($event) => unref(bottomPanelStore).activeBottomPanelTabId = $event)
|
||
}, {
|
||
default: withCtx(() => [
|
||
createVNode(unref(script$c), { "pt:tabList": "border-none" }, {
|
||
default: withCtx(() => [
|
||
createBaseVNode("div", _hoisted_2$i, [
|
||
createBaseVNode("div", _hoisted_3$f, [
|
||
(openBlock(true), createElementBlock(Fragment, null, renderList(unref(bottomPanelStore).bottomPanelTabs, (tab) => {
|
||
return openBlock(), createBlock(unref(script$b), {
|
||
key: tab.id,
|
||
value: tab.id,
|
||
class: "p-3 border-none"
|
||
}, {
|
||
default: withCtx(() => [
|
||
createBaseVNode("span", _hoisted_4$6, toDisplayString(tab.title.toUpperCase()), 1)
|
||
]),
|
||
_: 2
|
||
}, 1032, ["value"]);
|
||
}), 128))
|
||
]),
|
||
createVNode(unref(script$f), {
|
||
class: "justify-self-end",
|
||
icon: "pi pi-times",
|
||
severity: "secondary",
|
||
size: "small",
|
||
text: "",
|
||
onClick: _cache[0] || (_cache[0] = ($event) => unref(bottomPanelStore).bottomPanelVisible = false)
|
||
})
|
||
])
|
||
]),
|
||
_: 1
|
||
})
|
||
]),
|
||
_: 1
|
||
}, 8, ["value"]),
|
||
createBaseVNode("div", _hoisted_5$4, [
|
||
unref(bottomPanelStore).bottomPanelVisible && unref(bottomPanelStore).activeBottomPanelTab ? (openBlock(), createBlock(_sfc_main$n, {
|
||
key: 0,
|
||
extension: unref(bottomPanelStore).activeBottomPanelTab
|
||
}, null, 8, ["extension"])) : createCommentVNode("", true)
|
||
])
|
||
]);
|
||
};
|
||
}
|
||
});
|
||
var theme$7 = /* @__PURE__ */ __name(function theme2(_ref) {
|
||
var dt = _ref.dt;
|
||
return "\n.p-splitter {\n display: flex;\n flex-wrap: nowrap;\n border: 1px solid ".concat(dt("splitter.border.color"), ";\n background: ").concat(dt("splitter.background"), ";\n border-radius: ").concat(dt("border.radius.md"), ";\n color: ").concat(dt("splitter.color"), ";\n}\n\n.p-splitter-vertical {\n flex-direction: column;\n}\n\n.p-splitter-gutter {\n flex-grow: 0;\n flex-shrink: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: 1;\n background: ").concat(dt("splitter.gutter.background"), ";\n}\n\n.p-splitter-gutter-handle {\n border-radius: ").concat(dt("splitter.handle.border.radius"), ";\n background: ").concat(dt("splitter.handle.background"), ";\n transition: outline-color ").concat(dt("splitter.transition.duration"), ", box-shadow ").concat(dt("splitter.transition.duration"), ";\n outline-color: transparent;\n}\n\n.p-splitter-gutter-handle:focus-visible {\n box-shadow: ").concat(dt("splitter.handle.focus.ring.shadow"), ";\n outline: ").concat(dt("splitter.handle.focus.ring.width"), " ").concat(dt("splitter.handle.focus.ring.style"), " ").concat(dt("splitter.handle.focus.ring.color"), ";\n outline-offset: ").concat(dt("splitter.handle.focus.ring.offset"), ";\n}\n\n.p-splitter-horizontal.p-splitter-resizing {\n cursor: col-resize;\n user-select: none;\n}\n\n.p-splitter-vertical.p-splitter-resizing {\n cursor: row-resize;\n user-select: none;\n}\n\n.p-splitter-horizontal > .p-splitter-gutter > .p-splitter-gutter-handle {\n height: ").concat(dt("splitter.handle.size"), ";\n width: 100%;\n}\n\n.p-splitter-vertical > .p-splitter-gutter > .p-splitter-gutter-handle {\n width: ").concat(dt("splitter.handle.size"), ";\n height: 100%;\n}\n\n.p-splitter-horizontal > .p-splitter-gutter {\n cursor: col-resize;\n}\n\n.p-splitter-vertical > .p-splitter-gutter {\n cursor: row-resize;\n}\n\n.p-splitterpanel {\n flex-grow: 1;\n overflow: hidden;\n}\n\n.p-splitterpanel-nested {\n display: flex;\n}\n\n.p-splitterpanel .p-splitter {\n flex-grow: 1;\n border: 0 none;\n}\n");
|
||
}, "theme");
|
||
var classes$8 = {
|
||
root: /* @__PURE__ */ __name(function root2(_ref2) {
|
||
var props = _ref2.props;
|
||
return ["p-splitter p-component", "p-splitter-" + props.layout];
|
||
}, "root"),
|
||
gutter: "p-splitter-gutter",
|
||
gutterHandle: "p-splitter-gutter-handle"
|
||
};
|
||
var inlineStyles$4 = {
|
||
root: /* @__PURE__ */ __name(function root3(_ref3) {
|
||
var props = _ref3.props;
|
||
return [{
|
||
display: "flex",
|
||
"flex-wrap": "nowrap"
|
||
}, props.layout === "vertical" ? {
|
||
"flex-direction": "column"
|
||
} : ""];
|
||
}, "root")
|
||
};
|
||
var SplitterStyle = BaseStyle.extend({
|
||
name: "splitter",
|
||
theme: theme$7,
|
||
classes: classes$8,
|
||
inlineStyles: inlineStyles$4
|
||
});
|
||
var script$1$8 = {
|
||
name: "BaseSplitter",
|
||
"extends": script$g,
|
||
props: {
|
||
layout: {
|
||
type: String,
|
||
"default": "horizontal"
|
||
},
|
||
gutterSize: {
|
||
type: Number,
|
||
"default": 4
|
||
},
|
||
stateKey: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
stateStorage: {
|
||
type: String,
|
||
"default": "session"
|
||
},
|
||
step: {
|
||
type: Number,
|
||
"default": 5
|
||
}
|
||
},
|
||
style: SplitterStyle,
|
||
provide: /* @__PURE__ */ __name(function provide5() {
|
||
return {
|
||
$pcSplitter: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
function _toConsumableArray$2(r) {
|
||
return _arrayWithoutHoles$2(r) || _iterableToArray$2(r) || _unsupportedIterableToArray$2(r) || _nonIterableSpread$2();
|
||
}
|
||
__name(_toConsumableArray$2, "_toConsumableArray$2");
|
||
function _nonIterableSpread$2() {
|
||
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
||
}
|
||
__name(_nonIterableSpread$2, "_nonIterableSpread$2");
|
||
function _unsupportedIterableToArray$2(r, a) {
|
||
if (r) {
|
||
if ("string" == typeof r) return _arrayLikeToArray$2(r, a);
|
||
var t = {}.toString.call(r).slice(8, -1);
|
||
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray$2(r, a) : void 0;
|
||
}
|
||
}
|
||
__name(_unsupportedIterableToArray$2, "_unsupportedIterableToArray$2");
|
||
function _iterableToArray$2(r) {
|
||
if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r);
|
||
}
|
||
__name(_iterableToArray$2, "_iterableToArray$2");
|
||
function _arrayWithoutHoles$2(r) {
|
||
if (Array.isArray(r)) return _arrayLikeToArray$2(r);
|
||
}
|
||
__name(_arrayWithoutHoles$2, "_arrayWithoutHoles$2");
|
||
function _arrayLikeToArray$2(r, a) {
|
||
(null == a || a > r.length) && (a = r.length);
|
||
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
|
||
return n;
|
||
}
|
||
__name(_arrayLikeToArray$2, "_arrayLikeToArray$2");
|
||
var script$a = {
|
||
name: "Splitter",
|
||
"extends": script$1$8,
|
||
inheritAttrs: false,
|
||
emits: ["resizestart", "resizeend", "resize"],
|
||
dragging: false,
|
||
mouseMoveListener: null,
|
||
mouseUpListener: null,
|
||
touchMoveListener: null,
|
||
touchEndListener: null,
|
||
size: null,
|
||
gutterElement: null,
|
||
startPos: null,
|
||
prevPanelElement: null,
|
||
nextPanelElement: null,
|
||
nextPanelSize: null,
|
||
prevPanelSize: null,
|
||
panelSizes: null,
|
||
prevPanelIndex: null,
|
||
timer: null,
|
||
data: /* @__PURE__ */ __name(function data2() {
|
||
return {
|
||
prevSize: null
|
||
};
|
||
}, "data"),
|
||
mounted: /* @__PURE__ */ __name(function mounted2() {
|
||
var _this = this;
|
||
if (this.panels && this.panels.length) {
|
||
var initialized = false;
|
||
if (this.isStateful()) {
|
||
initialized = this.restoreState();
|
||
}
|
||
if (!initialized) {
|
||
var children = _toConsumableArray$2(this.$el.children).filter(function(child) {
|
||
return child.getAttribute("data-pc-name") === "splitterpanel";
|
||
});
|
||
var _panelSizes = [];
|
||
this.panels.map(function(panel, i) {
|
||
var panelInitialSize = panel.props && panel.props.size ? panel.props.size : null;
|
||
var panelSize = panelInitialSize || 100 / _this.panels.length;
|
||
_panelSizes[i] = panelSize;
|
||
children[i].style.flexBasis = "calc(" + panelSize + "% - " + (_this.panels.length - 1) * _this.gutterSize + "px)";
|
||
});
|
||
this.panelSizes = _panelSizes;
|
||
this.prevSize = parseFloat(_panelSizes[0]).toFixed(4);
|
||
}
|
||
}
|
||
}, "mounted"),
|
||
beforeUnmount: /* @__PURE__ */ __name(function beforeUnmount2() {
|
||
this.clear();
|
||
this.unbindMouseListeners();
|
||
}, "beforeUnmount"),
|
||
methods: {
|
||
isSplitterPanel: /* @__PURE__ */ __name(function isSplitterPanel(child) {
|
||
return child.type.name === "SplitterPanel";
|
||
}, "isSplitterPanel"),
|
||
onResizeStart: /* @__PURE__ */ __name(function onResizeStart(event, index, isKeyDown) {
|
||
this.gutterElement = event.currentTarget || event.target.parentElement;
|
||
this.size = this.horizontal ? getWidth(this.$el) : getHeight(this.$el);
|
||
if (!isKeyDown) {
|
||
this.dragging = true;
|
||
this.startPos = this.layout === "horizontal" ? event.pageX || event.changedTouches[0].pageX : event.pageY || event.changedTouches[0].pageY;
|
||
}
|
||
this.prevPanelElement = this.gutterElement.previousElementSibling;
|
||
this.nextPanelElement = this.gutterElement.nextElementSibling;
|
||
if (isKeyDown) {
|
||
this.prevPanelSize = this.horizontal ? getOuterWidth(this.prevPanelElement, true) : getOuterHeight(this.prevPanelElement, true);
|
||
this.nextPanelSize = this.horizontal ? getOuterWidth(this.nextPanelElement, true) : getOuterHeight(this.nextPanelElement, true);
|
||
} else {
|
||
this.prevPanelSize = 100 * (this.horizontal ? getOuterWidth(this.prevPanelElement, true) : getOuterHeight(this.prevPanelElement, true)) / this.size;
|
||
this.nextPanelSize = 100 * (this.horizontal ? getOuterWidth(this.nextPanelElement, true) : getOuterHeight(this.nextPanelElement, true)) / this.size;
|
||
}
|
||
this.prevPanelIndex = index;
|
||
this.$emit("resizestart", {
|
||
originalEvent: event,
|
||
sizes: this.panelSizes
|
||
});
|
||
this.$refs.gutter[index].setAttribute("data-p-gutter-resizing", true);
|
||
this.$el.setAttribute("data-p-resizing", true);
|
||
}, "onResizeStart"),
|
||
onResize: /* @__PURE__ */ __name(function onResize(event, step, isKeyDown) {
|
||
var newPos, newPrevPanelSize, newNextPanelSize;
|
||
if (isKeyDown) {
|
||
if (this.horizontal) {
|
||
newPrevPanelSize = 100 * (this.prevPanelSize + step) / this.size;
|
||
newNextPanelSize = 100 * (this.nextPanelSize - step) / this.size;
|
||
} else {
|
||
newPrevPanelSize = 100 * (this.prevPanelSize - step) / this.size;
|
||
newNextPanelSize = 100 * (this.nextPanelSize + step) / this.size;
|
||
}
|
||
} else {
|
||
if (this.horizontal) newPos = event.pageX * 100 / this.size - this.startPos * 100 / this.size;
|
||
else newPos = event.pageY * 100 / this.size - this.startPos * 100 / this.size;
|
||
newPrevPanelSize = this.prevPanelSize + newPos;
|
||
newNextPanelSize = this.nextPanelSize - newPos;
|
||
}
|
||
if (this.validateResize(newPrevPanelSize, newNextPanelSize)) {
|
||
this.prevPanelElement.style.flexBasis = "calc(" + newPrevPanelSize + "% - " + (this.panels.length - 1) * this.gutterSize + "px)";
|
||
this.nextPanelElement.style.flexBasis = "calc(" + newNextPanelSize + "% - " + (this.panels.length - 1) * this.gutterSize + "px)";
|
||
this.panelSizes[this.prevPanelIndex] = newPrevPanelSize;
|
||
this.panelSizes[this.prevPanelIndex + 1] = newNextPanelSize;
|
||
this.prevSize = parseFloat(newPrevPanelSize).toFixed(4);
|
||
}
|
||
this.$emit("resize", {
|
||
originalEvent: event,
|
||
sizes: this.panelSizes
|
||
});
|
||
}, "onResize"),
|
||
onResizeEnd: /* @__PURE__ */ __name(function onResizeEnd(event) {
|
||
if (this.isStateful()) {
|
||
this.saveState();
|
||
}
|
||
this.$emit("resizeend", {
|
||
originalEvent: event,
|
||
sizes: this.panelSizes
|
||
});
|
||
this.$refs.gutter.forEach(function(gutter) {
|
||
return gutter.setAttribute("data-p-gutter-resizing", false);
|
||
});
|
||
this.$el.setAttribute("data-p-resizing", false);
|
||
this.clear();
|
||
}, "onResizeEnd"),
|
||
repeat: /* @__PURE__ */ __name(function repeat(event, index, step) {
|
||
this.onResizeStart(event, index, true);
|
||
this.onResize(event, step, true);
|
||
}, "repeat"),
|
||
setTimer: /* @__PURE__ */ __name(function setTimer(event, index, step) {
|
||
var _this2 = this;
|
||
if (!this.timer) {
|
||
this.timer = setInterval(function() {
|
||
_this2.repeat(event, index, step);
|
||
}, 40);
|
||
}
|
||
}, "setTimer"),
|
||
clearTimer: /* @__PURE__ */ __name(function clearTimer() {
|
||
if (this.timer) {
|
||
clearInterval(this.timer);
|
||
this.timer = null;
|
||
}
|
||
}, "clearTimer"),
|
||
onGutterKeyUp: /* @__PURE__ */ __name(function onGutterKeyUp() {
|
||
this.clearTimer();
|
||
this.onResizeEnd();
|
||
}, "onGutterKeyUp"),
|
||
onGutterKeyDown: /* @__PURE__ */ __name(function onGutterKeyDown(event, index) {
|
||
switch (event.code) {
|
||
case "ArrowLeft": {
|
||
if (this.layout === "horizontal") {
|
||
this.setTimer(event, index, this.step * -1);
|
||
}
|
||
event.preventDefault();
|
||
break;
|
||
}
|
||
case "ArrowRight": {
|
||
if (this.layout === "horizontal") {
|
||
this.setTimer(event, index, this.step);
|
||
}
|
||
event.preventDefault();
|
||
break;
|
||
}
|
||
case "ArrowDown": {
|
||
if (this.layout === "vertical") {
|
||
this.setTimer(event, index, this.step * -1);
|
||
}
|
||
event.preventDefault();
|
||
break;
|
||
}
|
||
case "ArrowUp": {
|
||
if (this.layout === "vertical") {
|
||
this.setTimer(event, index, this.step);
|
||
}
|
||
event.preventDefault();
|
||
break;
|
||
}
|
||
}
|
||
}, "onGutterKeyDown"),
|
||
onGutterMouseDown: /* @__PURE__ */ __name(function onGutterMouseDown(event, index) {
|
||
this.onResizeStart(event, index);
|
||
this.bindMouseListeners();
|
||
}, "onGutterMouseDown"),
|
||
onGutterTouchStart: /* @__PURE__ */ __name(function onGutterTouchStart(event, index) {
|
||
this.onResizeStart(event, index);
|
||
this.bindTouchListeners();
|
||
event.preventDefault();
|
||
}, "onGutterTouchStart"),
|
||
onGutterTouchMove: /* @__PURE__ */ __name(function onGutterTouchMove(event) {
|
||
this.onResize(event);
|
||
event.preventDefault();
|
||
}, "onGutterTouchMove"),
|
||
onGutterTouchEnd: /* @__PURE__ */ __name(function onGutterTouchEnd(event) {
|
||
this.onResizeEnd(event);
|
||
this.unbindTouchListeners();
|
||
event.preventDefault();
|
||
}, "onGutterTouchEnd"),
|
||
bindMouseListeners: /* @__PURE__ */ __name(function bindMouseListeners() {
|
||
var _this3 = this;
|
||
if (!this.mouseMoveListener) {
|
||
this.mouseMoveListener = function(event) {
|
||
return _this3.onResize(event);
|
||
};
|
||
document.addEventListener("mousemove", this.mouseMoveListener);
|
||
}
|
||
if (!this.mouseUpListener) {
|
||
this.mouseUpListener = function(event) {
|
||
_this3.onResizeEnd(event);
|
||
_this3.unbindMouseListeners();
|
||
};
|
||
document.addEventListener("mouseup", this.mouseUpListener);
|
||
}
|
||
}, "bindMouseListeners"),
|
||
bindTouchListeners: /* @__PURE__ */ __name(function bindTouchListeners() {
|
||
var _this4 = this;
|
||
if (!this.touchMoveListener) {
|
||
this.touchMoveListener = function(event) {
|
||
return _this4.onResize(event.changedTouches[0]);
|
||
};
|
||
document.addEventListener("touchmove", this.touchMoveListener);
|
||
}
|
||
if (!this.touchEndListener) {
|
||
this.touchEndListener = function(event) {
|
||
_this4.resizeEnd(event);
|
||
_this4.unbindTouchListeners();
|
||
};
|
||
document.addEventListener("touchend", this.touchEndListener);
|
||
}
|
||
}, "bindTouchListeners"),
|
||
validateResize: /* @__PURE__ */ __name(function validateResize(newPrevPanelSize, newNextPanelSize) {
|
||
if (newPrevPanelSize > 100 || newPrevPanelSize < 0) return false;
|
||
if (newNextPanelSize > 100 || newNextPanelSize < 0) return false;
|
||
var prevPanelMinSize = getVNodeProp(this.panels[this.prevPanelIndex], "minSize");
|
||
if (this.panels[this.prevPanelIndex].props && prevPanelMinSize && prevPanelMinSize > newPrevPanelSize) {
|
||
return false;
|
||
}
|
||
var newPanelMinSize = getVNodeProp(this.panels[this.prevPanelIndex + 1], "minSize");
|
||
if (this.panels[this.prevPanelIndex + 1].props && newPanelMinSize && newPanelMinSize > newNextPanelSize) {
|
||
return false;
|
||
}
|
||
return true;
|
||
}, "validateResize"),
|
||
unbindMouseListeners: /* @__PURE__ */ __name(function unbindMouseListeners() {
|
||
if (this.mouseMoveListener) {
|
||
document.removeEventListener("mousemove", this.mouseMoveListener);
|
||
this.mouseMoveListener = null;
|
||
}
|
||
if (this.mouseUpListener) {
|
||
document.removeEventListener("mouseup", this.mouseUpListener);
|
||
this.mouseUpListener = null;
|
||
}
|
||
}, "unbindMouseListeners"),
|
||
unbindTouchListeners: /* @__PURE__ */ __name(function unbindTouchListeners() {
|
||
if (this.touchMoveListener) {
|
||
document.removeEventListener("touchmove", this.touchMoveListener);
|
||
this.touchMoveListener = null;
|
||
}
|
||
if (this.touchEndListener) {
|
||
document.removeEventListener("touchend", this.touchEndListener);
|
||
this.touchEndListener = null;
|
||
}
|
||
}, "unbindTouchListeners"),
|
||
clear: /* @__PURE__ */ __name(function clear() {
|
||
this.dragging = false;
|
||
this.size = null;
|
||
this.startPos = null;
|
||
this.prevPanelElement = null;
|
||
this.nextPanelElement = null;
|
||
this.prevPanelSize = null;
|
||
this.nextPanelSize = null;
|
||
this.gutterElement = null;
|
||
this.prevPanelIndex = null;
|
||
}, "clear"),
|
||
isStateful: /* @__PURE__ */ __name(function isStateful() {
|
||
return this.stateKey != null;
|
||
}, "isStateful"),
|
||
getStorage: /* @__PURE__ */ __name(function getStorage() {
|
||
switch (this.stateStorage) {
|
||
case "local":
|
||
return window.localStorage;
|
||
case "session":
|
||
return window.sessionStorage;
|
||
default:
|
||
throw new Error(this.stateStorage + ' is not a valid value for the state storage, supported values are "local" and "session".');
|
||
}
|
||
}, "getStorage"),
|
||
saveState: /* @__PURE__ */ __name(function saveState() {
|
||
if (isArray(this.panelSizes)) {
|
||
this.getStorage().setItem(this.stateKey, JSON.stringify(this.panelSizes));
|
||
}
|
||
}, "saveState"),
|
||
restoreState: /* @__PURE__ */ __name(function restoreState() {
|
||
var _this5 = this;
|
||
var storage = this.getStorage();
|
||
var stateString = storage.getItem(this.stateKey);
|
||
if (stateString) {
|
||
this.panelSizes = JSON.parse(stateString);
|
||
var children = _toConsumableArray$2(this.$el.children).filter(function(child) {
|
||
return child.getAttribute("data-pc-name") === "splitterpanel";
|
||
});
|
||
children.forEach(function(child, i) {
|
||
child.style.flexBasis = "calc(" + _this5.panelSizes[i] + "% - " + (_this5.panels.length - 1) * _this5.gutterSize + "px)";
|
||
});
|
||
return true;
|
||
}
|
||
return false;
|
||
}, "restoreState")
|
||
},
|
||
computed: {
|
||
panels: /* @__PURE__ */ __name(function panels() {
|
||
var _this6 = this;
|
||
var panels2 = [];
|
||
this.$slots["default"]().forEach(function(child) {
|
||
if (_this6.isSplitterPanel(child)) {
|
||
panels2.push(child);
|
||
} else if (child.children instanceof Array) {
|
||
child.children.forEach(function(nestedChild) {
|
||
if (_this6.isSplitterPanel(nestedChild)) {
|
||
panels2.push(nestedChild);
|
||
}
|
||
});
|
||
}
|
||
});
|
||
return panels2;
|
||
}, "panels"),
|
||
gutterStyle: /* @__PURE__ */ __name(function gutterStyle() {
|
||
if (this.horizontal) return {
|
||
width: this.gutterSize + "px"
|
||
};
|
||
else return {
|
||
height: this.gutterSize + "px"
|
||
};
|
||
}, "gutterStyle"),
|
||
horizontal: /* @__PURE__ */ __name(function horizontal() {
|
||
return this.layout === "horizontal";
|
||
}, "horizontal"),
|
||
getPTOptions: /* @__PURE__ */ __name(function getPTOptions() {
|
||
var _this$$parentInstance;
|
||
return {
|
||
context: {
|
||
nested: (_this$$parentInstance = this.$parentInstance) === null || _this$$parentInstance === void 0 ? void 0 : _this$$parentInstance.nestedState
|
||
}
|
||
};
|
||
}, "getPTOptions")
|
||
}
|
||
};
|
||
var _hoisted_1$k = ["onMousedown", "onTouchstart", "onTouchmove", "onTouchend"];
|
||
var _hoisted_2$h = ["aria-orientation", "aria-valuenow", "onKeydown"];
|
||
function render$g(_ctx, _cache, $props, $setup, $data, $options) {
|
||
return openBlock(), createElementBlock("div", mergeProps({
|
||
"class": _ctx.cx("root"),
|
||
style: _ctx.sx("root"),
|
||
"data-p-resizing": false
|
||
}, _ctx.ptmi("root", $options.getPTOptions)), [(openBlock(true), createElementBlock(Fragment, null, renderList($options.panels, function(panel, i) {
|
||
return openBlock(), createElementBlock(Fragment, {
|
||
key: i
|
||
}, [(openBlock(), createBlock(resolveDynamicComponent(panel), {
|
||
tabindex: "-1"
|
||
})), i !== $options.panels.length - 1 ? (openBlock(), createElementBlock("div", mergeProps({
|
||
key: 0,
|
||
ref_for: true,
|
||
ref: "gutter",
|
||
"class": _ctx.cx("gutter"),
|
||
role: "separator",
|
||
tabindex: "-1",
|
||
onMousedown: /* @__PURE__ */ __name(function onMousedown($event) {
|
||
return $options.onGutterMouseDown($event, i);
|
||
}, "onMousedown"),
|
||
onTouchstart: /* @__PURE__ */ __name(function onTouchstart($event) {
|
||
return $options.onGutterTouchStart($event, i);
|
||
}, "onTouchstart"),
|
||
onTouchmove: /* @__PURE__ */ __name(function onTouchmove($event) {
|
||
return $options.onGutterTouchMove($event, i);
|
||
}, "onTouchmove"),
|
||
onTouchend: /* @__PURE__ */ __name(function onTouchend($event) {
|
||
return $options.onGutterTouchEnd($event, i);
|
||
}, "onTouchend"),
|
||
"data-p-gutter-resizing": false
|
||
}, _ctx.ptm("gutter")), [createBaseVNode("div", mergeProps({
|
||
"class": _ctx.cx("gutterHandle"),
|
||
tabindex: "0",
|
||
style: [$options.gutterStyle],
|
||
"aria-orientation": _ctx.layout,
|
||
"aria-valuenow": $data.prevSize,
|
||
onKeyup: _cache[0] || (_cache[0] = function() {
|
||
return $options.onGutterKeyUp && $options.onGutterKeyUp.apply($options, arguments);
|
||
}),
|
||
onKeydown: /* @__PURE__ */ __name(function onKeydown2($event) {
|
||
return $options.onGutterKeyDown($event, i);
|
||
}, "onKeydown"),
|
||
ref_for: true
|
||
}, _ctx.ptm("gutterHandle")), null, 16, _hoisted_2$h)], 16, _hoisted_1$k)) : createCommentVNode("", true)], 64);
|
||
}), 128))], 16);
|
||
}
|
||
__name(render$g, "render$g");
|
||
script$a.render = render$g;
|
||
var classes$7 = {
|
||
root: /* @__PURE__ */ __name(function root4(_ref) {
|
||
var instance = _ref.instance;
|
||
return ["p-splitterpanel", {
|
||
"p-splitterpanel-nested": instance.isNested
|
||
}];
|
||
}, "root")
|
||
};
|
||
var SplitterPanelStyle = BaseStyle.extend({
|
||
name: "splitterpanel",
|
||
classes: classes$7
|
||
});
|
||
var script$1$7 = {
|
||
name: "BaseSplitterPanel",
|
||
"extends": script$g,
|
||
props: {
|
||
size: {
|
||
type: Number,
|
||
"default": null
|
||
},
|
||
minSize: {
|
||
type: Number,
|
||
"default": null
|
||
}
|
||
},
|
||
style: SplitterPanelStyle,
|
||
provide: /* @__PURE__ */ __name(function provide6() {
|
||
return {
|
||
$pcSplitterPanel: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script$9 = {
|
||
name: "SplitterPanel",
|
||
"extends": script$1$7,
|
||
inheritAttrs: false,
|
||
data: /* @__PURE__ */ __name(function data3() {
|
||
return {
|
||
nestedState: null
|
||
};
|
||
}, "data"),
|
||
computed: {
|
||
isNested: /* @__PURE__ */ __name(function isNested() {
|
||
var _this = this;
|
||
return this.$slots["default"]().some(function(child) {
|
||
_this.nestedState = child.type.name === "Splitter" ? true : null;
|
||
return _this.nestedState;
|
||
});
|
||
}, "isNested"),
|
||
getPTOptions: /* @__PURE__ */ __name(function getPTOptions2() {
|
||
return {
|
||
context: {
|
||
nested: this.isNested
|
||
}
|
||
};
|
||
}, "getPTOptions")
|
||
}
|
||
};
|
||
function render$f(_ctx, _cache, $props, $setup, $data, $options) {
|
||
return openBlock(), createElementBlock("div", mergeProps({
|
||
ref: "container",
|
||
"class": _ctx.cx("root")
|
||
}, _ctx.ptmi("root", $options.getPTOptions)), [renderSlot(_ctx.$slots, "default")], 16);
|
||
}
|
||
__name(render$f, "render$f");
|
||
script$9.render = render$f;
|
||
const _sfc_main$k = /* @__PURE__ */ defineComponent({
|
||
__name: "LiteGraphCanvasSplitterOverlay",
|
||
setup(__props) {
|
||
const settingStore = useSettingStore();
|
||
const sidebarLocation = computed(
|
||
() => settingStore.get("Comfy.Sidebar.Location")
|
||
);
|
||
const sidebarPanelVisible = computed(
|
||
() => useSidebarTabStore().activeSidebarTab !== null
|
||
);
|
||
const bottomPanelVisible = computed(
|
||
() => useBottomPanelStore().bottomPanelVisible
|
||
);
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createBlock(unref(script$a), {
|
||
class: "splitter-overlay-root splitter-overlay",
|
||
"pt:gutter": sidebarPanelVisible.value ? "" : "hidden",
|
||
stateKey: "sidebar-splitter",
|
||
stateStorage: "local"
|
||
}, {
|
||
default: withCtx(() => [
|
||
sidebarLocation.value === "left" ? withDirectives((openBlock(), createBlock(unref(script$9), {
|
||
key: 0,
|
||
class: "side-bar-panel",
|
||
minSize: 10,
|
||
size: 20
|
||
}, {
|
||
default: withCtx(() => [
|
||
renderSlot(_ctx.$slots, "side-bar-panel", {}, void 0, true)
|
||
]),
|
||
_: 3
|
||
}, 512)), [
|
||
[vShow, sidebarPanelVisible.value]
|
||
]) : createCommentVNode("", true),
|
||
createVNode(unref(script$9), { size: 100 }, {
|
||
default: withCtx(() => [
|
||
createVNode(unref(script$a), {
|
||
class: "splitter-overlay max-w-full",
|
||
layout: "vertical",
|
||
"pt:gutter": bottomPanelVisible.value ? "" : "hidden",
|
||
stateKey: "bottom-panel-splitter",
|
||
stateStorage: "local"
|
||
}, {
|
||
default: withCtx(() => [
|
||
createVNode(unref(script$9), { class: "graph-canvas-panel relative" }, {
|
||
default: withCtx(() => [
|
||
renderSlot(_ctx.$slots, "graph-canvas-panel", {}, void 0, true)
|
||
]),
|
||
_: 3
|
||
}),
|
||
withDirectives(createVNode(unref(script$9), { class: "bottom-panel" }, {
|
||
default: withCtx(() => [
|
||
renderSlot(_ctx.$slots, "bottom-panel", {}, void 0, true)
|
||
]),
|
||
_: 3
|
||
}, 512), [
|
||
[vShow, bottomPanelVisible.value]
|
||
])
|
||
]),
|
||
_: 3
|
||
}, 8, ["pt:gutter"])
|
||
]),
|
||
_: 3
|
||
}),
|
||
sidebarLocation.value === "right" ? withDirectives((openBlock(), createBlock(unref(script$9), {
|
||
key: 1,
|
||
class: "side-bar-panel",
|
||
minSize: 10,
|
||
size: 20
|
||
}, {
|
||
default: withCtx(() => [
|
||
renderSlot(_ctx.$slots, "side-bar-panel", {}, void 0, true)
|
||
]),
|
||
_: 3
|
||
}, 512)), [
|
||
[vShow, sidebarPanelVisible.value]
|
||
]) : createCommentVNode("", true)
|
||
]),
|
||
_: 3
|
||
}, 8, ["pt:gutter"]);
|
||
};
|
||
}
|
||
});
|
||
const LiteGraphCanvasSplitterOverlay = /* @__PURE__ */ _export_sfc(_sfc_main$k, [["__scopeId", "data-v-7c3279c1"]]);
|
||
var theme$6 = /* @__PURE__ */ __name(function theme3(_ref) {
|
||
var dt = _ref.dt;
|
||
return "\n.p-autocomplete {\n display: inline-flex;\n}\n\n.p-autocomplete-loader {\n position: absolute;\n top: 50%;\n margin-top: -0.5rem;\n right: ".concat(dt("autocomplete.padding.x"), ";\n}\n\n.p-autocomplete:has(.p-autocomplete-dropdown) .p-autocomplete-loader {\n right: calc(").concat(dt("autocomplete.dropdown.width"), " + ").concat(dt("autocomplete.padding.x"), ");\n}\n\n.p-autocomplete:has(.p-autocomplete-dropdown) .p-autocomplete-input {\n flex: 1 1 auto;\n width: 1%;\n}\n\n.p-autocomplete:has(.p-autocomplete-dropdown) .p-autocomplete-input,\n.p-autocomplete:has(.p-autocomplete-dropdown) .p-autocomplete-input-multiple {\n border-top-right-radius: 0;\n border-bottom-right-radius: 0;\n}\n\n.p-autocomplete-dropdown {\n cursor: pointer;\n display: inline-flex;\n cursor: pointer;\n user-select: none;\n align-items: center;\n justify-content: center;\n overflow: hidden;\n position: relative;\n width: ").concat(dt("autocomplete.dropdown.width"), ";\n border-top-right-radius: ").concat(dt("autocomplete.dropdown.border.radius"), ";\n border-bottom-right-radius: ").concat(dt("autocomplete.dropdown.border.radius"), ";\n background: ").concat(dt("autocomplete.dropdown.background"), ";\n border: 1px solid ").concat(dt("autocomplete.dropdown.border.color"), ";\n border-left: 0 none;\n color: ").concat(dt("autocomplete.dropdown.color"), ";\n transition: background ").concat(dt("autocomplete.transition.duration"), ", color ").concat(dt("autocomplete.transition.duration"), ", border-color ").concat(dt("autocomplete.transition.duration"), ", outline-color ").concat(dt("autocomplete.transition.duration"), ", box-shadow ").concat(dt("autocomplete.transition.duration"), ";\n outline-color: transparent;\n}\n\n.p-autocomplete-dropdown:not(:disabled):hover {\n background: ").concat(dt("autocomplete.dropdown.hover.background"), ";\n border-color: ").concat(dt("autocomplete.dropdown.hover.border.color"), ";\n color: ").concat(dt("autocomplete.dropdown.hover.color"), ";\n}\n\n.p-autocomplete-dropdown:not(:disabled):active {\n background: ").concat(dt("autocomplete.dropdown.active.background"), ";\n border-color: ").concat(dt("autocomplete.dropdown.active.border.color"), ";\n color: ").concat(dt("autocomplete.dropdown.active.color"), ";\n}\n\n.p-autocomplete-dropdown:focus-visible {\n box-shadow: ").concat(dt("autocomplete.dropdown.focus.ring.shadow"), ";\n outline: ").concat(dt("autocomplete.dropdown.focus.ring.width"), " ").concat(dt("autocomplete.dropdown.focus.ring.style"), " ").concat(dt("autocomplete.dropdown.focus.ring.color"), ";\n outline-offset: ").concat(dt("autocomplete.dropdown.focus.ring.offset"), ";\n}\n\n.p-autocomplete .p-autocomplete-overlay {\n min-width: 100%;\n}\n\n.p-autocomplete-overlay {\n position: absolute;\n overflow: auto;\n top: 0;\n left: 0;\n background: ").concat(dt("autocomplete.overlay.background"), ";\n color: ").concat(dt("autocomplete.overlay.color"), ";\n border: 1px solid ").concat(dt("autocomplete.overlay.border.color"), ";\n border-radius: ").concat(dt("autocomplete.overlay.border.radius"), ";\n box-shadow: ").concat(dt("autocomplete.overlay.shadow"), ";\n}\n\n.p-autocomplete-list {\n margin: 0;\n padding: 0;\n list-style-type: none;\n display: flex;\n flex-direction: column;\n gap: ").concat(dt("autocomplete.list.gap"), ";\n padding: ").concat(dt("autocomplete.list.padding"), ";\n}\n\n.p-autocomplete-option {\n cursor: pointer;\n white-space: nowrap;\n position: relative;\n overflow: hidden;\n display: flex;\n align-items: center;\n padding: ").concat(dt("autocomplete.option.padding"), ";\n border: 0 none;\n color: ").concat(dt("autocomplete.option.color"), ";\n background: transparent;\n transition: background ").concat(dt("autocomplete.transition.duration"), ", color ").concat(dt("autocomplete.transition.duration"), ", border-color ").concat(dt("autocomplete.transition.duration"), ";\n border-radius: ").concat(dt("autocomplete.option.border.radius"), ";\n}\n\n.p-autocomplete-option:not(.p-autocomplete-option-selected):not(.p-disabled).p-focus {\n background: ").concat(dt("autocomplete.option.focus.background"), ";\n color: ").concat(dt("autocomplete.option.focus.color"), ";\n}\n\n.p-autocomplete-option-selected {\n background: ").concat(dt("autocomplete.option.selected.background"), ";\n color: ").concat(dt("autocomplete.option.selected.color"), ";\n}\n\n.p-autocomplete-option-selected.p-focus {\n background: ").concat(dt("autocomplete.option.selected.focus.background"), ";\n color: ").concat(dt("autocomplete.option.selected.focus.color"), ";\n}\n\n.p-autocomplete-option-group {\n margin: 0;\n padding: ").concat(dt("autocomplete.option.group.padding"), ";\n color: ").concat(dt("autocomplete.option.group.color"), ";\n background: ").concat(dt("autocomplete.option.group.background"), ";\n font-weight: ").concat(dt("autocomplete.option.group.font.weight"), ";\n}\n\n.p-autocomplete-input-multiple {\n margin: 0;\n list-style-type: none;\n cursor: text;\n overflow: hidden;\n display: flex;\n align-items: center;\n flex-wrap: wrap;\n padding: calc(").concat(dt("autocomplete.padding.y"), " / 2) ").concat(dt("autocomplete.padding.x"), ";\n gap: calc(").concat(dt("autocomplete.padding.y"), " / 2);\n color: ").concat(dt("autocomplete.color"), ";\n background: ").concat(dt("autocomplete.background"), ";\n border: 1px solid ").concat(dt("autocomplete.border.color"), ";\n border-radius: ").concat(dt("autocomplete.border.radius"), ";\n width: 100%;\n transition: background ").concat(dt("autocomplete.transition.duration"), ", color ").concat(dt("autocomplete.transition.duration"), ", border-color ").concat(dt("autocomplete.transition.duration"), ", outline-color ").concat(dt("autocomplete.transition.duration"), ", box-shadow ").concat(dt("autocomplete.transition.duration"), ";\n outline-color: transparent;\n box-shadow: ").concat(dt("autocomplete.shadow"), ";\n}\n\n.p-autocomplete:not(.p-disabled):hover .p-autocomplete-input-multiple {\n border-color: ").concat(dt("autocomplete.hover.border.color"), ";\n}\n\n.p-autocomplete:not(.p-disabled).p-focus .p-autocomplete-input-multiple {\n border-color: ").concat(dt("autocomplete.focus.border.color"), ";\n box-shadow: ").concat(dt("autocomplete.focus.ring.shadow"), ";\n outline: ").concat(dt("autocomplete.focus.ring.width"), " ").concat(dt("autocomplete.focus.ring.style"), " ").concat(dt("autocomplete.focus.ring.color"), ";\n outline-offset: ").concat(dt("autocomplete.focus.ring.offset"), ";\n}\n\n.p-autocomplete.p-invalid .p-autocomplete-input-multiple {\n border-color: ").concat(dt("autocomplete.invalid.border.color"), ";\n}\n\n.p-variant-filled.p-autocomplete-input-multiple {\n background: ").concat(dt("autocomplete.filled.background"), ";\n}\n\n.p-autocomplete:not(.p-disabled).p-focus .p-variant-filled.p-autocomplete-input-multiple {\n background: ").concat(dt("autocomplete.filled.focus.background"), ";\n}\n\n.p-autocomplete.p-disabled .p-autocomplete-input-multiple {\n opacity: 1;\n background: ").concat(dt("autocomplete.disabled.background"), ";\n color: ").concat(dt("autocomplete.disabled.color"), ";\n}\n\n.p-autocomplete-chip.p-chip {\n padding-top: calc(").concat(dt("autocomplete.padding.y"), " / 2);\n padding-bottom: calc(").concat(dt("autocomplete.padding.y"), " / 2);\n border-radius: ").concat(dt("autocomplete.chip.border.radius"), ";\n}\n\n.p-autocomplete-input-multiple:has(.p-autocomplete-chip) {\n padding-left: calc(").concat(dt("autocomplete.padding.y"), " / 2);\n padding-right: calc(").concat(dt("autocomplete.padding.y"), " / 2);\n}\n\n.p-autocomplete-chip-item.p-focus .p-autocomplete-chip {\n background: ").concat(dt("inputchips.chip.focus.background"), ";\n color: ").concat(dt("inputchips.chip.focus.color"), ";\n}\n\n.p-autocomplete-input-chip {\n flex: 1 1 auto;\n display: inline-flex;\n padding-top: calc(").concat(dt("autocomplete.padding.y"), " / 2);\n padding-bottom: calc(").concat(dt("autocomplete.padding.y"), " / 2);\n}\n\n.p-autocomplete-input-chip input {\n border: 0 none;\n outline: 0 none;\n background: transparent;\n margin: 0;\n padding: 0;\n box-shadow: none;\n border-radius: 0;\n width: 100%;\n font-family: inherit;\n font-feature-settings: inherit;\n font-size: 1rem;\n color: inherit;\n}\n\n.p-autocomplete-input-chip input::placeholder {\n color: ").concat(dt("autocomplete.placeholder.color"), ";\n}\n\n.p-autocomplete-empty-message {\n padding: ").concat(dt("autocomplete.empty.message.padding"), ";\n}\n\n.p-autocomplete-fluid {\n display: flex;\n}\n\n.p-autocomplete-fluid:has(.p-autocomplete-dropdown) .p-autocomplete-input {\n width: 1%;\n}\n");
|
||
}, "theme");
|
||
var inlineStyles$3 = {
|
||
root: {
|
||
position: "relative"
|
||
}
|
||
};
|
||
var classes$6 = {
|
||
root: /* @__PURE__ */ __name(function root5(_ref2) {
|
||
var instance = _ref2.instance, props = _ref2.props;
|
||
return ["p-autocomplete p-component p-inputwrapper", {
|
||
"p-disabled": props.disabled,
|
||
"p-invalid": props.invalid,
|
||
"p-focus": instance.focused,
|
||
"p-inputwrapper-filled": props.modelValue || isNotEmpty(instance.inputValue),
|
||
"p-inputwrapper-focus": instance.focused,
|
||
"p-autocomplete-open": instance.overlayVisible,
|
||
"p-autocomplete-fluid": instance.hasFluid
|
||
}];
|
||
}, "root"),
|
||
pcInput: "p-autocomplete-input",
|
||
inputMultiple: /* @__PURE__ */ __name(function inputMultiple(_ref3) {
|
||
var props = _ref3.props, instance = _ref3.instance;
|
||
return ["p-autocomplete-input-multiple", {
|
||
"p-variant-filled": props.variant ? props.variant === "filled" : instance.$primevue.config.inputStyle === "filled" || instance.$primevue.config.inputVariant === "filled"
|
||
}];
|
||
}, "inputMultiple"),
|
||
chipItem: /* @__PURE__ */ __name(function chipItem(_ref4) {
|
||
var instance = _ref4.instance, i = _ref4.i;
|
||
return ["p-autocomplete-chip-item", {
|
||
"p-focus": instance.focusedMultipleOptionIndex === i
|
||
}];
|
||
}, "chipItem"),
|
||
pcChip: "p-autocomplete-chip",
|
||
chipIcon: "p-autocomplete-chip-icon",
|
||
inputChip: "p-autocomplete-input-chip",
|
||
loader: "p-autocomplete-loader",
|
||
dropdown: "p-autocomplete-dropdown",
|
||
overlay: "p-autocomplete-overlay p-component",
|
||
list: "p-autocomplete-list",
|
||
optionGroup: "p-autocomplete-option-group",
|
||
option: /* @__PURE__ */ __name(function option(_ref5) {
|
||
var instance = _ref5.instance, _option = _ref5.option, i = _ref5.i, getItemOptions = _ref5.getItemOptions;
|
||
return ["p-autocomplete-option", {
|
||
"p-autocomplete-option-selected": instance.isSelected(_option),
|
||
"p-focus": instance.focusedOptionIndex === instance.getOptionIndex(i, getItemOptions),
|
||
"p-disabled": instance.isOptionDisabled(_option)
|
||
}];
|
||
}, "option"),
|
||
emptyMessage: "p-autocomplete-empty-message"
|
||
};
|
||
var AutoCompleteStyle = BaseStyle.extend({
|
||
name: "autocomplete",
|
||
theme: theme$6,
|
||
classes: classes$6,
|
||
inlineStyles: inlineStyles$3
|
||
});
|
||
var script$1$6 = {
|
||
name: "BaseAutoComplete",
|
||
"extends": script$g,
|
||
props: {
|
||
modelValue: null,
|
||
suggestions: {
|
||
type: Array,
|
||
"default": null
|
||
},
|
||
optionLabel: null,
|
||
optionDisabled: null,
|
||
optionGroupLabel: null,
|
||
optionGroupChildren: null,
|
||
scrollHeight: {
|
||
type: String,
|
||
"default": "14rem"
|
||
},
|
||
dropdown: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
dropdownMode: {
|
||
type: String,
|
||
"default": "blank"
|
||
},
|
||
multiple: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
loading: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
variant: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
invalid: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
disabled: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
placeholder: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
dataKey: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
minLength: {
|
||
type: Number,
|
||
"default": 1
|
||
},
|
||
delay: {
|
||
type: Number,
|
||
"default": 300
|
||
},
|
||
appendTo: {
|
||
type: [String, Object],
|
||
"default": "body"
|
||
},
|
||
forceSelection: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
completeOnFocus: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
inputId: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
inputStyle: {
|
||
type: Object,
|
||
"default": null
|
||
},
|
||
inputClass: {
|
||
type: [String, Object],
|
||
"default": null
|
||
},
|
||
panelStyle: {
|
||
type: Object,
|
||
"default": null
|
||
},
|
||
panelClass: {
|
||
type: [String, Object],
|
||
"default": null
|
||
},
|
||
overlayStyle: {
|
||
type: Object,
|
||
"default": null
|
||
},
|
||
overlayClass: {
|
||
type: [String, Object],
|
||
"default": null
|
||
},
|
||
dropdownIcon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
dropdownClass: {
|
||
type: [String, Object],
|
||
"default": null
|
||
},
|
||
loader: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
loadingIcon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
removeTokenIcon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
chipIcon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
virtualScrollerOptions: {
|
||
type: Object,
|
||
"default": null
|
||
},
|
||
autoOptionFocus: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
selectOnFocus: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
focusOnHover: {
|
||
type: Boolean,
|
||
"default": true
|
||
},
|
||
searchLocale: {
|
||
type: String,
|
||
"default": void 0
|
||
},
|
||
searchMessage: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
selectionMessage: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
emptySelectionMessage: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
emptySearchMessage: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
tabindex: {
|
||
type: Number,
|
||
"default": 0
|
||
},
|
||
typeahead: {
|
||
type: Boolean,
|
||
"default": true
|
||
},
|
||
ariaLabel: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
ariaLabelledby: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
fluid: {
|
||
type: Boolean,
|
||
"default": null
|
||
}
|
||
},
|
||
style: AutoCompleteStyle,
|
||
provide: /* @__PURE__ */ __name(function provide7() {
|
||
return {
|
||
$pcAutoComplete: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
function _typeof$1$1(o) {
|
||
"@babel/helpers - typeof";
|
||
return _typeof$1$1 = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(o2) {
|
||
return typeof o2;
|
||
} : function(o2) {
|
||
return o2 && "function" == typeof Symbol && o2.constructor === Symbol && o2 !== Symbol.prototype ? "symbol" : typeof o2;
|
||
}, _typeof$1$1(o);
|
||
}
|
||
__name(_typeof$1$1, "_typeof$1$1");
|
||
function _toConsumableArray$1(r) {
|
||
return _arrayWithoutHoles$1(r) || _iterableToArray$1(r) || _unsupportedIterableToArray$1(r) || _nonIterableSpread$1();
|
||
}
|
||
__name(_toConsumableArray$1, "_toConsumableArray$1");
|
||
function _nonIterableSpread$1() {
|
||
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
||
}
|
||
__name(_nonIterableSpread$1, "_nonIterableSpread$1");
|
||
function _unsupportedIterableToArray$1(r, a) {
|
||
if (r) {
|
||
if ("string" == typeof r) return _arrayLikeToArray$1(r, a);
|
||
var t = {}.toString.call(r).slice(8, -1);
|
||
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray$1(r, a) : void 0;
|
||
}
|
||
}
|
||
__name(_unsupportedIterableToArray$1, "_unsupportedIterableToArray$1");
|
||
function _iterableToArray$1(r) {
|
||
if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r);
|
||
}
|
||
__name(_iterableToArray$1, "_iterableToArray$1");
|
||
function _arrayWithoutHoles$1(r) {
|
||
if (Array.isArray(r)) return _arrayLikeToArray$1(r);
|
||
}
|
||
__name(_arrayWithoutHoles$1, "_arrayWithoutHoles$1");
|
||
function _arrayLikeToArray$1(r, a) {
|
||
(null == a || a > r.length) && (a = r.length);
|
||
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
|
||
return n;
|
||
}
|
||
__name(_arrayLikeToArray$1, "_arrayLikeToArray$1");
|
||
var script$8 = {
|
||
name: "AutoComplete",
|
||
"extends": script$1$6,
|
||
inheritAttrs: false,
|
||
emits: ["update:modelValue", "change", "focus", "blur", "item-select", "item-unselect", "option-select", "option-unselect", "dropdown-click", "clear", "complete", "before-show", "before-hide", "show", "hide"],
|
||
inject: {
|
||
$pcFluid: {
|
||
"default": null
|
||
}
|
||
},
|
||
outsideClickListener: null,
|
||
resizeListener: null,
|
||
scrollHandler: null,
|
||
overlay: null,
|
||
virtualScroller: null,
|
||
searchTimeout: null,
|
||
dirty: false,
|
||
data: /* @__PURE__ */ __name(function data4() {
|
||
return {
|
||
id: this.$attrs.id,
|
||
clicked: false,
|
||
focused: false,
|
||
focusedOptionIndex: -1,
|
||
focusedMultipleOptionIndex: -1,
|
||
overlayVisible: false,
|
||
searching: false
|
||
};
|
||
}, "data"),
|
||
watch: {
|
||
"$attrs.id": /* @__PURE__ */ __name(function $attrsId(newValue) {
|
||
this.id = newValue || UniqueComponentId();
|
||
}, "$attrsId"),
|
||
suggestions: /* @__PURE__ */ __name(function suggestions() {
|
||
if (this.searching) {
|
||
this.show();
|
||
this.focusedOptionIndex = this.overlayVisible && this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;
|
||
this.searching = false;
|
||
}
|
||
this.autoUpdateModel();
|
||
}, "suggestions")
|
||
},
|
||
mounted: /* @__PURE__ */ __name(function mounted3() {
|
||
this.id = this.id || UniqueComponentId();
|
||
this.autoUpdateModel();
|
||
}, "mounted"),
|
||
updated: /* @__PURE__ */ __name(function updated2() {
|
||
if (this.overlayVisible) {
|
||
this.alignOverlay();
|
||
}
|
||
}, "updated"),
|
||
beforeUnmount: /* @__PURE__ */ __name(function beforeUnmount3() {
|
||
this.unbindOutsideClickListener();
|
||
this.unbindResizeListener();
|
||
if (this.scrollHandler) {
|
||
this.scrollHandler.destroy();
|
||
this.scrollHandler = null;
|
||
}
|
||
if (this.overlay) {
|
||
ZIndex.clear(this.overlay);
|
||
this.overlay = null;
|
||
}
|
||
}, "beforeUnmount"),
|
||
methods: {
|
||
getOptionIndex: /* @__PURE__ */ __name(function getOptionIndex(index, fn) {
|
||
return this.virtualScrollerDisabled ? index : fn && fn(index)["index"];
|
||
}, "getOptionIndex"),
|
||
getOptionLabel: /* @__PURE__ */ __name(function getOptionLabel(option2) {
|
||
return this.optionLabel ? resolveFieldData(option2, this.optionLabel) : option2;
|
||
}, "getOptionLabel"),
|
||
getOptionValue: /* @__PURE__ */ __name(function getOptionValue(option2) {
|
||
return option2;
|
||
}, "getOptionValue"),
|
||
getOptionRenderKey: /* @__PURE__ */ __name(function getOptionRenderKey(option2, index) {
|
||
return (this.dataKey ? resolveFieldData(option2, this.dataKey) : this.getOptionLabel(option2)) + "_" + index;
|
||
}, "getOptionRenderKey"),
|
||
getPTOptions: /* @__PURE__ */ __name(function getPTOptions3(option2, itemOptions, index, key) {
|
||
return this.ptm(key, {
|
||
context: {
|
||
selected: this.isSelected(option2),
|
||
focused: this.focusedOptionIndex === this.getOptionIndex(index, itemOptions),
|
||
disabled: this.isOptionDisabled(option2)
|
||
}
|
||
});
|
||
}, "getPTOptions"),
|
||
isOptionDisabled: /* @__PURE__ */ __name(function isOptionDisabled(option2) {
|
||
return this.optionDisabled ? resolveFieldData(option2, this.optionDisabled) : false;
|
||
}, "isOptionDisabled"),
|
||
isOptionGroup: /* @__PURE__ */ __name(function isOptionGroup(option2) {
|
||
return this.optionGroupLabel && option2.optionGroup && option2.group;
|
||
}, "isOptionGroup"),
|
||
getOptionGroupLabel: /* @__PURE__ */ __name(function getOptionGroupLabel(optionGroup) {
|
||
return resolveFieldData(optionGroup, this.optionGroupLabel);
|
||
}, "getOptionGroupLabel"),
|
||
getOptionGroupChildren: /* @__PURE__ */ __name(function getOptionGroupChildren(optionGroup) {
|
||
return resolveFieldData(optionGroup, this.optionGroupChildren);
|
||
}, "getOptionGroupChildren"),
|
||
getAriaPosInset: /* @__PURE__ */ __name(function getAriaPosInset(index) {
|
||
var _this = this;
|
||
return (this.optionGroupLabel ? index - this.visibleOptions.slice(0, index).filter(function(option2) {
|
||
return _this.isOptionGroup(option2);
|
||
}).length : index) + 1;
|
||
}, "getAriaPosInset"),
|
||
show: /* @__PURE__ */ __name(function show(isFocus) {
|
||
this.$emit("before-show");
|
||
this.dirty = true;
|
||
this.overlayVisible = true;
|
||
this.focusedOptionIndex = this.focusedOptionIndex !== -1 ? this.focusedOptionIndex : this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;
|
||
isFocus && focus(this.multiple ? this.$refs.focusInput : this.$refs.focusInput.$el);
|
||
}, "show"),
|
||
hide: /* @__PURE__ */ __name(function hide(isFocus) {
|
||
var _this2 = this;
|
||
var _hide = /* @__PURE__ */ __name(function _hide2() {
|
||
_this2.$emit("before-hide");
|
||
_this2.dirty = isFocus;
|
||
_this2.overlayVisible = false;
|
||
_this2.clicked = false;
|
||
_this2.focusedOptionIndex = -1;
|
||
isFocus && focus(_this2.multiple ? _this2.$refs.focusInput : _this2.$refs.focusInput.$el);
|
||
}, "_hide");
|
||
setTimeout(function() {
|
||
_hide();
|
||
}, 0);
|
||
}, "hide"),
|
||
onFocus: /* @__PURE__ */ __name(function onFocus2(event) {
|
||
if (this.disabled) {
|
||
return;
|
||
}
|
||
if (!this.dirty && this.completeOnFocus) {
|
||
this.search(event, event.target.value, "focus");
|
||
}
|
||
this.dirty = true;
|
||
this.focused = true;
|
||
if (this.overlayVisible) {
|
||
this.focusedOptionIndex = this.focusedOptionIndex !== -1 ? this.focusedOptionIndex : this.overlayVisible && this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;
|
||
this.scrollInView(this.focusedOptionIndex);
|
||
}
|
||
this.$emit("focus", event);
|
||
}, "onFocus"),
|
||
onBlur: /* @__PURE__ */ __name(function onBlur(event) {
|
||
this.dirty = false;
|
||
this.focused = false;
|
||
this.focusedOptionIndex = -1;
|
||
this.$emit("blur", event);
|
||
}, "onBlur"),
|
||
onKeyDown: /* @__PURE__ */ __name(function onKeyDown(event) {
|
||
if (this.disabled) {
|
||
event.preventDefault();
|
||
return;
|
||
}
|
||
switch (event.code) {
|
||
case "ArrowDown":
|
||
this.onArrowDownKey(event);
|
||
break;
|
||
case "ArrowUp":
|
||
this.onArrowUpKey(event);
|
||
break;
|
||
case "ArrowLeft":
|
||
this.onArrowLeftKey(event);
|
||
break;
|
||
case "ArrowRight":
|
||
this.onArrowRightKey(event);
|
||
break;
|
||
case "Home":
|
||
this.onHomeKey(event);
|
||
break;
|
||
case "End":
|
||
this.onEndKey(event);
|
||
break;
|
||
case "PageDown":
|
||
this.onPageDownKey(event);
|
||
break;
|
||
case "PageUp":
|
||
this.onPageUpKey(event);
|
||
break;
|
||
case "Enter":
|
||
case "NumpadEnter":
|
||
this.onEnterKey(event);
|
||
break;
|
||
case "Escape":
|
||
this.onEscapeKey(event);
|
||
break;
|
||
case "Tab":
|
||
this.onTabKey(event);
|
||
break;
|
||
case "Backspace":
|
||
this.onBackspaceKey(event);
|
||
break;
|
||
}
|
||
this.clicked = false;
|
||
}, "onKeyDown"),
|
||
onInput: /* @__PURE__ */ __name(function onInput(event) {
|
||
var _this3 = this;
|
||
if (this.typeahead) {
|
||
if (this.searchTimeout) {
|
||
clearTimeout(this.searchTimeout);
|
||
}
|
||
var query = event.target.value;
|
||
if (!this.multiple) {
|
||
this.updateModel(event, query);
|
||
}
|
||
if (query.length === 0) {
|
||
this.hide();
|
||
this.$emit("clear");
|
||
} else {
|
||
if (query.length >= this.minLength) {
|
||
this.focusedOptionIndex = -1;
|
||
this.searchTimeout = setTimeout(function() {
|
||
_this3.search(event, query, "input");
|
||
}, this.delay);
|
||
} else {
|
||
this.hide();
|
||
}
|
||
}
|
||
}
|
||
}, "onInput"),
|
||
onChange: /* @__PURE__ */ __name(function onChange(event) {
|
||
var _this4 = this;
|
||
if (this.forceSelection) {
|
||
var valid = false;
|
||
if (this.visibleOptions && !this.multiple) {
|
||
var value = this.multiple ? this.$refs.focusInput.value : this.$refs.focusInput.$el.value;
|
||
var matchedValue = this.visibleOptions.find(function(option2) {
|
||
return _this4.isOptionMatched(option2, value || "");
|
||
});
|
||
if (matchedValue !== void 0) {
|
||
valid = true;
|
||
!this.isSelected(matchedValue) && this.onOptionSelect(event, matchedValue);
|
||
}
|
||
}
|
||
if (!valid) {
|
||
if (this.multiple) this.$refs.focusInput.value = "";
|
||
else this.$refs.focusInput.$el.value = "";
|
||
this.$emit("clear");
|
||
!this.multiple && this.updateModel(event, null);
|
||
}
|
||
}
|
||
}, "onChange"),
|
||
onMultipleContainerFocus: /* @__PURE__ */ __name(function onMultipleContainerFocus() {
|
||
if (this.disabled) {
|
||
return;
|
||
}
|
||
this.focused = true;
|
||
}, "onMultipleContainerFocus"),
|
||
onMultipleContainerBlur: /* @__PURE__ */ __name(function onMultipleContainerBlur() {
|
||
this.focusedMultipleOptionIndex = -1;
|
||
this.focused = false;
|
||
}, "onMultipleContainerBlur"),
|
||
onMultipleContainerKeyDown: /* @__PURE__ */ __name(function onMultipleContainerKeyDown(event) {
|
||
if (this.disabled) {
|
||
event.preventDefault();
|
||
return;
|
||
}
|
||
switch (event.code) {
|
||
case "ArrowLeft":
|
||
this.onArrowLeftKeyOnMultiple(event);
|
||
break;
|
||
case "ArrowRight":
|
||
this.onArrowRightKeyOnMultiple(event);
|
||
break;
|
||
case "Backspace":
|
||
this.onBackspaceKeyOnMultiple(event);
|
||
break;
|
||
}
|
||
}, "onMultipleContainerKeyDown"),
|
||
onContainerClick: /* @__PURE__ */ __name(function onContainerClick(event) {
|
||
this.clicked = true;
|
||
if (this.disabled || this.searching || this.loading || this.isInputClicked(event) || this.isDropdownClicked(event)) {
|
||
return;
|
||
}
|
||
if (!this.overlay || !this.overlay.contains(event.target)) {
|
||
focus(this.multiple ? this.$refs.focusInput : this.$refs.focusInput.$el);
|
||
}
|
||
}, "onContainerClick"),
|
||
onDropdownClick: /* @__PURE__ */ __name(function onDropdownClick(event) {
|
||
var query = void 0;
|
||
if (this.overlayVisible) {
|
||
this.hide(true);
|
||
} else {
|
||
var target = this.multiple ? this.$refs.focusInput : this.$refs.focusInput.$el;
|
||
focus(target);
|
||
query = target.value;
|
||
if (this.dropdownMode === "blank") this.search(event, "", "dropdown");
|
||
else if (this.dropdownMode === "current") this.search(event, query, "dropdown");
|
||
}
|
||
this.$emit("dropdown-click", {
|
||
originalEvent: event,
|
||
query
|
||
});
|
||
}, "onDropdownClick"),
|
||
onOptionSelect: /* @__PURE__ */ __name(function onOptionSelect(event, option2) {
|
||
var isHide = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : true;
|
||
var value = this.getOptionValue(option2);
|
||
if (this.multiple) {
|
||
this.$refs.focusInput.value = "";
|
||
if (!this.isSelected(option2)) {
|
||
this.updateModel(event, [].concat(_toConsumableArray$1(this.modelValue || []), [value]));
|
||
}
|
||
} else {
|
||
this.updateModel(event, value);
|
||
}
|
||
this.$emit("item-select", {
|
||
originalEvent: event,
|
||
value: option2
|
||
});
|
||
this.$emit("option-select", {
|
||
originalEvent: event,
|
||
value: option2
|
||
});
|
||
isHide && this.hide(true);
|
||
}, "onOptionSelect"),
|
||
onOptionMouseMove: /* @__PURE__ */ __name(function onOptionMouseMove(event, index) {
|
||
if (this.focusOnHover) {
|
||
this.changeFocusedOptionIndex(event, index);
|
||
}
|
||
}, "onOptionMouseMove"),
|
||
onOverlayClick: /* @__PURE__ */ __name(function onOverlayClick(event) {
|
||
OverlayEventBus.emit("overlay-click", {
|
||
originalEvent: event,
|
||
target: this.$el
|
||
});
|
||
}, "onOverlayClick"),
|
||
onOverlayKeyDown: /* @__PURE__ */ __name(function onOverlayKeyDown(event) {
|
||
switch (event.code) {
|
||
case "Escape":
|
||
this.onEscapeKey(event);
|
||
break;
|
||
}
|
||
}, "onOverlayKeyDown"),
|
||
onArrowDownKey: /* @__PURE__ */ __name(function onArrowDownKey(event) {
|
||
if (!this.overlayVisible) {
|
||
return;
|
||
}
|
||
var optionIndex = this.focusedOptionIndex !== -1 ? this.findNextOptionIndex(this.focusedOptionIndex) : this.clicked ? this.findFirstOptionIndex() : this.findFirstFocusedOptionIndex();
|
||
this.changeFocusedOptionIndex(event, optionIndex);
|
||
event.preventDefault();
|
||
}, "onArrowDownKey"),
|
||
onArrowUpKey: /* @__PURE__ */ __name(function onArrowUpKey(event) {
|
||
if (!this.overlayVisible) {
|
||
return;
|
||
}
|
||
if (event.altKey) {
|
||
if (this.focusedOptionIndex !== -1) {
|
||
this.onOptionSelect(event, this.visibleOptions[this.focusedOptionIndex]);
|
||
}
|
||
this.overlayVisible && this.hide();
|
||
event.preventDefault();
|
||
} else {
|
||
var optionIndex = this.focusedOptionIndex !== -1 ? this.findPrevOptionIndex(this.focusedOptionIndex) : this.clicked ? this.findLastOptionIndex() : this.findLastFocusedOptionIndex();
|
||
this.changeFocusedOptionIndex(event, optionIndex);
|
||
event.preventDefault();
|
||
}
|
||
}, "onArrowUpKey"),
|
||
onArrowLeftKey: /* @__PURE__ */ __name(function onArrowLeftKey2(event) {
|
||
var target = event.currentTarget;
|
||
this.focusedOptionIndex = -1;
|
||
if (this.multiple) {
|
||
if (isEmpty(target.value) && this.hasSelectedOption) {
|
||
focus(this.$refs.multiContainer);
|
||
this.focusedMultipleOptionIndex = this.modelValue.length;
|
||
} else {
|
||
event.stopPropagation();
|
||
}
|
||
}
|
||
}, "onArrowLeftKey"),
|
||
onArrowRightKey: /* @__PURE__ */ __name(function onArrowRightKey2(event) {
|
||
this.focusedOptionIndex = -1;
|
||
this.multiple && event.stopPropagation();
|
||
}, "onArrowRightKey"),
|
||
onHomeKey: /* @__PURE__ */ __name(function onHomeKey2(event) {
|
||
var currentTarget = event.currentTarget;
|
||
var len = currentTarget.value.length;
|
||
currentTarget.setSelectionRange(0, event.shiftKey ? len : 0);
|
||
this.focusedOptionIndex = -1;
|
||
event.preventDefault();
|
||
}, "onHomeKey"),
|
||
onEndKey: /* @__PURE__ */ __name(function onEndKey2(event) {
|
||
var currentTarget = event.currentTarget;
|
||
var len = currentTarget.value.length;
|
||
currentTarget.setSelectionRange(event.shiftKey ? 0 : len, len);
|
||
this.focusedOptionIndex = -1;
|
||
event.preventDefault();
|
||
}, "onEndKey"),
|
||
onPageUpKey: /* @__PURE__ */ __name(function onPageUpKey2(event) {
|
||
this.scrollInView(0);
|
||
event.preventDefault();
|
||
}, "onPageUpKey"),
|
||
onPageDownKey: /* @__PURE__ */ __name(function onPageDownKey2(event) {
|
||
this.scrollInView(this.visibleOptions.length - 1);
|
||
event.preventDefault();
|
||
}, "onPageDownKey"),
|
||
onEnterKey: /* @__PURE__ */ __name(function onEnterKey2(event) {
|
||
if (!this.typeahead) {
|
||
if (this.multiple) {
|
||
this.updateModel(event, [].concat(_toConsumableArray$1(this.modelValue || []), [event.target.value]));
|
||
this.$refs.focusInput.value = "";
|
||
}
|
||
} else {
|
||
if (!this.overlayVisible) {
|
||
this.focusedOptionIndex = -1;
|
||
this.onArrowDownKey(event);
|
||
} else {
|
||
if (this.focusedOptionIndex !== -1) {
|
||
this.onOptionSelect(event, this.visibleOptions[this.focusedOptionIndex]);
|
||
}
|
||
this.hide();
|
||
}
|
||
}
|
||
}, "onEnterKey"),
|
||
onEscapeKey: /* @__PURE__ */ __name(function onEscapeKey(event) {
|
||
this.overlayVisible && this.hide(true);
|
||
event.preventDefault();
|
||
}, "onEscapeKey"),
|
||
onTabKey: /* @__PURE__ */ __name(function onTabKey(event) {
|
||
if (this.focusedOptionIndex !== -1) {
|
||
this.onOptionSelect(event, this.visibleOptions[this.focusedOptionIndex]);
|
||
}
|
||
this.overlayVisible && this.hide();
|
||
}, "onTabKey"),
|
||
onBackspaceKey: /* @__PURE__ */ __name(function onBackspaceKey(event) {
|
||
if (this.multiple) {
|
||
if (isNotEmpty(this.modelValue) && !this.$refs.focusInput.value) {
|
||
var removedValue = this.modelValue[this.modelValue.length - 1];
|
||
var newValue = this.modelValue.slice(0, -1);
|
||
this.$emit("update:modelValue", newValue);
|
||
this.$emit("item-unselect", {
|
||
originalEvent: event,
|
||
value: removedValue
|
||
});
|
||
this.$emit("option-unselect", {
|
||
originalEvent: event,
|
||
value: removedValue
|
||
});
|
||
}
|
||
event.stopPropagation();
|
||
}
|
||
}, "onBackspaceKey"),
|
||
onArrowLeftKeyOnMultiple: /* @__PURE__ */ __name(function onArrowLeftKeyOnMultiple() {
|
||
this.focusedMultipleOptionIndex = this.focusedMultipleOptionIndex < 1 ? 0 : this.focusedMultipleOptionIndex - 1;
|
||
}, "onArrowLeftKeyOnMultiple"),
|
||
onArrowRightKeyOnMultiple: /* @__PURE__ */ __name(function onArrowRightKeyOnMultiple() {
|
||
this.focusedMultipleOptionIndex++;
|
||
if (this.focusedMultipleOptionIndex > this.modelValue.length - 1) {
|
||
this.focusedMultipleOptionIndex = -1;
|
||
focus(this.$refs.focusInput);
|
||
}
|
||
}, "onArrowRightKeyOnMultiple"),
|
||
onBackspaceKeyOnMultiple: /* @__PURE__ */ __name(function onBackspaceKeyOnMultiple(event) {
|
||
if (this.focusedMultipleOptionIndex !== -1) {
|
||
this.removeOption(event, this.focusedMultipleOptionIndex);
|
||
}
|
||
}, "onBackspaceKeyOnMultiple"),
|
||
onOverlayEnter: /* @__PURE__ */ __name(function onOverlayEnter(el) {
|
||
ZIndex.set("overlay", el, this.$primevue.config.zIndex.overlay);
|
||
addStyle(el, {
|
||
position: "absolute",
|
||
top: "0",
|
||
left: "0"
|
||
});
|
||
this.alignOverlay();
|
||
}, "onOverlayEnter"),
|
||
onOverlayAfterEnter: /* @__PURE__ */ __name(function onOverlayAfterEnter() {
|
||
this.bindOutsideClickListener();
|
||
this.bindScrollListener();
|
||
this.bindResizeListener();
|
||
this.$emit("show");
|
||
}, "onOverlayAfterEnter"),
|
||
onOverlayLeave: /* @__PURE__ */ __name(function onOverlayLeave() {
|
||
this.unbindOutsideClickListener();
|
||
this.unbindScrollListener();
|
||
this.unbindResizeListener();
|
||
this.$emit("hide");
|
||
this.overlay = null;
|
||
}, "onOverlayLeave"),
|
||
onOverlayAfterLeave: /* @__PURE__ */ __name(function onOverlayAfterLeave(el) {
|
||
ZIndex.clear(el);
|
||
}, "onOverlayAfterLeave"),
|
||
alignOverlay: /* @__PURE__ */ __name(function alignOverlay() {
|
||
var target = this.multiple ? this.$refs.multiContainer : this.$refs.focusInput.$el;
|
||
if (this.appendTo === "self") {
|
||
relativePosition(this.overlay, target);
|
||
} else {
|
||
this.overlay.style.minWidth = getOuterWidth(target) + "px";
|
||
absolutePosition(this.overlay, target);
|
||
}
|
||
}, "alignOverlay"),
|
||
bindOutsideClickListener: /* @__PURE__ */ __name(function bindOutsideClickListener() {
|
||
var _this5 = this;
|
||
if (!this.outsideClickListener) {
|
||
this.outsideClickListener = function(event) {
|
||
if (_this5.overlayVisible && _this5.overlay && _this5.isOutsideClicked(event)) {
|
||
_this5.hide();
|
||
}
|
||
};
|
||
document.addEventListener("click", this.outsideClickListener);
|
||
}
|
||
}, "bindOutsideClickListener"),
|
||
unbindOutsideClickListener: /* @__PURE__ */ __name(function unbindOutsideClickListener() {
|
||
if (this.outsideClickListener) {
|
||
document.removeEventListener("click", this.outsideClickListener);
|
||
this.outsideClickListener = null;
|
||
}
|
||
}, "unbindOutsideClickListener"),
|
||
bindScrollListener: /* @__PURE__ */ __name(function bindScrollListener() {
|
||
var _this6 = this;
|
||
if (!this.scrollHandler) {
|
||
this.scrollHandler = new ConnectedOverlayScrollHandler(this.$refs.container, function() {
|
||
if (_this6.overlayVisible) {
|
||
_this6.hide();
|
||
}
|
||
});
|
||
}
|
||
this.scrollHandler.bindScrollListener();
|
||
}, "bindScrollListener"),
|
||
unbindScrollListener: /* @__PURE__ */ __name(function unbindScrollListener() {
|
||
if (this.scrollHandler) {
|
||
this.scrollHandler.unbindScrollListener();
|
||
}
|
||
}, "unbindScrollListener"),
|
||
bindResizeListener: /* @__PURE__ */ __name(function bindResizeListener() {
|
||
var _this7 = this;
|
||
if (!this.resizeListener) {
|
||
this.resizeListener = function() {
|
||
if (_this7.overlayVisible && !isTouchDevice()) {
|
||
_this7.hide();
|
||
}
|
||
};
|
||
window.addEventListener("resize", this.resizeListener);
|
||
}
|
||
}, "bindResizeListener"),
|
||
unbindResizeListener: /* @__PURE__ */ __name(function unbindResizeListener() {
|
||
if (this.resizeListener) {
|
||
window.removeEventListener("resize", this.resizeListener);
|
||
this.resizeListener = null;
|
||
}
|
||
}, "unbindResizeListener"),
|
||
isOutsideClicked: /* @__PURE__ */ __name(function isOutsideClicked(event) {
|
||
return !this.overlay.contains(event.target) && !this.isInputClicked(event) && !this.isDropdownClicked(event);
|
||
}, "isOutsideClicked"),
|
||
isInputClicked: /* @__PURE__ */ __name(function isInputClicked(event) {
|
||
if (this.multiple) return event.target === this.$refs.multiContainer || this.$refs.multiContainer.contains(event.target);
|
||
else return event.target === this.$refs.focusInput.$el;
|
||
}, "isInputClicked"),
|
||
isDropdownClicked: /* @__PURE__ */ __name(function isDropdownClicked(event) {
|
||
return this.$refs.dropdownButton ? event.target === this.$refs.dropdownButton || this.$refs.dropdownButton.contains(event.target) : false;
|
||
}, "isDropdownClicked"),
|
||
isOptionMatched: /* @__PURE__ */ __name(function isOptionMatched(option2, value) {
|
||
var _this$getOptionLabel;
|
||
return this.isValidOption(option2) && ((_this$getOptionLabel = this.getOptionLabel(option2)) === null || _this$getOptionLabel === void 0 ? void 0 : _this$getOptionLabel.toLocaleLowerCase(this.searchLocale)) === value.toLocaleLowerCase(this.searchLocale);
|
||
}, "isOptionMatched"),
|
||
isValidOption: /* @__PURE__ */ __name(function isValidOption(option2) {
|
||
return isNotEmpty(option2) && !(this.isOptionDisabled(option2) || this.isOptionGroup(option2));
|
||
}, "isValidOption"),
|
||
isValidSelectedOption: /* @__PURE__ */ __name(function isValidSelectedOption(option2) {
|
||
return this.isValidOption(option2) && this.isSelected(option2);
|
||
}, "isValidSelectedOption"),
|
||
isEquals: /* @__PURE__ */ __name(function isEquals(value1, value2) {
|
||
return equals(value1, value2, this.equalityKey);
|
||
}, "isEquals"),
|
||
isSelected: /* @__PURE__ */ __name(function isSelected(option2) {
|
||
var _this8 = this;
|
||
var optionValue = this.getOptionValue(option2);
|
||
return this.multiple ? (this.modelValue || []).some(function(value) {
|
||
return _this8.isEquals(value, optionValue);
|
||
}) : this.isEquals(this.modelValue, this.getOptionValue(option2));
|
||
}, "isSelected"),
|
||
findFirstOptionIndex: /* @__PURE__ */ __name(function findFirstOptionIndex() {
|
||
var _this9 = this;
|
||
return this.visibleOptions.findIndex(function(option2) {
|
||
return _this9.isValidOption(option2);
|
||
});
|
||
}, "findFirstOptionIndex"),
|
||
findLastOptionIndex: /* @__PURE__ */ __name(function findLastOptionIndex() {
|
||
var _this10 = this;
|
||
return findLastIndex(this.visibleOptions, function(option2) {
|
||
return _this10.isValidOption(option2);
|
||
});
|
||
}, "findLastOptionIndex"),
|
||
findNextOptionIndex: /* @__PURE__ */ __name(function findNextOptionIndex(index) {
|
||
var _this11 = this;
|
||
var matchedOptionIndex = index < this.visibleOptions.length - 1 ? this.visibleOptions.slice(index + 1).findIndex(function(option2) {
|
||
return _this11.isValidOption(option2);
|
||
}) : -1;
|
||
return matchedOptionIndex > -1 ? matchedOptionIndex + index + 1 : index;
|
||
}, "findNextOptionIndex"),
|
||
findPrevOptionIndex: /* @__PURE__ */ __name(function findPrevOptionIndex(index) {
|
||
var _this12 = this;
|
||
var matchedOptionIndex = index > 0 ? findLastIndex(this.visibleOptions.slice(0, index), function(option2) {
|
||
return _this12.isValidOption(option2);
|
||
}) : -1;
|
||
return matchedOptionIndex > -1 ? matchedOptionIndex : index;
|
||
}, "findPrevOptionIndex"),
|
||
findSelectedOptionIndex: /* @__PURE__ */ __name(function findSelectedOptionIndex() {
|
||
var _this13 = this;
|
||
return this.hasSelectedOption ? this.visibleOptions.findIndex(function(option2) {
|
||
return _this13.isValidSelectedOption(option2);
|
||
}) : -1;
|
||
}, "findSelectedOptionIndex"),
|
||
findFirstFocusedOptionIndex: /* @__PURE__ */ __name(function findFirstFocusedOptionIndex() {
|
||
var selectedIndex = this.findSelectedOptionIndex();
|
||
return selectedIndex < 0 ? this.findFirstOptionIndex() : selectedIndex;
|
||
}, "findFirstFocusedOptionIndex"),
|
||
findLastFocusedOptionIndex: /* @__PURE__ */ __name(function findLastFocusedOptionIndex() {
|
||
var selectedIndex = this.findSelectedOptionIndex();
|
||
return selectedIndex < 0 ? this.findLastOptionIndex() : selectedIndex;
|
||
}, "findLastFocusedOptionIndex"),
|
||
search: /* @__PURE__ */ __name(function search(event, query, source) {
|
||
if (query === void 0 || query === null) {
|
||
return;
|
||
}
|
||
if (source === "input" && query.trim().length === 0) {
|
||
return;
|
||
}
|
||
this.searching = true;
|
||
this.$emit("complete", {
|
||
originalEvent: event,
|
||
query
|
||
});
|
||
}, "search"),
|
||
removeOption: /* @__PURE__ */ __name(function removeOption(event, index) {
|
||
var _this14 = this;
|
||
var removedOption = this.modelValue[index];
|
||
var value = this.modelValue.filter(function(_2, i) {
|
||
return i !== index;
|
||
}).map(function(option2) {
|
||
return _this14.getOptionValue(option2);
|
||
});
|
||
this.updateModel(event, value);
|
||
this.$emit("item-unselect", {
|
||
originalEvent: event,
|
||
value: removedOption
|
||
});
|
||
this.$emit("option-unselect", {
|
||
originalEvent: event,
|
||
value: removedOption
|
||
});
|
||
this.dirty = true;
|
||
focus(this.multiple ? this.$refs.focusInput : this.$refs.focusInput.$el);
|
||
}, "removeOption"),
|
||
changeFocusedOptionIndex: /* @__PURE__ */ __name(function changeFocusedOptionIndex(event, index) {
|
||
if (this.focusedOptionIndex !== index) {
|
||
this.focusedOptionIndex = index;
|
||
this.scrollInView();
|
||
if (this.selectOnFocus) {
|
||
this.onOptionSelect(event, this.visibleOptions[index], false);
|
||
}
|
||
}
|
||
}, "changeFocusedOptionIndex"),
|
||
scrollInView: /* @__PURE__ */ __name(function scrollInView2() {
|
||
var _this15 = this;
|
||
var index = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : -1;
|
||
this.$nextTick(function() {
|
||
var id2 = index !== -1 ? "".concat(_this15.id, "_").concat(index) : _this15.focusedOptionId;
|
||
var element = findSingle(_this15.list, 'li[id="'.concat(id2, '"]'));
|
||
if (element) {
|
||
element.scrollIntoView && element.scrollIntoView({
|
||
block: "nearest",
|
||
inline: "start"
|
||
});
|
||
} else if (!_this15.virtualScrollerDisabled) {
|
||
_this15.virtualScroller && _this15.virtualScroller.scrollToIndex(index !== -1 ? index : _this15.focusedOptionIndex);
|
||
}
|
||
});
|
||
}, "scrollInView"),
|
||
autoUpdateModel: /* @__PURE__ */ __name(function autoUpdateModel() {
|
||
if (this.selectOnFocus && this.autoOptionFocus && !this.hasSelectedOption) {
|
||
this.focusedOptionIndex = this.findFirstFocusedOptionIndex();
|
||
this.onOptionSelect(null, this.visibleOptions[this.focusedOptionIndex], false);
|
||
}
|
||
}, "autoUpdateModel"),
|
||
updateModel: /* @__PURE__ */ __name(function updateModel(event, value) {
|
||
this.$emit("update:modelValue", value);
|
||
this.$emit("change", {
|
||
originalEvent: event,
|
||
value
|
||
});
|
||
}, "updateModel"),
|
||
flatOptions: /* @__PURE__ */ __name(function flatOptions(options) {
|
||
var _this16 = this;
|
||
return (options || []).reduce(function(result, option2, index) {
|
||
result.push({
|
||
optionGroup: option2,
|
||
group: true,
|
||
index
|
||
});
|
||
var optionGroupChildren = _this16.getOptionGroupChildren(option2);
|
||
optionGroupChildren && optionGroupChildren.forEach(function(o) {
|
||
return result.push(o);
|
||
});
|
||
return result;
|
||
}, []);
|
||
}, "flatOptions"),
|
||
overlayRef: /* @__PURE__ */ __name(function overlayRef(el) {
|
||
this.overlay = el;
|
||
}, "overlayRef"),
|
||
listRef: /* @__PURE__ */ __name(function listRef(el, contentRef) {
|
||
this.list = el;
|
||
contentRef && contentRef(el);
|
||
}, "listRef"),
|
||
virtualScrollerRef: /* @__PURE__ */ __name(function virtualScrollerRef(el) {
|
||
this.virtualScroller = el;
|
||
}, "virtualScrollerRef")
|
||
},
|
||
computed: {
|
||
visibleOptions: /* @__PURE__ */ __name(function visibleOptions() {
|
||
return this.optionGroupLabel ? this.flatOptions(this.suggestions) : this.suggestions || [];
|
||
}, "visibleOptions"),
|
||
inputValue: /* @__PURE__ */ __name(function inputValue() {
|
||
if (isNotEmpty(this.modelValue)) {
|
||
if (_typeof$1$1(this.modelValue) === "object") {
|
||
var label = this.getOptionLabel(this.modelValue);
|
||
return label != null ? label : this.modelValue;
|
||
} else {
|
||
return this.modelValue;
|
||
}
|
||
} else {
|
||
return "";
|
||
}
|
||
}, "inputValue"),
|
||
hasSelectedOption: /* @__PURE__ */ __name(function hasSelectedOption() {
|
||
return isNotEmpty(this.modelValue);
|
||
}, "hasSelectedOption"),
|
||
equalityKey: /* @__PURE__ */ __name(function equalityKey() {
|
||
return this.dataKey;
|
||
}, "equalityKey"),
|
||
searchResultMessageText: /* @__PURE__ */ __name(function searchResultMessageText() {
|
||
return isNotEmpty(this.visibleOptions) && this.overlayVisible ? this.searchMessageText.replaceAll("{0}", this.visibleOptions.length) : this.emptySearchMessageText;
|
||
}, "searchResultMessageText"),
|
||
searchMessageText: /* @__PURE__ */ __name(function searchMessageText() {
|
||
return this.searchMessage || this.$primevue.config.locale.searchMessage || "";
|
||
}, "searchMessageText"),
|
||
emptySearchMessageText: /* @__PURE__ */ __name(function emptySearchMessageText() {
|
||
return this.emptySearchMessage || this.$primevue.config.locale.emptySearchMessage || "";
|
||
}, "emptySearchMessageText"),
|
||
selectionMessageText: /* @__PURE__ */ __name(function selectionMessageText() {
|
||
return this.selectionMessage || this.$primevue.config.locale.selectionMessage || "";
|
||
}, "selectionMessageText"),
|
||
emptySelectionMessageText: /* @__PURE__ */ __name(function emptySelectionMessageText() {
|
||
return this.emptySelectionMessage || this.$primevue.config.locale.emptySelectionMessage || "";
|
||
}, "emptySelectionMessageText"),
|
||
selectedMessageText: /* @__PURE__ */ __name(function selectedMessageText() {
|
||
return this.hasSelectedOption ? this.selectionMessageText.replaceAll("{0}", this.multiple ? this.modelValue.length : "1") : this.emptySelectionMessageText;
|
||
}, "selectedMessageText"),
|
||
listAriaLabel: /* @__PURE__ */ __name(function listAriaLabel() {
|
||
return this.$primevue.config.locale.aria ? this.$primevue.config.locale.aria.listLabel : void 0;
|
||
}, "listAriaLabel"),
|
||
focusedOptionId: /* @__PURE__ */ __name(function focusedOptionId() {
|
||
return this.focusedOptionIndex !== -1 ? "".concat(this.id, "_").concat(this.focusedOptionIndex) : null;
|
||
}, "focusedOptionId"),
|
||
focusedMultipleOptionId: /* @__PURE__ */ __name(function focusedMultipleOptionId() {
|
||
return this.focusedMultipleOptionIndex !== -1 ? "".concat(this.id, "_multiple_option_").concat(this.focusedMultipleOptionIndex) : null;
|
||
}, "focusedMultipleOptionId"),
|
||
ariaSetSize: /* @__PURE__ */ __name(function ariaSetSize() {
|
||
var _this17 = this;
|
||
return this.visibleOptions.filter(function(option2) {
|
||
return !_this17.isOptionGroup(option2);
|
||
}).length;
|
||
}, "ariaSetSize"),
|
||
virtualScrollerDisabled: /* @__PURE__ */ __name(function virtualScrollerDisabled() {
|
||
return !this.virtualScrollerOptions;
|
||
}, "virtualScrollerDisabled"),
|
||
panelId: /* @__PURE__ */ __name(function panelId() {
|
||
return this.id + "_panel";
|
||
}, "panelId"),
|
||
hasFluid: /* @__PURE__ */ __name(function hasFluid() {
|
||
return isEmpty(this.fluid) ? !!this.$pcFluid : this.fluid;
|
||
}, "hasFluid")
|
||
},
|
||
components: {
|
||
InputText: script$k,
|
||
VirtualScroller: script$l,
|
||
Portal: script$m,
|
||
ChevronDownIcon: script$n,
|
||
SpinnerIcon: script$o,
|
||
Chip: script$p
|
||
},
|
||
directives: {
|
||
ripple: Ripple
|
||
}
|
||
};
|
||
function _typeof$4(o) {
|
||
"@babel/helpers - typeof";
|
||
return _typeof$4 = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(o2) {
|
||
return typeof o2;
|
||
} : function(o2) {
|
||
return o2 && "function" == typeof Symbol && o2.constructor === Symbol && o2 !== Symbol.prototype ? "symbol" : typeof o2;
|
||
}, _typeof$4(o);
|
||
}
|
||
__name(_typeof$4, "_typeof$4");
|
||
function ownKeys$3(e, r) {
|
||
var t = Object.keys(e);
|
||
if (Object.getOwnPropertySymbols) {
|
||
var o = Object.getOwnPropertySymbols(e);
|
||
r && (o = o.filter(function(r2) {
|
||
return Object.getOwnPropertyDescriptor(e, r2).enumerable;
|
||
})), t.push.apply(t, o);
|
||
}
|
||
return t;
|
||
}
|
||
__name(ownKeys$3, "ownKeys$3");
|
||
function _objectSpread$3(e) {
|
||
for (var r = 1; r < arguments.length; r++) {
|
||
var t = null != arguments[r] ? arguments[r] : {};
|
||
r % 2 ? ownKeys$3(Object(t), true).forEach(function(r2) {
|
||
_defineProperty$4(e, r2, t[r2]);
|
||
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$3(Object(t)).forEach(function(r2) {
|
||
Object.defineProperty(e, r2, Object.getOwnPropertyDescriptor(t, r2));
|
||
});
|
||
}
|
||
return e;
|
||
}
|
||
__name(_objectSpread$3, "_objectSpread$3");
|
||
function _defineProperty$4(e, r, t) {
|
||
return (r = _toPropertyKey$4(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: true, configurable: true, writable: true }) : e[r] = t, e;
|
||
}
|
||
__name(_defineProperty$4, "_defineProperty$4");
|
||
function _toPropertyKey$4(t) {
|
||
var i = _toPrimitive$4(t, "string");
|
||
return "symbol" == _typeof$4(i) ? i : i + "";
|
||
}
|
||
__name(_toPropertyKey$4, "_toPropertyKey$4");
|
||
function _toPrimitive$4(t, r) {
|
||
if ("object" != _typeof$4(t) || !t) return t;
|
||
var e = t[Symbol.toPrimitive];
|
||
if (void 0 !== e) {
|
||
var i = e.call(t, r || "default");
|
||
if ("object" != _typeof$4(i)) return i;
|
||
throw new TypeError("@@toPrimitive must return a primitive value.");
|
||
}
|
||
return ("string" === r ? String : Number)(t);
|
||
}
|
||
__name(_toPrimitive$4, "_toPrimitive$4");
|
||
var _hoisted_1$j = ["aria-activedescendant"];
|
||
var _hoisted_2$g = ["id", "aria-label", "aria-setsize", "aria-posinset"];
|
||
var _hoisted_3$e = ["id", "placeholder", "tabindex", "disabled", "aria-label", "aria-labelledby", "aria-expanded", "aria-controls", "aria-activedescendant", "aria-invalid"];
|
||
var _hoisted_4$5 = ["disabled", "aria-expanded", "aria-controls"];
|
||
var _hoisted_5$3 = ["id"];
|
||
var _hoisted_6$2 = ["id", "aria-label"];
|
||
var _hoisted_7$1 = ["id"];
|
||
var _hoisted_8$1 = ["id", "aria-label", "aria-selected", "aria-disabled", "aria-setsize", "aria-posinset", "onClick", "onMousemove", "data-p-selected", "data-p-focus", "data-p-disabled"];
|
||
function render$e(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _component_InputText = resolveComponent("InputText");
|
||
var _component_Chip = resolveComponent("Chip");
|
||
var _component_SpinnerIcon = resolveComponent("SpinnerIcon");
|
||
var _component_VirtualScroller = resolveComponent("VirtualScroller");
|
||
var _component_Portal = resolveComponent("Portal");
|
||
var _directive_ripple = resolveDirective("ripple");
|
||
return openBlock(), createElementBlock("div", mergeProps({
|
||
ref: "container",
|
||
"class": _ctx.cx("root"),
|
||
style: _ctx.sx("root"),
|
||
onClick: _cache[11] || (_cache[11] = function() {
|
||
return $options.onContainerClick && $options.onContainerClick.apply($options, arguments);
|
||
})
|
||
}, _ctx.ptmi("root")), [!_ctx.multiple ? (openBlock(), createBlock(_component_InputText, {
|
||
key: 0,
|
||
ref: "focusInput",
|
||
id: _ctx.inputId,
|
||
type: "text",
|
||
"class": normalizeClass([_ctx.cx("pcInput"), _ctx.inputClass]),
|
||
style: normalizeStyle(_ctx.inputStyle),
|
||
value: $options.inputValue,
|
||
placeholder: _ctx.placeholder,
|
||
tabindex: !_ctx.disabled ? _ctx.tabindex : -1,
|
||
fluid: $options.hasFluid,
|
||
disabled: _ctx.disabled,
|
||
invalid: _ctx.invalid,
|
||
variant: _ctx.variant,
|
||
autocomplete: "off",
|
||
role: "combobox",
|
||
"aria-label": _ctx.ariaLabel,
|
||
"aria-labelledby": _ctx.ariaLabelledby,
|
||
"aria-haspopup": "listbox",
|
||
"aria-autocomplete": "list",
|
||
"aria-expanded": $data.overlayVisible,
|
||
"aria-controls": $options.panelId,
|
||
"aria-activedescendant": $data.focused ? $options.focusedOptionId : void 0,
|
||
onFocus: $options.onFocus,
|
||
onBlur: $options.onBlur,
|
||
onKeydown: $options.onKeyDown,
|
||
onInput: $options.onInput,
|
||
onChange: $options.onChange,
|
||
unstyled: _ctx.unstyled,
|
||
pt: _ctx.ptm("pcInput")
|
||
}, null, 8, ["id", "class", "style", "value", "placeholder", "tabindex", "fluid", "disabled", "invalid", "variant", "aria-label", "aria-labelledby", "aria-expanded", "aria-controls", "aria-activedescendant", "onFocus", "onBlur", "onKeydown", "onInput", "onChange", "unstyled", "pt"])) : createCommentVNode("", true), _ctx.multiple ? (openBlock(), createElementBlock("ul", mergeProps({
|
||
key: 1,
|
||
ref: "multiContainer",
|
||
"class": _ctx.cx("inputMultiple"),
|
||
tabindex: "-1",
|
||
role: "listbox",
|
||
"aria-orientation": "horizontal",
|
||
"aria-activedescendant": $data.focused ? $options.focusedMultipleOptionId : void 0,
|
||
onFocus: _cache[5] || (_cache[5] = function() {
|
||
return $options.onMultipleContainerFocus && $options.onMultipleContainerFocus.apply($options, arguments);
|
||
}),
|
||
onBlur: _cache[6] || (_cache[6] = function() {
|
||
return $options.onMultipleContainerBlur && $options.onMultipleContainerBlur.apply($options, arguments);
|
||
}),
|
||
onKeydown: _cache[7] || (_cache[7] = function() {
|
||
return $options.onMultipleContainerKeyDown && $options.onMultipleContainerKeyDown.apply($options, arguments);
|
||
})
|
||
}, _ctx.ptm("inputMultiple")), [(openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.modelValue, function(option2, i) {
|
||
return openBlock(), createElementBlock("li", mergeProps({
|
||
key: "".concat(i, "_").concat($options.getOptionLabel(option2)),
|
||
id: $data.id + "_multiple_option_" + i,
|
||
"class": _ctx.cx("chipItem", {
|
||
i
|
||
}),
|
||
role: "option",
|
||
"aria-label": $options.getOptionLabel(option2),
|
||
"aria-selected": true,
|
||
"aria-setsize": _ctx.modelValue.length,
|
||
"aria-posinset": i + 1,
|
||
ref_for: true
|
||
}, _ctx.ptm("chipItem")), [renderSlot(_ctx.$slots, "chip", mergeProps({
|
||
"class": _ctx.cx("pcChip"),
|
||
value: option2,
|
||
index: i,
|
||
removeCallback: /* @__PURE__ */ __name(function removeCallback(event) {
|
||
return $options.removeOption(event, i);
|
||
}, "removeCallback"),
|
||
ref_for: true
|
||
}, _ctx.ptm("pcChip")), function() {
|
||
return [createVNode(_component_Chip, {
|
||
"class": normalizeClass(_ctx.cx("pcChip")),
|
||
label: $options.getOptionLabel(option2),
|
||
removeIcon: _ctx.chipIcon || _ctx.removeTokenIcon,
|
||
removable: "",
|
||
unstyled: _ctx.unstyled,
|
||
onRemove: /* @__PURE__ */ __name(function onRemove2($event) {
|
||
return $options.removeOption($event, i);
|
||
}, "onRemove"),
|
||
pt: _ctx.ptm("pcChip")
|
||
}, {
|
||
removeicon: withCtx(function() {
|
||
return [renderSlot(_ctx.$slots, _ctx.$slots.chipicon ? "chipicon" : "removetokenicon", {
|
||
"class": normalizeClass(_ctx.cx("chipIcon")),
|
||
index: i,
|
||
removeCallback: /* @__PURE__ */ __name(function removeCallback(event) {
|
||
return $options.removeOption(event, i);
|
||
}, "removeCallback")
|
||
})];
|
||
}),
|
||
_: 2
|
||
}, 1032, ["class", "label", "removeIcon", "unstyled", "onRemove", "pt"])];
|
||
})], 16, _hoisted_2$g);
|
||
}), 128)), createBaseVNode("li", mergeProps({
|
||
"class": _ctx.cx("inputChip"),
|
||
role: "option"
|
||
}, _ctx.ptm("inputChip")), [createBaseVNode("input", mergeProps({
|
||
ref: "focusInput",
|
||
id: _ctx.inputId,
|
||
type: "text",
|
||
style: _ctx.inputStyle,
|
||
"class": _ctx.inputClass,
|
||
placeholder: _ctx.placeholder,
|
||
tabindex: !_ctx.disabled ? _ctx.tabindex : -1,
|
||
disabled: _ctx.disabled,
|
||
autocomplete: "off",
|
||
role: "combobox",
|
||
"aria-label": _ctx.ariaLabel,
|
||
"aria-labelledby": _ctx.ariaLabelledby,
|
||
"aria-haspopup": "listbox",
|
||
"aria-autocomplete": "list",
|
||
"aria-expanded": $data.overlayVisible,
|
||
"aria-controls": $data.id + "_list",
|
||
"aria-activedescendant": $data.focused ? $options.focusedOptionId : void 0,
|
||
"aria-invalid": _ctx.invalid || void 0,
|
||
onFocus: _cache[0] || (_cache[0] = function() {
|
||
return $options.onFocus && $options.onFocus.apply($options, arguments);
|
||
}),
|
||
onBlur: _cache[1] || (_cache[1] = function() {
|
||
return $options.onBlur && $options.onBlur.apply($options, arguments);
|
||
}),
|
||
onKeydown: _cache[2] || (_cache[2] = function() {
|
||
return $options.onKeyDown && $options.onKeyDown.apply($options, arguments);
|
||
}),
|
||
onInput: _cache[3] || (_cache[3] = function() {
|
||
return $options.onInput && $options.onInput.apply($options, arguments);
|
||
}),
|
||
onChange: _cache[4] || (_cache[4] = function() {
|
||
return $options.onChange && $options.onChange.apply($options, arguments);
|
||
})
|
||
}, _ctx.ptm("input")), null, 16, _hoisted_3$e)], 16)], 16, _hoisted_1$j)) : createCommentVNode("", true), $data.searching || _ctx.loading ? renderSlot(_ctx.$slots, _ctx.$slots.loader ? "loader" : "loadingicon", {
|
||
key: 2,
|
||
"class": normalizeClass(_ctx.cx("loader"))
|
||
}, function() {
|
||
return [_ctx.loader || _ctx.loadingIcon ? (openBlock(), createElementBlock("i", mergeProps({
|
||
key: 0,
|
||
"class": ["pi-spin", _ctx.cx("loader"), _ctx.loader, _ctx.loadingIcon],
|
||
"aria-hidden": "true"
|
||
}, _ctx.ptm("loader")), null, 16)) : (openBlock(), createBlock(_component_SpinnerIcon, mergeProps({
|
||
key: 1,
|
||
"class": _ctx.cx("loader"),
|
||
spin: "",
|
||
"aria-hidden": "true"
|
||
}, _ctx.ptm("loader")), null, 16, ["class"]))];
|
||
}) : createCommentVNode("", true), renderSlot(_ctx.$slots, _ctx.$slots.dropdown ? "dropdown" : "dropdownbutton", {
|
||
toggleCallback: /* @__PURE__ */ __name(function toggleCallback(event) {
|
||
return $options.onDropdownClick(event);
|
||
}, "toggleCallback")
|
||
}, function() {
|
||
return [_ctx.dropdown ? (openBlock(), createElementBlock("button", mergeProps({
|
||
key: 0,
|
||
ref: "dropdownButton",
|
||
type: "button",
|
||
"class": [_ctx.cx("dropdown"), _ctx.dropdownClass],
|
||
disabled: _ctx.disabled,
|
||
"aria-haspopup": "listbox",
|
||
"aria-expanded": $data.overlayVisible,
|
||
"aria-controls": $options.panelId,
|
||
onClick: _cache[8] || (_cache[8] = function() {
|
||
return $options.onDropdownClick && $options.onDropdownClick.apply($options, arguments);
|
||
})
|
||
}, _ctx.ptm("dropdown")), [renderSlot(_ctx.$slots, "dropdownicon", {
|
||
"class": normalizeClass(_ctx.dropdownIcon)
|
||
}, function() {
|
||
return [(openBlock(), createBlock(resolveDynamicComponent(_ctx.dropdownIcon ? "span" : "ChevronDownIcon"), mergeProps({
|
||
"class": _ctx.dropdownIcon
|
||
}, _ctx.ptm("dropdownIcon")), null, 16, ["class"]))];
|
||
})], 16, _hoisted_4$5)) : createCommentVNode("", true)];
|
||
}), createBaseVNode("span", mergeProps({
|
||
role: "status",
|
||
"aria-live": "polite",
|
||
"class": "p-hidden-accessible"
|
||
}, _ctx.ptm("hiddenSearchResult"), {
|
||
"data-p-hidden-accessible": true
|
||
}), toDisplayString($options.searchResultMessageText), 17), createVNode(_component_Portal, {
|
||
appendTo: _ctx.appendTo
|
||
}, {
|
||
"default": withCtx(function() {
|
||
return [createVNode(Transition, mergeProps({
|
||
name: "p-connected-overlay",
|
||
onEnter: $options.onOverlayEnter,
|
||
onAfterEnter: $options.onOverlayAfterEnter,
|
||
onLeave: $options.onOverlayLeave,
|
||
onAfterLeave: $options.onOverlayAfterLeave
|
||
}, _ctx.ptm("transition")), {
|
||
"default": withCtx(function() {
|
||
return [$data.overlayVisible ? (openBlock(), createElementBlock("div", mergeProps({
|
||
key: 0,
|
||
ref: $options.overlayRef,
|
||
id: $options.panelId,
|
||
"class": [_ctx.cx("overlay"), _ctx.panelClass, _ctx.overlayClass],
|
||
style: _objectSpread$3(_objectSpread$3(_objectSpread$3({}, _ctx.panelStyle), _ctx.overlayStyle), {}, {
|
||
"max-height": $options.virtualScrollerDisabled ? _ctx.scrollHeight : ""
|
||
}),
|
||
onClick: _cache[9] || (_cache[9] = function() {
|
||
return $options.onOverlayClick && $options.onOverlayClick.apply($options, arguments);
|
||
}),
|
||
onKeydown: _cache[10] || (_cache[10] = function() {
|
||
return $options.onOverlayKeyDown && $options.onOverlayKeyDown.apply($options, arguments);
|
||
})
|
||
}, _ctx.ptm("overlay")), [renderSlot(_ctx.$slots, "header", {
|
||
value: _ctx.modelValue,
|
||
suggestions: $options.visibleOptions
|
||
}), createVNode(_component_VirtualScroller, mergeProps({
|
||
ref: $options.virtualScrollerRef
|
||
}, _ctx.virtualScrollerOptions, {
|
||
style: {
|
||
height: _ctx.scrollHeight
|
||
},
|
||
items: $options.visibleOptions,
|
||
tabindex: -1,
|
||
disabled: $options.virtualScrollerDisabled,
|
||
pt: _ctx.ptm("virtualScroller")
|
||
}), createSlots({
|
||
content: withCtx(function(_ref) {
|
||
var styleClass = _ref.styleClass, contentRef = _ref.contentRef, items = _ref.items, getItemOptions = _ref.getItemOptions, contentStyle = _ref.contentStyle, itemSize = _ref.itemSize;
|
||
return [createBaseVNode("ul", mergeProps({
|
||
ref: /* @__PURE__ */ __name(function ref2(el) {
|
||
return $options.listRef(el, contentRef);
|
||
}, "ref"),
|
||
id: $data.id + "_list",
|
||
"class": [_ctx.cx("list"), styleClass],
|
||
style: contentStyle,
|
||
role: "listbox",
|
||
"aria-label": $options.listAriaLabel
|
||
}, _ctx.ptm("list")), [(openBlock(true), createElementBlock(Fragment, null, renderList(items, function(option2, i) {
|
||
return openBlock(), createElementBlock(Fragment, {
|
||
key: $options.getOptionRenderKey(option2, $options.getOptionIndex(i, getItemOptions))
|
||
}, [$options.isOptionGroup(option2) ? (openBlock(), createElementBlock("li", mergeProps({
|
||
key: 0,
|
||
id: $data.id + "_" + $options.getOptionIndex(i, getItemOptions),
|
||
style: {
|
||
height: itemSize ? itemSize + "px" : void 0
|
||
},
|
||
"class": _ctx.cx("optionGroup"),
|
||
role: "option",
|
||
ref_for: true
|
||
}, _ctx.ptm("optionGroup")), [renderSlot(_ctx.$slots, "optiongroup", {
|
||
option: option2.optionGroup,
|
||
index: $options.getOptionIndex(i, getItemOptions)
|
||
}, function() {
|
||
return [createTextVNode(toDisplayString($options.getOptionGroupLabel(option2.optionGroup)), 1)];
|
||
})], 16, _hoisted_7$1)) : withDirectives((openBlock(), createElementBlock("li", mergeProps({
|
||
key: 1,
|
||
id: $data.id + "_" + $options.getOptionIndex(i, getItemOptions),
|
||
style: {
|
||
height: itemSize ? itemSize + "px" : void 0
|
||
},
|
||
"class": _ctx.cx("option", {
|
||
option: option2,
|
||
i,
|
||
getItemOptions
|
||
}),
|
||
role: "option",
|
||
"aria-label": $options.getOptionLabel(option2),
|
||
"aria-selected": $options.isSelected(option2),
|
||
"aria-disabled": $options.isOptionDisabled(option2),
|
||
"aria-setsize": $options.ariaSetSize,
|
||
"aria-posinset": $options.getAriaPosInset($options.getOptionIndex(i, getItemOptions)),
|
||
onClick: /* @__PURE__ */ __name(function onClick2($event) {
|
||
return $options.onOptionSelect($event, option2);
|
||
}, "onClick"),
|
||
onMousemove: /* @__PURE__ */ __name(function onMousemove($event) {
|
||
return $options.onOptionMouseMove($event, $options.getOptionIndex(i, getItemOptions));
|
||
}, "onMousemove"),
|
||
"data-p-selected": $options.isSelected(option2),
|
||
"data-p-focus": $data.focusedOptionIndex === $options.getOptionIndex(i, getItemOptions),
|
||
"data-p-disabled": $options.isOptionDisabled(option2),
|
||
ref_for: true
|
||
}, $options.getPTOptions(option2, getItemOptions, i, "option")), [renderSlot(_ctx.$slots, "option", {
|
||
option: option2,
|
||
index: $options.getOptionIndex(i, getItemOptions)
|
||
}, function() {
|
||
return [createTextVNode(toDisplayString($options.getOptionLabel(option2)), 1)];
|
||
})], 16, _hoisted_8$1)), [[_directive_ripple]])], 64);
|
||
}), 128)), !items || items && items.length === 0 ? (openBlock(), createElementBlock("li", mergeProps({
|
||
key: 0,
|
||
"class": _ctx.cx("emptyMessage"),
|
||
role: "option"
|
||
}, _ctx.ptm("emptyMessage")), [renderSlot(_ctx.$slots, "empty", {}, function() {
|
||
return [createTextVNode(toDisplayString($options.searchResultMessageText), 1)];
|
||
})], 16)) : createCommentVNode("", true)], 16, _hoisted_6$2)];
|
||
}),
|
||
_: 2
|
||
}, [_ctx.$slots.loader ? {
|
||
name: "loader",
|
||
fn: withCtx(function(_ref2) {
|
||
var options = _ref2.options;
|
||
return [renderSlot(_ctx.$slots, "loader", {
|
||
options
|
||
})];
|
||
}),
|
||
key: "0"
|
||
} : void 0]), 1040, ["style", "items", "disabled", "pt"]), renderSlot(_ctx.$slots, "footer", {
|
||
value: _ctx.modelValue,
|
||
suggestions: $options.visibleOptions
|
||
}), createBaseVNode("span", mergeProps({
|
||
role: "status",
|
||
"aria-live": "polite",
|
||
"class": "p-hidden-accessible"
|
||
}, _ctx.ptm("hiddenSelectedMessage"), {
|
||
"data-p-hidden-accessible": true
|
||
}), toDisplayString($options.selectedMessageText), 17)], 16, _hoisted_5$3)) : createCommentVNode("", true)];
|
||
}),
|
||
_: 3
|
||
}, 16, ["onEnter", "onAfterEnter", "onLeave", "onAfterLeave"])];
|
||
}),
|
||
_: 3
|
||
}, 8, ["appendTo"])], 16);
|
||
}
|
||
__name(render$e, "render$e");
|
||
script$8.render = render$e;
|
||
const _sfc_main$j = {
|
||
name: "AutoCompletePlus",
|
||
extends: script$8,
|
||
emits: ["focused-option-changed"],
|
||
mounted() {
|
||
if (typeof script$8.mounted === "function") {
|
||
script$8.mounted.call(this);
|
||
}
|
||
this.$watch(
|
||
() => this.focusedOptionIndex,
|
||
(newVal, oldVal) => {
|
||
this.$emit("focused-option-changed", newVal);
|
||
}
|
||
);
|
||
}
|
||
};
|
||
const _withScopeId$4 = /* @__PURE__ */ __name((n) => (pushScopeId("data-v-d7cc0bce"), n = n(), popScopeId(), n), "_withScopeId$4");
|
||
const _hoisted_1$i = { class: "option-container flex justify-between items-center px-2 py-0 cursor-pointer overflow-hidden w-full" };
|
||
const _hoisted_2$f = { class: "option-display-name font-semibold flex flex-col" };
|
||
const _hoisted_3$d = { key: 0 };
|
||
const _hoisted_4$4 = /* @__PURE__ */ _withScopeId$4(() => /* @__PURE__ */ createBaseVNode("i", { class: "pi pi-bookmark-fill text-sm mr-1" }, null, -1));
|
||
const _hoisted_5$2 = [
|
||
_hoisted_4$4
|
||
];
|
||
const _hoisted_6$1 = ["innerHTML"];
|
||
const _hoisted_7 = /* @__PURE__ */ _withScopeId$4(() => /* @__PURE__ */ createBaseVNode("span", null, " ", -1));
|
||
const _hoisted_8 = ["innerHTML"];
|
||
const _hoisted_9 = {
|
||
key: 0,
|
||
class: "option-category font-light text-sm text-gray-400 overflow-hidden text-ellipsis whitespace-nowrap"
|
||
};
|
||
const _hoisted_10 = { class: "option-badges" };
|
||
const _sfc_main$i = /* @__PURE__ */ defineComponent({
|
||
__name: "NodeSearchItem",
|
||
props: {
|
||
nodeDef: {},
|
||
currentQuery: {}
|
||
},
|
||
setup(__props) {
|
||
const settingStore = useSettingStore();
|
||
const showCategory = computed(
|
||
() => settingStore.get("Comfy.NodeSearchBoxImpl.ShowCategory")
|
||
);
|
||
const showIdName = computed(
|
||
() => settingStore.get("Comfy.NodeSearchBoxImpl.ShowIdName")
|
||
);
|
||
const showNodeFrequency = computed(
|
||
() => settingStore.get("Comfy.NodeSearchBoxImpl.ShowNodeFrequency")
|
||
);
|
||
const nodeFrequencyStore = useNodeFrequencyStore();
|
||
const nodeFrequency = computed(
|
||
() => nodeFrequencyStore.getNodeFrequency(props.nodeDef)
|
||
);
|
||
const nodeBookmarkStore = useNodeBookmarkStore();
|
||
const isBookmarked = computed(
|
||
() => nodeBookmarkStore.isBookmarked(props.nodeDef)
|
||
);
|
||
const props = __props;
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock("div", _hoisted_1$i, [
|
||
createBaseVNode("div", _hoisted_2$f, [
|
||
createBaseVNode("div", null, [
|
||
isBookmarked.value ? (openBlock(), createElementBlock("span", _hoisted_3$d, _hoisted_5$2)) : createCommentVNode("", true),
|
||
createBaseVNode("span", {
|
||
innerHTML: unref(highlightQuery)(_ctx.nodeDef.display_name, _ctx.currentQuery)
|
||
}, null, 8, _hoisted_6$1),
|
||
_hoisted_7,
|
||
showIdName.value ? (openBlock(), createBlock(unref(script$q), {
|
||
key: 1,
|
||
severity: "secondary"
|
||
}, {
|
||
default: withCtx(() => [
|
||
createBaseVNode("span", {
|
||
innerHTML: unref(highlightQuery)(_ctx.nodeDef.name, _ctx.currentQuery)
|
||
}, null, 8, _hoisted_8)
|
||
]),
|
||
_: 1
|
||
})) : createCommentVNode("", true)
|
||
]),
|
||
showCategory.value ? (openBlock(), createElementBlock("div", _hoisted_9, toDisplayString(_ctx.nodeDef.category.replaceAll("/", " > ")), 1)) : createCommentVNode("", true)
|
||
]),
|
||
createBaseVNode("div", _hoisted_10, [
|
||
_ctx.nodeDef.experimental ? (openBlock(), createBlock(unref(script$q), {
|
||
key: 0,
|
||
value: _ctx.$t("g.experimental"),
|
||
severity: "primary"
|
||
}, null, 8, ["value"])) : createCommentVNode("", true),
|
||
_ctx.nodeDef.deprecated ? (openBlock(), createBlock(unref(script$q), {
|
||
key: 1,
|
||
value: _ctx.$t("g.deprecated"),
|
||
severity: "danger"
|
||
}, null, 8, ["value"])) : createCommentVNode("", true),
|
||
showNodeFrequency.value && nodeFrequency.value > 0 ? (openBlock(), createBlock(unref(script$q), {
|
||
key: 2,
|
||
value: unref(formatNumberWithSuffix)(nodeFrequency.value, { roundToInt: true }),
|
||
severity: "secondary"
|
||
}, null, 8, ["value"])) : createCommentVNode("", true),
|
||
_ctx.nodeDef.nodeSource.type !== unref(NodeSourceType).Unknown ? (openBlock(), createBlock(unref(script$p), {
|
||
key: 3,
|
||
class: "text-sm font-light"
|
||
}, {
|
||
default: withCtx(() => [
|
||
createTextVNode(toDisplayString(_ctx.nodeDef.nodeSource.displayText), 1)
|
||
]),
|
||
_: 1
|
||
})) : createCommentVNode("", true)
|
||
])
|
||
]);
|
||
};
|
||
}
|
||
});
|
||
const NodeSearchItem = /* @__PURE__ */ _export_sfc(_sfc_main$i, [["__scopeId", "data-v-d7cc0bce"]]);
|
||
const _hoisted_1$h = { class: "comfy-vue-node-search-container flex justify-center items-center w-full min-w-96 pointer-events-auto" };
|
||
const _hoisted_2$e = {
|
||
key: 0,
|
||
class: "comfy-vue-node-preview-container absolute left-[-350px] top-[50px]"
|
||
};
|
||
const _hoisted_3$c = /* @__PURE__ */ createBaseVNode("h3", null, "Add node filter condition", -1);
|
||
const _hoisted_4$3 = { class: "_dialog-body" };
|
||
const _sfc_main$h = /* @__PURE__ */ defineComponent({
|
||
__name: "NodeSearchBox",
|
||
props: {
|
||
filters: {},
|
||
searchLimit: { default: 64 }
|
||
},
|
||
emits: ["addFilter", "removeFilter", "addNode"],
|
||
setup(__props, { emit: __emit }) {
|
||
const settingStore = useSettingStore();
|
||
const { t } = useI18n();
|
||
const enableNodePreview = computed(
|
||
() => settingStore.get("Comfy.NodeSearchBoxImpl.NodePreview")
|
||
);
|
||
const props = __props;
|
||
const nodeSearchFilterVisible = ref(false);
|
||
const inputId = `comfy-vue-node-search-box-input-${Math.random()}`;
|
||
const suggestions2 = ref([]);
|
||
const hoveredSuggestion = ref(null);
|
||
const currentQuery = ref("");
|
||
const placeholder = computed(() => {
|
||
return props.filters.length === 0 ? t("g.searchNodes") + "..." : "";
|
||
});
|
||
const nodeDefStore = useNodeDefStore();
|
||
const nodeFrequencyStore = useNodeFrequencyStore();
|
||
const search2 = /* @__PURE__ */ __name((query) => {
|
||
const queryIsEmpty = query === "" && props.filters.length === 0;
|
||
currentQuery.value = query;
|
||
suggestions2.value = queryIsEmpty ? nodeFrequencyStore.topNodeDefs : [
|
||
...nodeDefStore.nodeSearchService.searchNode(query, props.filters, {
|
||
limit: props.searchLimit
|
||
})
|
||
];
|
||
}, "search");
|
||
const emit = __emit;
|
||
const reFocusInput = /* @__PURE__ */ __name(() => {
|
||
const inputElement = document.getElementById(inputId);
|
||
if (inputElement) {
|
||
inputElement.blur();
|
||
inputElement.focus();
|
||
}
|
||
}, "reFocusInput");
|
||
onMounted(reFocusInput);
|
||
const onAddFilter = /* @__PURE__ */ __name((filterAndValue) => {
|
||
nodeSearchFilterVisible.value = false;
|
||
emit("addFilter", filterAndValue);
|
||
reFocusInput();
|
||
}, "onAddFilter");
|
||
const onRemoveFilter = /* @__PURE__ */ __name((event, filterAndValue) => {
|
||
event.stopPropagation();
|
||
event.preventDefault();
|
||
emit("removeFilter", filterAndValue);
|
||
reFocusInput();
|
||
}, "onRemoveFilter");
|
||
const setHoverSuggestion = /* @__PURE__ */ __name((index) => {
|
||
if (index === -1) {
|
||
hoveredSuggestion.value = null;
|
||
return;
|
||
}
|
||
const value = suggestions2.value[index];
|
||
hoveredSuggestion.value = value;
|
||
}, "setHoverSuggestion");
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock("div", _hoisted_1$h, [
|
||
enableNodePreview.value ? (openBlock(), createElementBlock("div", _hoisted_2$e, [
|
||
hoveredSuggestion.value ? (openBlock(), createBlock(NodePreview, {
|
||
nodeDef: hoveredSuggestion.value,
|
||
key: hoveredSuggestion.value?.name || ""
|
||
}, null, 8, ["nodeDef"])) : createCommentVNode("", true)
|
||
])) : createCommentVNode("", true),
|
||
createVNode(unref(script$f), {
|
||
icon: "pi pi-filter",
|
||
severity: "secondary",
|
||
class: "filter-button z-10",
|
||
onClick: _cache[0] || (_cache[0] = ($event) => nodeSearchFilterVisible.value = true)
|
||
}),
|
||
createVNode(unref(script$r), {
|
||
visible: nodeSearchFilterVisible.value,
|
||
"onUpdate:visible": _cache[1] || (_cache[1] = ($event) => nodeSearchFilterVisible.value = $event),
|
||
class: "min-w-96"
|
||
}, {
|
||
header: withCtx(() => [
|
||
_hoisted_3$c
|
||
]),
|
||
default: withCtx(() => [
|
||
createBaseVNode("div", _hoisted_4$3, [
|
||
createVNode(NodeSearchFilter, { onAddFilter })
|
||
])
|
||
]),
|
||
_: 1
|
||
}, 8, ["visible"]),
|
||
createVNode(_sfc_main$j, {
|
||
"model-value": props.filters,
|
||
class: "comfy-vue-node-search-box z-10 flex-grow",
|
||
scrollHeight: "40vh",
|
||
placeholder: placeholder.value,
|
||
"input-id": inputId,
|
||
"append-to": "self",
|
||
suggestions: suggestions2.value,
|
||
"min-length": 0,
|
||
delay: 100,
|
||
loading: !unref(nodeFrequencyStore).isLoaded,
|
||
onComplete: _cache[2] || (_cache[2] = ($event) => search2($event.query)),
|
||
onOptionSelect: _cache[3] || (_cache[3] = ($event) => emit("addNode", $event.value)),
|
||
onFocusedOptionChanged: _cache[4] || (_cache[4] = ($event) => setHoverSuggestion($event)),
|
||
"complete-on-focus": "",
|
||
"auto-option-focus": "",
|
||
"force-selection": "",
|
||
multiple: "",
|
||
optionLabel: "display_name"
|
||
}, {
|
||
option: withCtx(({ option: option2 }) => [
|
||
createVNode(NodeSearchItem, {
|
||
nodeDef: option2,
|
||
currentQuery: currentQuery.value
|
||
}, null, 8, ["nodeDef", "currentQuery"])
|
||
]),
|
||
chip: withCtx(({ value }) => [
|
||
createVNode(SearchFilterChip, {
|
||
onRemove: /* @__PURE__ */ __name(($event) => onRemoveFilter($event, value), "onRemove"),
|
||
text: value[1],
|
||
badge: value[0].invokeSequence.toUpperCase(),
|
||
"badge-class": value[0].invokeSequence + "-badge"
|
||
}, null, 8, ["onRemove", "text", "badge", "badge-class"])
|
||
]),
|
||
_: 1
|
||
}, 8, ["model-value", "placeholder", "suggestions", "loading"])
|
||
]);
|
||
};
|
||
}
|
||
});
|
||
class ConnectingLinkImpl {
|
||
static {
|
||
__name(this, "ConnectingLinkImpl");
|
||
}
|
||
constructor(node, slot, input, output, pos, afterRerouteId) {
|
||
this.node = node;
|
||
this.slot = slot;
|
||
this.input = input;
|
||
this.output = output;
|
||
this.pos = pos;
|
||
this.afterRerouteId = afterRerouteId;
|
||
}
|
||
static createFromPlainObject(obj) {
|
||
return new ConnectingLinkImpl(
|
||
obj.node,
|
||
obj.slot,
|
||
obj.input,
|
||
obj.output,
|
||
obj.pos,
|
||
obj.afterRerouteId
|
||
);
|
||
}
|
||
get type() {
|
||
const result = this.input ? this.input.type : this.output?.type ?? null;
|
||
return result === -1 ? null : result;
|
||
}
|
||
/**
|
||
* Which slot type is release and need to be reconnected.
|
||
* - 'output' means we need a new node's outputs slot to connect with this link
|
||
*/
|
||
get releaseSlotType() {
|
||
return this.output ? "input" : "output";
|
||
}
|
||
connectTo(newNode) {
|
||
const newNodeSlots = this.releaseSlotType === "output" ? newNode.outputs : newNode.inputs;
|
||
if (!newNodeSlots) return;
|
||
const newNodeSlot = newNodeSlots.findIndex(
|
||
(slot) => LiteGraph.isValidConnection(slot.type, this.type)
|
||
);
|
||
if (newNodeSlot === -1) {
|
||
console.warn(
|
||
`Could not find slot with type ${this.type} on node ${newNode.title}. This should never happen`
|
||
);
|
||
return;
|
||
}
|
||
if (this.releaseSlotType === "input") {
|
||
this.node.connect(this.slot, newNode, newNodeSlot, this.afterRerouteId);
|
||
} else {
|
||
newNode.connect(newNodeSlot, this.node, this.slot, this.afterRerouteId);
|
||
}
|
||
}
|
||
}
|
||
const useSearchBoxStore = defineStore("searchBox", () => {
|
||
const visible = ref(false);
|
||
function toggleVisible() {
|
||
visible.value = !visible.value;
|
||
}
|
||
__name(toggleVisible, "toggleVisible");
|
||
return {
|
||
visible,
|
||
toggleVisible
|
||
};
|
||
});
|
||
const _sfc_main$g = /* @__PURE__ */ defineComponent({
|
||
__name: "NodeSearchBoxPopover",
|
||
setup(__props) {
|
||
const settingStore = useSettingStore();
|
||
const { visible } = storeToRefs(useSearchBoxStore());
|
||
const dismissable = ref(true);
|
||
const triggerEvent = ref(null);
|
||
const getNewNodeLocation = /* @__PURE__ */ __name(() => {
|
||
if (!triggerEvent.value) {
|
||
return app.getCanvasCenter();
|
||
}
|
||
const originalEvent = triggerEvent.value.detail.originalEvent;
|
||
return [originalEvent.canvasX, originalEvent.canvasY];
|
||
}, "getNewNodeLocation");
|
||
const nodeFilters = ref([]);
|
||
const addFilter = /* @__PURE__ */ __name((filter) => {
|
||
nodeFilters.value.push(filter);
|
||
}, "addFilter");
|
||
const removeFilter = /* @__PURE__ */ __name((filter) => {
|
||
nodeFilters.value = nodeFilters.value.filter(
|
||
(f) => toRaw(f) !== toRaw(filter)
|
||
);
|
||
}, "removeFilter");
|
||
const clearFilters = /* @__PURE__ */ __name(() => {
|
||
nodeFilters.value = [];
|
||
}, "clearFilters");
|
||
const closeDialog = /* @__PURE__ */ __name(() => {
|
||
visible.value = false;
|
||
}, "closeDialog");
|
||
const addNode = /* @__PURE__ */ __name((nodeDef) => {
|
||
const node = app.addNodeOnGraph(nodeDef, { pos: getNewNodeLocation() });
|
||
const eventDetail = triggerEvent.value?.detail;
|
||
if (eventDetail && eventDetail.subType === "empty-release") {
|
||
eventDetail.linkReleaseContext.links.forEach((link) => {
|
||
ConnectingLinkImpl.createFromPlainObject(link).connectTo(node);
|
||
});
|
||
}
|
||
window.setTimeout(() => {
|
||
closeDialog();
|
||
}, 100);
|
||
}, "addNode");
|
||
const newSearchBoxEnabled = computed(
|
||
() => settingStore.get("Comfy.NodeSearchBoxImpl") === "default"
|
||
);
|
||
const showSearchBox = /* @__PURE__ */ __name((e) => {
|
||
const detail = e.detail;
|
||
if (newSearchBoxEnabled.value) {
|
||
if (detail.originalEvent?.pointerType === "touch") {
|
||
setTimeout(() => {
|
||
showNewSearchBox(e);
|
||
}, 128);
|
||
} else {
|
||
showNewSearchBox(e);
|
||
}
|
||
} else {
|
||
canvasStore.canvas.showSearchBox(detail.originalEvent);
|
||
}
|
||
}, "showSearchBox");
|
||
const nodeDefStore = useNodeDefStore();
|
||
const showNewSearchBox = /* @__PURE__ */ __name((e) => {
|
||
if (e.detail.subType === "empty-release") {
|
||
const links = e.detail.linkReleaseContext.links;
|
||
if (links.length === 0) {
|
||
console.warn("Empty release with no links! This should never happen");
|
||
return;
|
||
}
|
||
const firstLink = ConnectingLinkImpl.createFromPlainObject(links[0]);
|
||
const filter = nodeDefStore.nodeSearchService.getFilterById(
|
||
firstLink.releaseSlotType
|
||
);
|
||
const dataType = firstLink.type.toString();
|
||
addFilter([filter, dataType]);
|
||
}
|
||
visible.value = true;
|
||
triggerEvent.value = e;
|
||
dismissable.value = false;
|
||
setTimeout(() => {
|
||
dismissable.value = true;
|
||
}, 300);
|
||
}, "showNewSearchBox");
|
||
const showContextMenu = /* @__PURE__ */ __name((e) => {
|
||
if (e.detail.subType !== "empty-release") {
|
||
return;
|
||
}
|
||
const links = e.detail.linkReleaseContext.links;
|
||
if (links.length === 0) {
|
||
console.warn("Empty release with no links! This should never happen");
|
||
return;
|
||
}
|
||
const firstLink = ConnectingLinkImpl.createFromPlainObject(links[0]);
|
||
const mouseEvent = e.detail.originalEvent;
|
||
const commonOptions = {
|
||
e: mouseEvent,
|
||
allow_searchbox: true,
|
||
showSearchBox: /* @__PURE__ */ __name(() => showSearchBox(e), "showSearchBox")
|
||
};
|
||
const connectionOptions = firstLink.output ? {
|
||
nodeFrom: firstLink.node,
|
||
slotFrom: firstLink.output,
|
||
afterRerouteId: firstLink.afterRerouteId
|
||
} : {
|
||
nodeTo: firstLink.node,
|
||
slotTo: firstLink.input,
|
||
afterRerouteId: firstLink.afterRerouteId
|
||
};
|
||
canvasStore.canvas.showConnectionMenu({
|
||
...connectionOptions,
|
||
...commonOptions
|
||
});
|
||
}, "showContextMenu");
|
||
const canvasStore = useCanvasStore();
|
||
watchEffect(() => {
|
||
if (canvasStore.canvas) {
|
||
LiteGraph.release_link_on_empty_shows_menu = false;
|
||
canvasStore.canvas.allow_searchbox = false;
|
||
}
|
||
});
|
||
const canvasEventHandler = /* @__PURE__ */ __name((e) => {
|
||
if (e.detail.subType === "empty-double-click") {
|
||
showSearchBox(e);
|
||
} else if (e.detail.subType === "empty-release") {
|
||
handleCanvasEmptyRelease(e);
|
||
} else if (e.detail.subType === "group-double-click") {
|
||
const group = e.detail.group;
|
||
const [x, y] = group.pos;
|
||
const relativeY = e.detail.originalEvent.canvasY - y;
|
||
if (relativeY > group.titleHeight) {
|
||
showSearchBox(e);
|
||
}
|
||
}
|
||
}, "canvasEventHandler");
|
||
const linkReleaseAction = computed(() => {
|
||
return settingStore.get("Comfy.LinkRelease.Action");
|
||
});
|
||
const linkReleaseActionShift = computed(() => {
|
||
return settingStore.get("Comfy.LinkRelease.ActionShift");
|
||
});
|
||
const handleCanvasEmptyRelease = /* @__PURE__ */ __name((e) => {
|
||
const detail = e.detail;
|
||
const shiftPressed = detail.originalEvent.shiftKey;
|
||
const action = shiftPressed ? linkReleaseActionShift.value : linkReleaseAction.value;
|
||
switch (action) {
|
||
case LinkReleaseTriggerAction.SEARCH_BOX:
|
||
showSearchBox(e);
|
||
break;
|
||
case LinkReleaseTriggerAction.CONTEXT_MENU:
|
||
showContextMenu(e);
|
||
break;
|
||
case LinkReleaseTriggerAction.NO_ACTION:
|
||
default:
|
||
break;
|
||
}
|
||
}, "handleCanvasEmptyRelease");
|
||
useEventListener(document, "litegraph:canvas", canvasEventHandler);
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock("div", null, [
|
||
createVNode(unref(script$r), {
|
||
visible: unref(visible),
|
||
"onUpdate:visible": _cache[0] || (_cache[0] = ($event) => isRef(visible) ? visible.value = $event : null),
|
||
modal: "",
|
||
"dismissable-mask": dismissable.value,
|
||
onHide: clearFilters,
|
||
pt: {
|
||
root: {
|
||
class: "invisible-dialog-root",
|
||
role: "search"
|
||
},
|
||
mask: { class: "node-search-box-dialog-mask" },
|
||
transition: {
|
||
enterFromClass: "opacity-0 scale-75",
|
||
// 100ms is the duration of the transition in the dialog component
|
||
enterActiveClass: "transition-all duration-100 ease-out",
|
||
leaveActiveClass: "transition-all duration-100 ease-in",
|
||
leaveToClass: "opacity-0 scale-75"
|
||
}
|
||
}
|
||
}, {
|
||
container: withCtx(() => [
|
||
createVNode(_sfc_main$h, {
|
||
filters: nodeFilters.value,
|
||
onAddFilter: addFilter,
|
||
onRemoveFilter: removeFilter,
|
||
onAddNode: addNode
|
||
}, null, 8, ["filters"])
|
||
]),
|
||
_: 1
|
||
}, 8, ["visible", "dismissable-mask"])
|
||
]);
|
||
};
|
||
}
|
||
});
|
||
const _sfc_main$f = /* @__PURE__ */ defineComponent({
|
||
__name: "NodeTooltip",
|
||
setup(__props) {
|
||
let idleTimeout;
|
||
const nodeDefStore = useNodeDefStore();
|
||
const tooltipRef = ref();
|
||
const tooltipText = ref("");
|
||
const left = ref();
|
||
const top = ref();
|
||
const hideTooltip = /* @__PURE__ */ __name(() => tooltipText.value = null, "hideTooltip");
|
||
const showTooltip = /* @__PURE__ */ __name(async (tooltip) => {
|
||
if (!tooltip) return;
|
||
left.value = app.canvas.mouse[0] + "px";
|
||
top.value = app.canvas.mouse[1] + "px";
|
||
tooltipText.value = tooltip;
|
||
await nextTick();
|
||
const rect = tooltipRef.value.getBoundingClientRect();
|
||
if (rect.right > window.innerWidth) {
|
||
left.value = app.canvas.mouse[0] - rect.width + "px";
|
||
}
|
||
if (rect.top < 0) {
|
||
top.value = app.canvas.mouse[1] + rect.height + "px";
|
||
}
|
||
}, "showTooltip");
|
||
const onIdle = /* @__PURE__ */ __name(() => {
|
||
const { canvas } = app;
|
||
const node = canvas.node_over;
|
||
if (!node) return;
|
||
const ctor = node.constructor;
|
||
const nodeDef = nodeDefStore.nodeDefsByName[node.type];
|
||
if (ctor.title_mode !== LiteGraph.NO_TITLE && canvas.graph_mouse[1] < node.pos[1]) {
|
||
return showTooltip(nodeDef.description);
|
||
}
|
||
if (node.flags?.collapsed) return;
|
||
const inputSlot = canvas.isOverNodeInput(
|
||
node,
|
||
canvas.graph_mouse[0],
|
||
canvas.graph_mouse[1],
|
||
[0, 0]
|
||
);
|
||
if (inputSlot !== -1) {
|
||
const inputName = node.inputs[inputSlot].name;
|
||
const translatedTooltip = st(
|
||
`nodeDefs.${normalizeI18nKey(node.type)}.inputs.${normalizeI18nKey(inputName)}.tooltip`,
|
||
nodeDef.inputs.getInput(inputName)?.tooltip
|
||
);
|
||
return showTooltip(translatedTooltip);
|
||
}
|
||
const outputSlot = canvas.isOverNodeOutput(
|
||
node,
|
||
canvas.graph_mouse[0],
|
||
canvas.graph_mouse[1],
|
||
[0, 0]
|
||
);
|
||
if (outputSlot !== -1) {
|
||
const translatedTooltip = st(
|
||
`nodeDefs.${normalizeI18nKey(node.type)}.outputs.${outputSlot}.tooltip`,
|
||
nodeDef.outputs.all?.[outputSlot]?.tooltip
|
||
);
|
||
return showTooltip(translatedTooltip);
|
||
}
|
||
const widget = app.canvas.getWidgetAtCursor();
|
||
if (widget && !widget.element) {
|
||
const translatedTooltip = st(
|
||
`nodeDefs.${normalizeI18nKey(node.type)}.inputs.${normalizeI18nKey(widget.name)}.tooltip`,
|
||
nodeDef.inputs.getInput(widget.name)?.tooltip
|
||
);
|
||
return showTooltip(widget.tooltip ?? translatedTooltip);
|
||
}
|
||
}, "onIdle");
|
||
const onMouseMove = /* @__PURE__ */ __name((e) => {
|
||
hideTooltip();
|
||
clearTimeout(idleTimeout);
|
||
if (e.target.nodeName !== "CANVAS") return;
|
||
idleTimeout = window.setTimeout(onIdle, 500);
|
||
}, "onMouseMove");
|
||
useEventListener(window, "mousemove", onMouseMove);
|
||
useEventListener(window, "click", hideTooltip);
|
||
return (_ctx, _cache) => {
|
||
return tooltipText.value ? (openBlock(), createElementBlock("div", {
|
||
key: 0,
|
||
ref_key: "tooltipRef",
|
||
ref: tooltipRef,
|
||
class: "node-tooltip",
|
||
style: normalizeStyle({ left: left.value, top: top.value })
|
||
}, toDisplayString(tooltipText.value), 5)) : createCommentVNode("", true);
|
||
};
|
||
}
|
||
});
|
||
const NodeTooltip = /* @__PURE__ */ _export_sfc(_sfc_main$f, [["__scopeId", "data-v-9ecc8adc"]]);
|
||
const _sfc_main$e = /* @__PURE__ */ defineComponent({
|
||
__name: "NodeBadge",
|
||
setup(__props) {
|
||
const settingStore = useSettingStore();
|
||
const nodeSourceBadgeMode = computed(
|
||
() => settingStore.get("Comfy.NodeBadge.NodeSourceBadgeMode")
|
||
);
|
||
const nodeIdBadgeMode = computed(
|
||
() => settingStore.get("Comfy.NodeBadge.NodeIdBadgeMode")
|
||
);
|
||
const nodeLifeCycleBadgeMode = computed(
|
||
() => settingStore.get("Comfy.NodeBadge.NodeLifeCycleBadgeMode")
|
||
);
|
||
watch([nodeSourceBadgeMode, nodeIdBadgeMode, nodeLifeCycleBadgeMode], () => {
|
||
app.graph?.setDirtyCanvas(true, true);
|
||
});
|
||
const colorPalette = computed(
|
||
() => getColorPalette(settingStore.get("Comfy.ColorPalette"))
|
||
);
|
||
const nodeDefStore = useNodeDefStore();
|
||
function badgeTextVisible(nodeDef, badgeMode) {
|
||
return !(badgeMode === NodeBadgeMode.None || nodeDef?.isCoreNode && badgeMode === NodeBadgeMode.HideBuiltIn);
|
||
}
|
||
__name(badgeTextVisible, "badgeTextVisible");
|
||
onMounted(() => {
|
||
app.registerExtension({
|
||
name: "Comfy.NodeBadge",
|
||
nodeCreated(node) {
|
||
node.badgePosition = BadgePosition.TopRight;
|
||
const badge = computed(() => {
|
||
const nodeDef = nodeDefStore.fromLGraphNode(node);
|
||
return new LGraphBadge({
|
||
text: _.truncate(
|
||
[
|
||
badgeTextVisible(nodeDef, nodeIdBadgeMode.value) ? `#${node.id}` : "",
|
||
badgeTextVisible(nodeDef, nodeLifeCycleBadgeMode.value) ? nodeDef?.nodeLifeCycleBadgeText ?? "" : "",
|
||
badgeTextVisible(nodeDef, nodeSourceBadgeMode.value) ? nodeDef?.nodeSource?.badgeText ?? "" : ""
|
||
].filter((s) => s.length > 0).join(" "),
|
||
{
|
||
length: 31
|
||
}
|
||
),
|
||
fgColor: colorPalette.value?.colors?.litegraph_base?.BADGE_FG_COLOR || defaultColorPalette.colors.litegraph_base.BADGE_FG_COLOR,
|
||
bgColor: colorPalette.value?.colors?.litegraph_base?.BADGE_BG_COLOR || defaultColorPalette.colors.litegraph_base.BADGE_BG_COLOR
|
||
});
|
||
});
|
||
node.badges.push(() => badge.value);
|
||
}
|
||
});
|
||
});
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock("div");
|
||
};
|
||
}
|
||
});
|
||
const _hoisted_1$g = {
|
||
viewBox: "0 0 1024 1024",
|
||
width: "1.2em",
|
||
height: "1.2em"
|
||
};
|
||
const _hoisted_2$d = /* @__PURE__ */ createBaseVNode("path", {
|
||
fill: "currentColor",
|
||
d: "M921.088 103.232L584.832 889.024L465.52 544.512L121.328 440.48zM1004.46.769c-6.096 0-13.52 1.728-22.096 5.36L27.708 411.2c-34.383 14.592-36.56 42.704-4.847 62.464l395.296 123.584l129.36 403.264c9.28 15.184 20.496 22.72 31.263 22.72c11.936 0 23.296-9.152 31.04-27.248l408.272-953.728C1029.148 16.368 1022.86.769 1004.46.769"
|
||
}, null, -1);
|
||
const _hoisted_3$b = [
|
||
_hoisted_2$d
|
||
];
|
||
function render$d(_ctx, _cache) {
|
||
return openBlock(), createElementBlock("svg", _hoisted_1$g, [..._hoisted_3$b]);
|
||
}
|
||
__name(render$d, "render$d");
|
||
const __unplugin_components_1$2 = markRaw({ name: "simple-line-icons-cursor", render: render$d });
|
||
const _hoisted_1$f = {
|
||
viewBox: "0 0 24 24",
|
||
width: "1.2em",
|
||
height: "1.2em"
|
||
};
|
||
const _hoisted_2$c = /* @__PURE__ */ createBaseVNode("path", {
|
||
fill: "currentColor",
|
||
d: "M10.05 23q-.75 0-1.4-.337T7.575 21.7L1.2 12.375l.6-.575q.475-.475 1.125-.55t1.175.3L7 13.575V4q0-.425.288-.712T8 3t.713.288T9 4v13.425l-3.7-2.6l3.925 5.725q.125.2.35.325t.475.125H17q.825 0 1.413-.587T19 19V5q0-.425.288-.712T20 4t.713.288T21 5v14q0 1.65-1.175 2.825T17 23zM11 12V2q0-.425.288-.712T12 1t.713.288T13 2v10zm4 0V3q0-.425.288-.712T16 2t.713.288T17 3v9zm-2.85 4.5"
|
||
}, null, -1);
|
||
const _hoisted_3$a = [
|
||
_hoisted_2$c
|
||
];
|
||
function render$c(_ctx, _cache) {
|
||
return openBlock(), createElementBlock("svg", _hoisted_1$f, [..._hoisted_3$a]);
|
||
}
|
||
__name(render$c, "render$c");
|
||
const __unplugin_components_0$2 = markRaw({ name: "material-symbols-pan-tool-outline", render: render$c });
|
||
var theme$5 = /* @__PURE__ */ __name(function theme4(_ref) {
|
||
_ref.dt;
|
||
return "\n.p-buttongroup .p-button {\n margin: 0;\n}\n\n.p-buttongroup .p-button:not(:last-child),\n.p-buttongroup .p-button:not(:last-child):hover {\n border-right: 0 none;\n}\n\n.p-buttongroup .p-button:not(:first-of-type):not(:last-of-type) {\n border-radius: 0;\n}\n\n.p-buttongroup .p-button:first-of-type:not(:only-of-type) {\n border-top-right-radius: 0;\n border-bottom-right-radius: 0;\n}\n\n.p-buttongroup .p-button:last-of-type:not(:only-of-type) {\n border-top-left-radius: 0;\n border-bottom-left-radius: 0;\n}\n\n.p-buttongroup .p-button:focus {\n position: relative;\n z-index: 1;\n}\n";
|
||
}, "theme");
|
||
var classes$5 = {
|
||
root: "p-buttongroup p-component"
|
||
};
|
||
var ButtonGroupStyle = BaseStyle.extend({
|
||
name: "buttongroup",
|
||
theme: theme$5,
|
||
classes: classes$5
|
||
});
|
||
var script$1$5 = {
|
||
name: "BaseButtonGroup",
|
||
"extends": script$g,
|
||
style: ButtonGroupStyle,
|
||
provide: /* @__PURE__ */ __name(function provide8() {
|
||
return {
|
||
$pcButtonGroup: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script$7 = {
|
||
name: "ButtonGroup",
|
||
"extends": script$1$5,
|
||
inheritAttrs: false
|
||
};
|
||
function render$b(_ctx, _cache, $props, $setup, $data, $options) {
|
||
return openBlock(), createElementBlock("span", mergeProps({
|
||
"class": _ctx.cx("root"),
|
||
role: "group"
|
||
}, _ctx.ptmi("root")), [renderSlot(_ctx.$slots, "default")], 16);
|
||
}
|
||
__name(render$b, "render$b");
|
||
script$7.render = render$b;
|
||
const _sfc_main$d = /* @__PURE__ */ defineComponent({
|
||
__name: "GraphCanvasMenu",
|
||
setup(__props) {
|
||
const { t } = useI18n();
|
||
const commandStore = useCommandStore();
|
||
const canvasStore = useCanvasStore();
|
||
const settingStore = useSettingStore();
|
||
const linkHidden = computed(
|
||
() => settingStore.get("Comfy.LinkRenderMode") === LiteGraph.HIDDEN_LINK
|
||
);
|
||
let interval = null;
|
||
const repeat2 = /* @__PURE__ */ __name((command) => {
|
||
if (interval) return;
|
||
const cmd = /* @__PURE__ */ __name(() => commandStore.execute(command), "cmd");
|
||
cmd();
|
||
interval = window.setInterval(cmd, 100);
|
||
}, "repeat");
|
||
const stopRepeat = /* @__PURE__ */ __name(() => {
|
||
if (interval) {
|
||
clearInterval(interval);
|
||
interval = null;
|
||
}
|
||
}, "stopRepeat");
|
||
return (_ctx, _cache) => {
|
||
const _component_i_material_symbols58pan_tool_outline = __unplugin_components_0$2;
|
||
const _component_i_simple_line_icons58cursor = __unplugin_components_1$2;
|
||
const _directive_tooltip = resolveDirective("tooltip");
|
||
return openBlock(), createBlock(unref(script$7), { class: "p-buttongroup-vertical absolute bottom-[10px] right-[10px] z-[1000] pointer-events-auto" }, {
|
||
default: withCtx(() => [
|
||
withDirectives(createVNode(unref(script$f), {
|
||
severity: "secondary",
|
||
icon: "pi pi-plus",
|
||
onMousedown: _cache[0] || (_cache[0] = ($event) => repeat2("Comfy.Canvas.ZoomIn")),
|
||
onMouseup: stopRepeat
|
||
}, null, 512), [
|
||
[
|
||
_directive_tooltip,
|
||
unref(t)("graphCanvasMenu.zoomIn"),
|
||
void 0,
|
||
{ left: true }
|
||
]
|
||
]),
|
||
withDirectives(createVNode(unref(script$f), {
|
||
severity: "secondary",
|
||
icon: "pi pi-minus",
|
||
onMousedown: _cache[1] || (_cache[1] = ($event) => repeat2("Comfy.Canvas.ZoomOut")),
|
||
onMouseup: stopRepeat
|
||
}, null, 512), [
|
||
[
|
||
_directive_tooltip,
|
||
unref(t)("graphCanvasMenu.zoomOut"),
|
||
void 0,
|
||
{ left: true }
|
||
]
|
||
]),
|
||
withDirectives(createVNode(unref(script$f), {
|
||
severity: "secondary",
|
||
icon: "pi pi-expand",
|
||
onClick: _cache[2] || (_cache[2] = () => unref(commandStore).execute("Comfy.Canvas.FitView"))
|
||
}, null, 512), [
|
||
[
|
||
_directive_tooltip,
|
||
unref(t)("graphCanvasMenu.fitView"),
|
||
void 0,
|
||
{ left: true }
|
||
]
|
||
]),
|
||
withDirectives((openBlock(), createBlock(unref(script$f), {
|
||
severity: "secondary",
|
||
onClick: _cache[3] || (_cache[3] = () => unref(commandStore).execute("Comfy.Canvas.ToggleLock"))
|
||
}, {
|
||
icon: withCtx(() => [
|
||
unref(canvasStore).canvas?.read_only ? (openBlock(), createBlock(_component_i_material_symbols58pan_tool_outline, { key: 0 })) : (openBlock(), createBlock(_component_i_simple_line_icons58cursor, { key: 1 }))
|
||
]),
|
||
_: 1
|
||
})), [
|
||
[
|
||
_directive_tooltip,
|
||
unref(t)(
|
||
"graphCanvasMenu." + (unref(canvasStore).canvas?.read_only ? "panMode" : "selectMode")
|
||
) + " (Space)",
|
||
void 0,
|
||
{ left: true }
|
||
]
|
||
]),
|
||
withDirectives(createVNode(unref(script$f), {
|
||
severity: "secondary",
|
||
icon: linkHidden.value ? "pi pi-eye-slash" : "pi pi-eye",
|
||
onClick: _cache[4] || (_cache[4] = () => unref(commandStore).execute("Comfy.Canvas.ToggleLinkVisibility")),
|
||
"data-testid": "toggle-link-visibility-button"
|
||
}, null, 8, ["icon"]), [
|
||
[
|
||
_directive_tooltip,
|
||
unref(t)("graphCanvasMenu.toggleLinkVisibility"),
|
||
void 0,
|
||
{ left: true }
|
||
]
|
||
])
|
||
]),
|
||
_: 1
|
||
});
|
||
};
|
||
}
|
||
});
|
||
const GraphCanvasMenu = /* @__PURE__ */ _export_sfc(_sfc_main$d, [["__scopeId", "data-v-94481f39"]]);
|
||
const _sfc_main$c = /* @__PURE__ */ defineComponent({
|
||
__name: "GraphCanvas",
|
||
emits: ["ready"],
|
||
setup(__props, { emit: __emit }) {
|
||
const emit = __emit;
|
||
const canvasRef = ref(null);
|
||
const settingStore = useSettingStore();
|
||
const nodeDefStore = useNodeDefStore();
|
||
const workspaceStore = useWorkspaceStore();
|
||
const canvasStore = useCanvasStore();
|
||
const modelToNodeStore = useModelToNodeStore();
|
||
const betaMenuEnabled = computed(
|
||
() => settingStore.get("Comfy.UseNewMenu") !== "Disabled"
|
||
);
|
||
const canvasMenuEnabled = computed(
|
||
() => settingStore.get("Comfy.Graph.CanvasMenu")
|
||
);
|
||
const tooltipEnabled = computed(() => settingStore.get("Comfy.EnableTooltips"));
|
||
watchEffect(() => {
|
||
const canvasInfoEnabled = settingStore.get("Comfy.Graph.CanvasInfo");
|
||
if (canvasStore.canvas) {
|
||
canvasStore.canvas.show_info = canvasInfoEnabled;
|
||
}
|
||
});
|
||
watchEffect(() => {
|
||
const zoomSpeed = settingStore.get("Comfy.Graph.ZoomSpeed");
|
||
if (canvasStore.canvas) {
|
||
canvasStore.canvas.zoom_speed = zoomSpeed;
|
||
}
|
||
});
|
||
watchEffect(() => {
|
||
LiteGraph.snaps_for_comfy = settingStore.get("Comfy.Node.AutoSnapLinkToSlot");
|
||
});
|
||
watchEffect(() => {
|
||
LiteGraph.snap_highlights_node = settingStore.get(
|
||
"Comfy.Node.SnapHighlightsNode"
|
||
);
|
||
});
|
||
watchEffect(() => {
|
||
LGraphNode.keepAllLinksOnBypass = settingStore.get(
|
||
"Comfy.Node.BypassAllLinksOnDelete"
|
||
);
|
||
});
|
||
watchEffect(() => {
|
||
LiteGraph.middle_click_slot_add_default_node = settingStore.get(
|
||
"Comfy.Node.MiddleClickRerouteNode"
|
||
);
|
||
});
|
||
watchEffect(() => {
|
||
nodeDefStore.showDeprecated = settingStore.get("Comfy.Node.ShowDeprecated");
|
||
});
|
||
watchEffect(() => {
|
||
nodeDefStore.showExperimental = settingStore.get(
|
||
"Comfy.Node.ShowExperimental"
|
||
);
|
||
});
|
||
watchEffect(() => {
|
||
const spellcheckEnabled = settingStore.get("Comfy.TextareaWidget.Spellcheck");
|
||
const textareas = document.querySelectorAll("textarea.comfy-multiline-input");
|
||
textareas.forEach((textarea) => {
|
||
textarea.spellcheck = spellcheckEnabled;
|
||
textarea.focus();
|
||
textarea.blur();
|
||
});
|
||
});
|
||
watchEffect(() => {
|
||
const linkRenderMode = settingStore.get("Comfy.LinkRenderMode");
|
||
if (canvasStore.canvas) {
|
||
canvasStore.canvas.links_render_mode = linkRenderMode;
|
||
canvasStore.canvas.setDirty(
|
||
/* fg */
|
||
false,
|
||
/* bg */
|
||
true
|
||
);
|
||
}
|
||
});
|
||
watchEffect(() => {
|
||
const linkMarkerShape = settingStore.get("Comfy.Graph.LinkMarkers");
|
||
const { canvas } = canvasStore;
|
||
if (canvas) {
|
||
canvas.linkMarkerShape = linkMarkerShape;
|
||
canvas.setDirty(false, true);
|
||
}
|
||
});
|
||
watchEffect(() => {
|
||
const reroutesEnabled = settingStore.get("Comfy.RerouteBeta");
|
||
const { canvas } = canvasStore;
|
||
if (canvas) {
|
||
canvas.reroutesEnabled = reroutesEnabled;
|
||
canvas.setDirty(false, true);
|
||
}
|
||
});
|
||
watchEffect(() => {
|
||
const maximumFps = settingStore.get("LiteGraph.Canvas.MaximumFps");
|
||
const { canvas } = canvasStore;
|
||
if (canvas) canvas.maximumFps = maximumFps;
|
||
});
|
||
watchEffect(() => {
|
||
CanvasPointer.doubleClickTime = settingStore.get(
|
||
"Comfy.Pointer.DoubleClickTime"
|
||
);
|
||
});
|
||
watchEffect(() => {
|
||
CanvasPointer.bufferTime = settingStore.get("Comfy.Pointer.ClickBufferTime");
|
||
});
|
||
watchEffect(() => {
|
||
CanvasPointer.maxClickDrift = settingStore.get("Comfy.Pointer.ClickDrift");
|
||
});
|
||
watchEffect(() => {
|
||
LiteGraph.CANVAS_GRID_SIZE = settingStore.get("Comfy.SnapToGrid.GridSize");
|
||
});
|
||
watchEffect(() => {
|
||
LiteGraph.alwaysSnapToGrid = settingStore.get("pysssss.SnapToGrid");
|
||
});
|
||
watchEffect(() => {
|
||
if (!canvasStore.canvas) return;
|
||
if (canvasStore.canvas.state.draggingCanvas) {
|
||
canvasStore.canvas.canvas.style.cursor = "grabbing";
|
||
return;
|
||
}
|
||
if (canvasStore.canvas.state.readOnly) {
|
||
canvasStore.canvas.canvas.style.cursor = "grab";
|
||
return;
|
||
}
|
||
canvasStore.canvas.canvas.style.cursor = "default";
|
||
});
|
||
const workflowStore = useWorkflowStore();
|
||
const persistCurrentWorkflow = /* @__PURE__ */ __name(() => {
|
||
const workflow = JSON.stringify(app.serializeGraph());
|
||
localStorage.setItem("workflow", workflow);
|
||
if (api.clientId) {
|
||
sessionStorage.setItem(`workflow:${api.clientId}`, workflow);
|
||
}
|
||
}, "persistCurrentWorkflow");
|
||
watchEffect(() => {
|
||
if (workflowStore.activeWorkflow) {
|
||
const workflow = workflowStore.activeWorkflow;
|
||
setStorageValue("Comfy.PreviousWorkflow", workflow.key);
|
||
persistCurrentWorkflow();
|
||
}
|
||
});
|
||
api.addEventListener("graphChanged", persistCurrentWorkflow);
|
||
usePragmaticDroppable(() => canvasRef.value, {
|
||
onDrop: /* @__PURE__ */ __name((event) => {
|
||
const loc = event.location.current.input;
|
||
const dndData = event.source.data;
|
||
if (dndData.type === "tree-explorer-node") {
|
||
const node = dndData.data;
|
||
if (node.data instanceof ComfyNodeDefImpl) {
|
||
const nodeDef = node.data;
|
||
const pos = app.clientPosToCanvasPos([
|
||
loc.clientX - 20,
|
||
loc.clientY
|
||
]);
|
||
app.addNodeOnGraph(nodeDef, { pos });
|
||
} else if (node.data instanceof ComfyModelDef) {
|
||
const model = node.data;
|
||
const pos = app.clientPosToCanvasPos([loc.clientX, loc.clientY]);
|
||
const nodeAtPos = app.graph.getNodeOnPos(pos[0], pos[1]);
|
||
let targetProvider = null;
|
||
let targetGraphNode = null;
|
||
if (nodeAtPos) {
|
||
const providers = modelToNodeStore.getAllNodeProviders(
|
||
model.directory
|
||
);
|
||
for (const provider of providers) {
|
||
if (provider.nodeDef.name === nodeAtPos.comfyClass) {
|
||
targetGraphNode = nodeAtPos;
|
||
targetProvider = provider;
|
||
}
|
||
}
|
||
}
|
||
if (!targetGraphNode) {
|
||
const provider = modelToNodeStore.getNodeProvider(model.directory);
|
||
if (provider) {
|
||
targetGraphNode = app.addNodeOnGraph(provider.nodeDef, {
|
||
pos
|
||
});
|
||
targetProvider = provider;
|
||
}
|
||
}
|
||
if (targetGraphNode) {
|
||
const widget = targetGraphNode.widgets.find(
|
||
(widget2) => widget2.name === targetProvider.key
|
||
);
|
||
if (widget) {
|
||
widget.value = model.file_name;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}, "onDrop")
|
||
});
|
||
const comfyAppReady = ref(false);
|
||
onMounted(async () => {
|
||
window["LiteGraph"] = LiteGraph;
|
||
window["LGraph"] = LGraph;
|
||
window["LLink"] = LLink;
|
||
window["LGraphNode"] = LGraphNode;
|
||
window["LGraphGroup"] = LGraphGroup;
|
||
window["DragAndScale"] = DragAndScale;
|
||
window["LGraphCanvas"] = LGraphCanvas;
|
||
window["ContextMenu"] = ContextMenu;
|
||
window["LGraphBadge"] = LGraphBadge;
|
||
app.vueAppReady = true;
|
||
workspaceStore.spinner = true;
|
||
ChangeTracker.init(app);
|
||
await app.setup(canvasRef.value);
|
||
canvasStore.canvas = app.canvas;
|
||
canvasStore.canvas.render_canvas_border = false;
|
||
workspaceStore.spinner = false;
|
||
window["app"] = app;
|
||
window["graph"] = app.graph;
|
||
comfyAppReady.value = true;
|
||
watch(
|
||
() => settingStore.get("Comfy.Locale"),
|
||
async () => {
|
||
await useCommandStore().execute("Comfy.RefreshNodeDefinitions");
|
||
workflowService.reloadCurrentWorkflow();
|
||
}
|
||
);
|
||
emit("ready");
|
||
});
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock(Fragment, null, [
|
||
(openBlock(), createBlock(Teleport, { to: ".graph-canvas-container" }, [
|
||
comfyAppReady.value && betaMenuEnabled.value && !unref(workspaceStore).focusMode ? (openBlock(), createBlock(LiteGraphCanvasSplitterOverlay, { key: 0 }, {
|
||
"side-bar-panel": withCtx(() => [
|
||
createVNode(SideToolbar)
|
||
]),
|
||
"bottom-panel": withCtx(() => [
|
||
createVNode(_sfc_main$l)
|
||
]),
|
||
"graph-canvas-panel": withCtx(() => [
|
||
canvasMenuEnabled.value ? (openBlock(), createBlock(GraphCanvasMenu, { key: 0 })) : createCommentVNode("", true)
|
||
]),
|
||
_: 1
|
||
})) : createCommentVNode("", true),
|
||
createVNode(TitleEditor),
|
||
!betaMenuEnabled.value && canvasMenuEnabled.value ? (openBlock(), createBlock(GraphCanvasMenu, { key: 1 })) : createCommentVNode("", true),
|
||
createBaseVNode("canvas", {
|
||
ref_key: "canvasRef",
|
||
ref: canvasRef,
|
||
id: "graph-canvas",
|
||
tabindex: "1"
|
||
}, null, 512)
|
||
])),
|
||
createVNode(_sfc_main$g),
|
||
tooltipEnabled.value ? (openBlock(), createBlock(NodeTooltip, { key: 0 })) : createCommentVNode("", true),
|
||
createVNode(_sfc_main$e)
|
||
], 64);
|
||
};
|
||
}
|
||
});
|
||
const _sfc_main$b = /* @__PURE__ */ defineComponent({
|
||
__name: "MenuHamburger",
|
||
setup(__props) {
|
||
const workspaceState = useWorkspaceStore();
|
||
const settingStore = useSettingStore();
|
||
const exitFocusMode = /* @__PURE__ */ __name(() => {
|
||
workspaceState.focusMode = false;
|
||
}, "exitFocusMode");
|
||
watchEffect(() => {
|
||
if (settingStore.get("Comfy.UseNewMenu") !== "Disabled") {
|
||
return;
|
||
}
|
||
if (workspaceState.focusMode) {
|
||
app.ui.menuContainer.style.display = "none";
|
||
} else {
|
||
app.ui.menuContainer.style.display = "block";
|
||
}
|
||
});
|
||
const menuSetting = computed(() => settingStore.get("Comfy.UseNewMenu"));
|
||
const positionCSS = computed(
|
||
() => (
|
||
// 'Bottom' menuSetting shows the hamburger button in the bottom right corner
|
||
// 'Disabled', 'Top' menuSetting shows the hamburger button in the top right corner
|
||
menuSetting.value === "Bottom" ? { bottom: "0px", right: "0px" } : { top: "0px", right: "0px" }
|
||
)
|
||
);
|
||
return (_ctx, _cache) => {
|
||
const _directive_tooltip = resolveDirective("tooltip");
|
||
return withDirectives((openBlock(), createBlock(unref(script$f), {
|
||
class: "comfy-menu-hamburger",
|
||
style: normalizeStyle(positionCSS.value),
|
||
icon: "pi pi-bars",
|
||
severity: "secondary",
|
||
text: "",
|
||
size: "large",
|
||
onClick: exitFocusMode,
|
||
onContextmenu: unref(showNativeMenu)
|
||
}, null, 8, ["style", "onContextmenu"])), [
|
||
[vShow, unref(workspaceState).focusMode],
|
||
[_directive_tooltip, { value: _ctx.$t("menu.showMenu"), showDelay: 300 }]
|
||
]);
|
||
};
|
||
}
|
||
});
|
||
const MenuHamburger = /* @__PURE__ */ _export_sfc(_sfc_main$b, [["__scopeId", "data-v-962c4073"]]);
|
||
function _typeof$3(o) {
|
||
"@babel/helpers - typeof";
|
||
return _typeof$3 = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(o2) {
|
||
return typeof o2;
|
||
} : function(o2) {
|
||
return o2 && "function" == typeof Symbol && o2.constructor === Symbol && o2 !== Symbol.prototype ? "symbol" : typeof o2;
|
||
}, _typeof$3(o);
|
||
}
|
||
__name(_typeof$3, "_typeof$3");
|
||
function _defineProperty$3(e, r, t) {
|
||
return (r = _toPropertyKey$3(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: true, configurable: true, writable: true }) : e[r] = t, e;
|
||
}
|
||
__name(_defineProperty$3, "_defineProperty$3");
|
||
function _toPropertyKey$3(t) {
|
||
var i = _toPrimitive$3(t, "string");
|
||
return "symbol" == _typeof$3(i) ? i : i + "";
|
||
}
|
||
__name(_toPropertyKey$3, "_toPropertyKey$3");
|
||
function _toPrimitive$3(t, r) {
|
||
if ("object" != _typeof$3(t) || !t) return t;
|
||
var e = t[Symbol.toPrimitive];
|
||
if (void 0 !== e) {
|
||
var i = e.call(t, r || "default");
|
||
if ("object" != _typeof$3(i)) return i;
|
||
throw new TypeError("@@toPrimitive must return a primitive value.");
|
||
}
|
||
return ("string" === r ? String : Number)(t);
|
||
}
|
||
__name(_toPrimitive$3, "_toPrimitive$3");
|
||
var theme$4 = /* @__PURE__ */ __name(function theme5(_ref) {
|
||
var dt = _ref.dt;
|
||
return "\n.p-toast {\n width: ".concat(dt("toast.width"), ";\n white-space: pre-line;\n word-break: break-word;\n}\n\n.p-toast-message {\n margin: 0 0 1rem 0;\n}\n\n.p-toast-message-icon {\n flex-shrink: 0;\n font-size: ").concat(dt("toast.icon.size"), ";\n width: ").concat(dt("toast.icon.size"), ";\n height: ").concat(dt("toast.icon.size"), ";\n}\n\n.p-toast-message-content {\n display: flex;\n align-items: flex-start;\n padding: ").concat(dt("toast.content.padding"), ";\n gap: ").concat(dt("toast.content.gap"), ";\n}\n\n.p-toast-message-text {\n flex: 1 1 auto;\n display: flex;\n flex-direction: column;\n gap: ").concat(dt("toast.text.gap"), ";\n}\n\n.p-toast-summary {\n font-weight: ").concat(dt("toast.summary.font.weight"), ";\n font-size: ").concat(dt("toast.summary.font.size"), ";\n}\n\n.p-toast-detail {\n font-weight: ").concat(dt("toast.detail.font.weight"), ";\n font-size: ").concat(dt("toast.detail.font.size"), ";\n}\n\n.p-toast-close-button {\n display: flex;\n align-items: center;\n justify-content: center;\n overflow: hidden;\n position: relative;\n cursor: pointer;\n background: transparent;\n transition: background ").concat(dt("toast.transition.duration"), ", color ").concat(dt("toast.transition.duration"), ", outline-color ").concat(dt("toast.transition.duration"), ", box-shadow ").concat(dt("toast.transition.duration"), ";\n outline-color: transparent;\n color: inherit;\n width: ").concat(dt("toast.close.button.width"), ";\n height: ").concat(dt("toast.close.button.height"), ";\n border-radius: ").concat(dt("toast.close.button.border.radius"), ";\n margin: -25% 0 0 0;\n right: -25%;\n padding: 0;\n border: none;\n user-select: none;\n}\n\n.p-toast-message-info,\n.p-toast-message-success,\n.p-toast-message-warn,\n.p-toast-message-error,\n.p-toast-message-secondary,\n.p-toast-message-contrast {\n border-width: ").concat(dt("toast.border.width"), ";\n border-style: solid;\n backdrop-filter: blur(").concat(dt("toast.blur"), ");\n border-radius: ").concat(dt("toast.border.radius"), ";\n}\n\n.p-toast-close-icon {\n font-size: ").concat(dt("toast.close.icon.size"), ";\n width: ").concat(dt("toast.close.icon.size"), ";\n height: ").concat(dt("toast.close.icon.size"), ";\n}\n\n.p-toast-close-button:focus-visible {\n outline-width: ").concat(dt("focus.ring.width"), ";\n outline-style: ").concat(dt("focus.ring.style"), ";\n outline-offset: ").concat(dt("focus.ring.offset"), ";\n}\n\n.p-toast-message-info {\n background: ").concat(dt("toast.info.background"), ";\n border-color: ").concat(dt("toast.info.border.color"), ";\n color: ").concat(dt("toast.info.color"), ";\n box-shadow: ").concat(dt("toast.info.shadow"), ";\n}\n\n.p-toast-message-info .p-toast-detail {\n color: ").concat(dt("toast.info.detail.color"), ";\n}\n\n.p-toast-message-info .p-toast-close-button:focus-visible {\n outline-color: ").concat(dt("toast.info.close.button.focus.ring.color"), ";\n box-shadow: ").concat(dt("toast.info.close.button.focus.ring.shadow"), ";\n}\n\n.p-toast-message-info .p-toast-close-button:hover {\n background: ").concat(dt("toast.info.close.button.hover.background"), ";\n}\n\n.p-toast-message-success {\n background: ").concat(dt("toast.success.background"), ";\n border-color: ").concat(dt("toast.success.border.color"), ";\n color: ").concat(dt("toast.success.color"), ";\n box-shadow: ").concat(dt("toast.success.shadow"), ";\n}\n\n.p-toast-message-success .p-toast-detail {\n color: ").concat(dt("toast.success.detail.color"), ";\n}\n\n.p-toast-message-success .p-toast-close-button:focus-visible {\n outline-color: ").concat(dt("toast.success.close.button.focus.ring.color"), ";\n box-shadow: ").concat(dt("toast.success.close.button.focus.ring.shadow"), ";\n}\n\n.p-toast-message-success .p-toast-close-button:hover {\n background: ").concat(dt("toast.success.close.button.hover.background"), ";\n}\n\n.p-toast-message-warn {\n background: ").concat(dt("toast.warn.background"), ";\n border-color: ").concat(dt("toast.warn.border.color"), ";\n color: ").concat(dt("toast.warn.color"), ";\n box-shadow: ").concat(dt("toast.warn.shadow"), ";\n}\n\n.p-toast-message-warn .p-toast-detail {\n color: ").concat(dt("toast.warn.detail.color"), ";\n}\n\n.p-toast-message-warn .p-toast-close-button:focus-visible {\n outline-color: ").concat(dt("toast.warn.close.button.focus.ring.color"), ";\n box-shadow: ").concat(dt("toast.warn.close.button.focus.ring.shadow"), ";\n}\n\n.p-toast-message-warn .p-toast-close-button:hover {\n background: ").concat(dt("toast.warn.close.button.hover.background"), ";\n}\n\n.p-toast-message-error {\n background: ").concat(dt("toast.error.background"), ";\n border-color: ").concat(dt("toast.error.border.color"), ";\n color: ").concat(dt("toast.error.color"), ";\n box-shadow: ").concat(dt("toast.error.shadow"), ";\n}\n\n.p-toast-message-error .p-toast-detail {\n color: ").concat(dt("toast.error.detail.color"), ";\n}\n\n.p-toast-message-error .p-toast-close-button:focus-visible {\n outline-color: ").concat(dt("toast.error.close.button.focus.ring.color"), ";\n box-shadow: ").concat(dt("toast.error.close.button.focus.ring.shadow"), ";\n}\n\n.p-toast-message-error .p-toast-close-button:hover {\n background: ").concat(dt("toast.error.close.button.hover.background"), ";\n}\n\n.p-toast-message-secondary {\n background: ").concat(dt("toast.secondary.background"), ";\n border-color: ").concat(dt("toast.secondary.border.color"), ";\n color: ").concat(dt("toast.secondary.color"), ";\n box-shadow: ").concat(dt("toast.secondary.shadow"), ";\n}\n\n.p-toast-message-secondary .p-toast-detail {\n color: ").concat(dt("toast.secondary.detail.color"), ";\n}\n\n.p-toast-message-secondary .p-toast-close-button:focus-visible {\n outline-color: ").concat(dt("toast.secondary.close.button.focus.ring.color"), ";\n box-shadow: ").concat(dt("toast.secondary.close.button.focus.ring.shadow"), ";\n}\n\n.p-toast-message-secondary .p-toast-close-button:hover {\n background: ").concat(dt("toast.secondary.close.button.hover.background"), ";\n}\n\n.p-toast-message-contrast {\n background: ").concat(dt("toast.contrast.background"), ";\n border-color: ").concat(dt("toast.contrast.border.color"), ";\n color: ").concat(dt("toast.contrast.color"), ";\n box-shadow: ").concat(dt("toast.contrast.shadow"), ";\n}\n\n.p-toast-message-contrast .p-toast-detail {\n color: ").concat(dt("toast.contrast.detail.color"), ";\n}\n\n.p-toast-message-contrast .p-toast-close-button:focus-visible {\n outline-color: ").concat(dt("toast.contrast.close.button.focus.ring.color"), ";\n box-shadow: ").concat(dt("toast.contrast.close.button.focus.ring.shadow"), ";\n}\n\n.p-toast-message-contrast .p-toast-close-button:hover {\n background: ").concat(dt("toast.contrast.close.button.hover.background"), ";\n}\n\n.p-toast-top-center {\n transform: translateX(-50%);\n}\n\n.p-toast-bottom-center {\n transform: translateX(-50%);\n}\n\n.p-toast-center {\n min-width: 20vw;\n transform: translate(-50%, -50%);\n}\n\n.p-toast-message-enter-from {\n opacity: 0;\n transform: translateY(50%);\n}\n\n.p-toast-message-leave-from {\n max-height: 1000px;\n}\n\n.p-toast .p-toast-message.p-toast-message-leave-to {\n max-height: 0;\n opacity: 0;\n margin-bottom: 0;\n overflow: hidden;\n}\n\n.p-toast-message-enter-active {\n transition: transform 0.3s, opacity 0.3s;\n}\n\n.p-toast-message-leave-active {\n transition: max-height 0.45s cubic-bezier(0, 1, 0, 1), opacity 0.3s, margin-bottom 0.3s;\n}\n");
|
||
}, "theme");
|
||
var inlineStyles$2 = {
|
||
root: /* @__PURE__ */ __name(function root6(_ref2) {
|
||
var position = _ref2.position;
|
||
return {
|
||
position: "fixed",
|
||
top: position === "top-right" || position === "top-left" || position === "top-center" ? "20px" : position === "center" ? "50%" : null,
|
||
right: (position === "top-right" || position === "bottom-right") && "20px",
|
||
bottom: (position === "bottom-left" || position === "bottom-right" || position === "bottom-center") && "20px",
|
||
left: position === "top-left" || position === "bottom-left" ? "20px" : position === "center" || position === "top-center" || position === "bottom-center" ? "50%" : null
|
||
};
|
||
}, "root")
|
||
};
|
||
var classes$4 = {
|
||
root: /* @__PURE__ */ __name(function root7(_ref3) {
|
||
var props = _ref3.props;
|
||
return ["p-toast p-component p-toast-" + props.position];
|
||
}, "root"),
|
||
message: /* @__PURE__ */ __name(function message(_ref4) {
|
||
var props = _ref4.props;
|
||
return ["p-toast-message", {
|
||
"p-toast-message-info": props.message.severity === "info" || props.message.severity === void 0,
|
||
"p-toast-message-warn": props.message.severity === "warn",
|
||
"p-toast-message-error": props.message.severity === "error",
|
||
"p-toast-message-success": props.message.severity === "success",
|
||
"p-toast-message-secondary": props.message.severity === "secondary",
|
||
"p-toast-message-contrast": props.message.severity === "contrast"
|
||
}];
|
||
}, "message"),
|
||
messageContent: "p-toast-message-content",
|
||
messageIcon: /* @__PURE__ */ __name(function messageIcon(_ref5) {
|
||
var props = _ref5.props;
|
||
return ["p-toast-message-icon", _defineProperty$3(_defineProperty$3(_defineProperty$3(_defineProperty$3({}, props.infoIcon, props.message.severity === "info"), props.warnIcon, props.message.severity === "warn"), props.errorIcon, props.message.severity === "error"), props.successIcon, props.message.severity === "success")];
|
||
}, "messageIcon"),
|
||
messageText: "p-toast-message-text",
|
||
summary: "p-toast-summary",
|
||
detail: "p-toast-detail",
|
||
closeButton: "p-toast-close-button",
|
||
closeIcon: "p-toast-close-icon"
|
||
};
|
||
var ToastStyle = BaseStyle.extend({
|
||
name: "toast",
|
||
theme: theme$4,
|
||
classes: classes$4,
|
||
inlineStyles: inlineStyles$2
|
||
});
|
||
var script$2$2 = {
|
||
name: "BaseToast",
|
||
"extends": script$g,
|
||
props: {
|
||
group: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
position: {
|
||
type: String,
|
||
"default": "top-right"
|
||
},
|
||
autoZIndex: {
|
||
type: Boolean,
|
||
"default": true
|
||
},
|
||
baseZIndex: {
|
||
type: Number,
|
||
"default": 0
|
||
},
|
||
breakpoints: {
|
||
type: Object,
|
||
"default": null
|
||
},
|
||
closeIcon: {
|
||
type: String,
|
||
"default": void 0
|
||
},
|
||
infoIcon: {
|
||
type: String,
|
||
"default": void 0
|
||
},
|
||
warnIcon: {
|
||
type: String,
|
||
"default": void 0
|
||
},
|
||
errorIcon: {
|
||
type: String,
|
||
"default": void 0
|
||
},
|
||
successIcon: {
|
||
type: String,
|
||
"default": void 0
|
||
},
|
||
closeButtonProps: {
|
||
type: null,
|
||
"default": null
|
||
}
|
||
},
|
||
style: ToastStyle,
|
||
provide: /* @__PURE__ */ __name(function provide9() {
|
||
return {
|
||
$pcToast: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script$1$4 = {
|
||
name: "ToastMessage",
|
||
hostName: "Toast",
|
||
"extends": script$g,
|
||
emits: ["close"],
|
||
closeTimeout: null,
|
||
props: {
|
||
message: {
|
||
type: null,
|
||
"default": null
|
||
},
|
||
templates: {
|
||
type: Object,
|
||
"default": null
|
||
},
|
||
closeIcon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
infoIcon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
warnIcon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
errorIcon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
successIcon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
closeButtonProps: {
|
||
type: null,
|
||
"default": null
|
||
}
|
||
},
|
||
mounted: /* @__PURE__ */ __name(function mounted4() {
|
||
var _this = this;
|
||
if (this.message.life) {
|
||
this.closeTimeout = setTimeout(function() {
|
||
_this.close({
|
||
message: _this.message,
|
||
type: "life-end"
|
||
});
|
||
}, this.message.life);
|
||
}
|
||
}, "mounted"),
|
||
beforeUnmount: /* @__PURE__ */ __name(function beforeUnmount4() {
|
||
this.clearCloseTimeout();
|
||
}, "beforeUnmount"),
|
||
methods: {
|
||
close: /* @__PURE__ */ __name(function close(params) {
|
||
this.$emit("close", params);
|
||
}, "close"),
|
||
onCloseClick: /* @__PURE__ */ __name(function onCloseClick() {
|
||
this.clearCloseTimeout();
|
||
this.close({
|
||
message: this.message,
|
||
type: "close"
|
||
});
|
||
}, "onCloseClick"),
|
||
clearCloseTimeout: /* @__PURE__ */ __name(function clearCloseTimeout() {
|
||
if (this.closeTimeout) {
|
||
clearTimeout(this.closeTimeout);
|
||
this.closeTimeout = null;
|
||
}
|
||
}, "clearCloseTimeout")
|
||
},
|
||
computed: {
|
||
iconComponent: /* @__PURE__ */ __name(function iconComponent() {
|
||
return {
|
||
info: !this.infoIcon && script$s,
|
||
success: !this.successIcon && script$t,
|
||
warn: !this.warnIcon && script$u,
|
||
error: !this.errorIcon && script$v
|
||
}[this.message.severity];
|
||
}, "iconComponent"),
|
||
closeAriaLabel: /* @__PURE__ */ __name(function closeAriaLabel() {
|
||
return this.$primevue.config.locale.aria ? this.$primevue.config.locale.aria.close : void 0;
|
||
}, "closeAriaLabel")
|
||
},
|
||
components: {
|
||
TimesIcon: script$w,
|
||
InfoCircleIcon: script$s,
|
||
CheckIcon: script$t,
|
||
ExclamationTriangleIcon: script$u,
|
||
TimesCircleIcon: script$v
|
||
},
|
||
directives: {
|
||
ripple: Ripple
|
||
}
|
||
};
|
||
function _typeof$1(o) {
|
||
"@babel/helpers - typeof";
|
||
return _typeof$1 = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(o2) {
|
||
return typeof o2;
|
||
} : function(o2) {
|
||
return o2 && "function" == typeof Symbol && o2.constructor === Symbol && o2 !== Symbol.prototype ? "symbol" : typeof o2;
|
||
}, _typeof$1(o);
|
||
}
|
||
__name(_typeof$1, "_typeof$1");
|
||
function ownKeys$1(e, r) {
|
||
var t = Object.keys(e);
|
||
if (Object.getOwnPropertySymbols) {
|
||
var o = Object.getOwnPropertySymbols(e);
|
||
r && (o = o.filter(function(r2) {
|
||
return Object.getOwnPropertyDescriptor(e, r2).enumerable;
|
||
})), t.push.apply(t, o);
|
||
}
|
||
return t;
|
||
}
|
||
__name(ownKeys$1, "ownKeys$1");
|
||
function _objectSpread$1(e) {
|
||
for (var r = 1; r < arguments.length; r++) {
|
||
var t = null != arguments[r] ? arguments[r] : {};
|
||
r % 2 ? ownKeys$1(Object(t), true).forEach(function(r2) {
|
||
_defineProperty$1(e, r2, t[r2]);
|
||
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$1(Object(t)).forEach(function(r2) {
|
||
Object.defineProperty(e, r2, Object.getOwnPropertyDescriptor(t, r2));
|
||
});
|
||
}
|
||
return e;
|
||
}
|
||
__name(_objectSpread$1, "_objectSpread$1");
|
||
function _defineProperty$1(e, r, t) {
|
||
return (r = _toPropertyKey$1(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: true, configurable: true, writable: true }) : e[r] = t, e;
|
||
}
|
||
__name(_defineProperty$1, "_defineProperty$1");
|
||
function _toPropertyKey$1(t) {
|
||
var i = _toPrimitive$1(t, "string");
|
||
return "symbol" == _typeof$1(i) ? i : i + "";
|
||
}
|
||
__name(_toPropertyKey$1, "_toPropertyKey$1");
|
||
function _toPrimitive$1(t, r) {
|
||
if ("object" != _typeof$1(t) || !t) return t;
|
||
var e = t[Symbol.toPrimitive];
|
||
if (void 0 !== e) {
|
||
var i = e.call(t, r || "default");
|
||
if ("object" != _typeof$1(i)) return i;
|
||
throw new TypeError("@@toPrimitive must return a primitive value.");
|
||
}
|
||
return ("string" === r ? String : Number)(t);
|
||
}
|
||
__name(_toPrimitive$1, "_toPrimitive$1");
|
||
var _hoisted_1$e = ["aria-label"];
|
||
function render$1$3(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _directive_ripple = resolveDirective("ripple");
|
||
return openBlock(), createElementBlock("div", mergeProps({
|
||
"class": [_ctx.cx("message"), $props.message.styleClass],
|
||
role: "alert",
|
||
"aria-live": "assertive",
|
||
"aria-atomic": "true"
|
||
}, _ctx.ptm("message")), [$props.templates.container ? (openBlock(), createBlock(resolveDynamicComponent($props.templates.container), {
|
||
key: 0,
|
||
message: $props.message,
|
||
closeCallback: $options.onCloseClick
|
||
}, null, 8, ["message", "closeCallback"])) : (openBlock(), createElementBlock("div", mergeProps({
|
||
key: 1,
|
||
"class": [_ctx.cx("messageContent"), $props.message.contentStyleClass]
|
||
}, _ctx.ptm("messageContent")), [!$props.templates.message ? (openBlock(), createElementBlock(Fragment, {
|
||
key: 0
|
||
}, [(openBlock(), createBlock(resolveDynamicComponent($props.templates.messageicon ? $props.templates.messageicon : $props.templates.icon ? $props.templates.icon : $options.iconComponent && $options.iconComponent.name ? $options.iconComponent : "span"), mergeProps({
|
||
"class": _ctx.cx("messageIcon")
|
||
}, _ctx.ptm("messageIcon")), null, 16, ["class"])), createBaseVNode("div", mergeProps({
|
||
"class": _ctx.cx("messageText")
|
||
}, _ctx.ptm("messageText")), [createBaseVNode("span", mergeProps({
|
||
"class": _ctx.cx("summary")
|
||
}, _ctx.ptm("summary")), toDisplayString($props.message.summary), 17), createBaseVNode("div", mergeProps({
|
||
"class": _ctx.cx("detail")
|
||
}, _ctx.ptm("detail")), toDisplayString($props.message.detail), 17)], 16)], 64)) : (openBlock(), createBlock(resolveDynamicComponent($props.templates.message), {
|
||
key: 1,
|
||
message: $props.message
|
||
}, null, 8, ["message"])), $props.message.closable !== false ? (openBlock(), createElementBlock("div", normalizeProps(mergeProps({
|
||
key: 2
|
||
}, _ctx.ptm("buttonContainer"))), [withDirectives((openBlock(), createElementBlock("button", mergeProps({
|
||
"class": _ctx.cx("closeButton"),
|
||
type: "button",
|
||
"aria-label": $options.closeAriaLabel,
|
||
onClick: _cache[0] || (_cache[0] = function() {
|
||
return $options.onCloseClick && $options.onCloseClick.apply($options, arguments);
|
||
}),
|
||
autofocus: ""
|
||
}, _objectSpread$1(_objectSpread$1({}, $props.closeButtonProps), _ctx.ptm("closeButton"))), [(openBlock(), createBlock(resolveDynamicComponent($props.templates.closeicon || "TimesIcon"), mergeProps({
|
||
"class": [_ctx.cx("closeIcon"), $props.closeIcon]
|
||
}, _ctx.ptm("closeIcon")), null, 16, ["class"]))], 16, _hoisted_1$e)), [[_directive_ripple]])], 16)) : createCommentVNode("", true)], 16))], 16);
|
||
}
|
||
__name(render$1$3, "render$1$3");
|
||
script$1$4.render = render$1$3;
|
||
function _toConsumableArray(r) {
|
||
return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread();
|
||
}
|
||
__name(_toConsumableArray, "_toConsumableArray");
|
||
function _nonIterableSpread() {
|
||
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
||
}
|
||
__name(_nonIterableSpread, "_nonIterableSpread");
|
||
function _unsupportedIterableToArray(r, a) {
|
||
if (r) {
|
||
if ("string" == typeof r) return _arrayLikeToArray(r, a);
|
||
var t = {}.toString.call(r).slice(8, -1);
|
||
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
|
||
}
|
||
}
|
||
__name(_unsupportedIterableToArray, "_unsupportedIterableToArray");
|
||
function _iterableToArray(r) {
|
||
if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r);
|
||
}
|
||
__name(_iterableToArray, "_iterableToArray");
|
||
function _arrayWithoutHoles(r) {
|
||
if (Array.isArray(r)) return _arrayLikeToArray(r);
|
||
}
|
||
__name(_arrayWithoutHoles, "_arrayWithoutHoles");
|
||
function _arrayLikeToArray(r, a) {
|
||
(null == a || a > r.length) && (a = r.length);
|
||
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
|
||
return n;
|
||
}
|
||
__name(_arrayLikeToArray, "_arrayLikeToArray");
|
||
var messageIdx = 0;
|
||
var script$6 = {
|
||
name: "Toast",
|
||
"extends": script$2$2,
|
||
inheritAttrs: false,
|
||
emits: ["close", "life-end"],
|
||
data: /* @__PURE__ */ __name(function data5() {
|
||
return {
|
||
messages: []
|
||
};
|
||
}, "data"),
|
||
styleElement: null,
|
||
mounted: /* @__PURE__ */ __name(function mounted5() {
|
||
ToastEventBus.on("add", this.onAdd);
|
||
ToastEventBus.on("remove", this.onRemove);
|
||
ToastEventBus.on("remove-group", this.onRemoveGroup);
|
||
ToastEventBus.on("remove-all-groups", this.onRemoveAllGroups);
|
||
if (this.breakpoints) {
|
||
this.createStyle();
|
||
}
|
||
}, "mounted"),
|
||
beforeUnmount: /* @__PURE__ */ __name(function beforeUnmount5() {
|
||
this.destroyStyle();
|
||
if (this.$refs.container && this.autoZIndex) {
|
||
ZIndex.clear(this.$refs.container);
|
||
}
|
||
ToastEventBus.off("add", this.onAdd);
|
||
ToastEventBus.off("remove", this.onRemove);
|
||
ToastEventBus.off("remove-group", this.onRemoveGroup);
|
||
ToastEventBus.off("remove-all-groups", this.onRemoveAllGroups);
|
||
}, "beforeUnmount"),
|
||
methods: {
|
||
add: /* @__PURE__ */ __name(function add(message2) {
|
||
if (message2.id == null) {
|
||
message2.id = messageIdx++;
|
||
}
|
||
this.messages = [].concat(_toConsumableArray(this.messages), [message2]);
|
||
}, "add"),
|
||
remove: /* @__PURE__ */ __name(function remove(params) {
|
||
var index = this.messages.findIndex(function(m) {
|
||
return m.id === params.message.id;
|
||
});
|
||
if (index !== -1) {
|
||
this.messages.splice(index, 1);
|
||
this.$emit(params.type, {
|
||
message: params.message
|
||
});
|
||
}
|
||
}, "remove"),
|
||
onAdd: /* @__PURE__ */ __name(function onAdd(message2) {
|
||
if (this.group == message2.group) {
|
||
this.add(message2);
|
||
}
|
||
}, "onAdd"),
|
||
onRemove: /* @__PURE__ */ __name(function onRemove(message2) {
|
||
this.remove({
|
||
message: message2,
|
||
type: "close"
|
||
});
|
||
}, "onRemove"),
|
||
onRemoveGroup: /* @__PURE__ */ __name(function onRemoveGroup(group) {
|
||
if (this.group === group) {
|
||
this.messages = [];
|
||
}
|
||
}, "onRemoveGroup"),
|
||
onRemoveAllGroups: /* @__PURE__ */ __name(function onRemoveAllGroups() {
|
||
this.messages = [];
|
||
}, "onRemoveAllGroups"),
|
||
onEnter: /* @__PURE__ */ __name(function onEnter() {
|
||
this.$refs.container.setAttribute(this.attributeSelector, "");
|
||
if (this.autoZIndex) {
|
||
ZIndex.set("modal", this.$refs.container, this.baseZIndex || this.$primevue.config.zIndex.modal);
|
||
}
|
||
}, "onEnter"),
|
||
onLeave: /* @__PURE__ */ __name(function onLeave() {
|
||
var _this = this;
|
||
if (this.$refs.container && this.autoZIndex && isEmpty(this.messages)) {
|
||
setTimeout(function() {
|
||
ZIndex.clear(_this.$refs.container);
|
||
}, 200);
|
||
}
|
||
}, "onLeave"),
|
||
createStyle: /* @__PURE__ */ __name(function createStyle() {
|
||
if (!this.styleElement && !this.isUnstyled) {
|
||
var _this$$primevue;
|
||
this.styleElement = document.createElement("style");
|
||
this.styleElement.type = "text/css";
|
||
setAttribute(this.styleElement, "nonce", (_this$$primevue = this.$primevue) === null || _this$$primevue === void 0 || (_this$$primevue = _this$$primevue.config) === null || _this$$primevue === void 0 || (_this$$primevue = _this$$primevue.csp) === null || _this$$primevue === void 0 ? void 0 : _this$$primevue.nonce);
|
||
document.head.appendChild(this.styleElement);
|
||
var innerHTML = "";
|
||
for (var breakpoint in this.breakpoints) {
|
||
var breakpointStyle = "";
|
||
for (var styleProp in this.breakpoints[breakpoint]) {
|
||
breakpointStyle += styleProp + ":" + this.breakpoints[breakpoint][styleProp] + "!important;";
|
||
}
|
||
innerHTML += "\n @media screen and (max-width: ".concat(breakpoint, ") {\n .p-toast[").concat(this.attributeSelector, "] {\n ").concat(breakpointStyle, "\n }\n }\n ");
|
||
}
|
||
this.styleElement.innerHTML = innerHTML;
|
||
}
|
||
}, "createStyle"),
|
||
destroyStyle: /* @__PURE__ */ __name(function destroyStyle() {
|
||
if (this.styleElement) {
|
||
document.head.removeChild(this.styleElement);
|
||
this.styleElement = null;
|
||
}
|
||
}, "destroyStyle")
|
||
},
|
||
computed: {
|
||
attributeSelector: /* @__PURE__ */ __name(function attributeSelector() {
|
||
return UniqueComponentId();
|
||
}, "attributeSelector")
|
||
},
|
||
components: {
|
||
ToastMessage: script$1$4,
|
||
Portal: script$m
|
||
}
|
||
};
|
||
function _typeof$2(o) {
|
||
"@babel/helpers - typeof";
|
||
return _typeof$2 = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(o2) {
|
||
return typeof o2;
|
||
} : function(o2) {
|
||
return o2 && "function" == typeof Symbol && o2.constructor === Symbol && o2 !== Symbol.prototype ? "symbol" : typeof o2;
|
||
}, _typeof$2(o);
|
||
}
|
||
__name(_typeof$2, "_typeof$2");
|
||
function ownKeys$2(e, r) {
|
||
var t = Object.keys(e);
|
||
if (Object.getOwnPropertySymbols) {
|
||
var o = Object.getOwnPropertySymbols(e);
|
||
r && (o = o.filter(function(r2) {
|
||
return Object.getOwnPropertyDescriptor(e, r2).enumerable;
|
||
})), t.push.apply(t, o);
|
||
}
|
||
return t;
|
||
}
|
||
__name(ownKeys$2, "ownKeys$2");
|
||
function _objectSpread$2(e) {
|
||
for (var r = 1; r < arguments.length; r++) {
|
||
var t = null != arguments[r] ? arguments[r] : {};
|
||
r % 2 ? ownKeys$2(Object(t), true).forEach(function(r2) {
|
||
_defineProperty$2(e, r2, t[r2]);
|
||
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$2(Object(t)).forEach(function(r2) {
|
||
Object.defineProperty(e, r2, Object.getOwnPropertyDescriptor(t, r2));
|
||
});
|
||
}
|
||
return e;
|
||
}
|
||
__name(_objectSpread$2, "_objectSpread$2");
|
||
function _defineProperty$2(e, r, t) {
|
||
return (r = _toPropertyKey$2(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: true, configurable: true, writable: true }) : e[r] = t, e;
|
||
}
|
||
__name(_defineProperty$2, "_defineProperty$2");
|
||
function _toPropertyKey$2(t) {
|
||
var i = _toPrimitive$2(t, "string");
|
||
return "symbol" == _typeof$2(i) ? i : i + "";
|
||
}
|
||
__name(_toPropertyKey$2, "_toPropertyKey$2");
|
||
function _toPrimitive$2(t, r) {
|
||
if ("object" != _typeof$2(t) || !t) return t;
|
||
var e = t[Symbol.toPrimitive];
|
||
if (void 0 !== e) {
|
||
var i = e.call(t, r || "default");
|
||
if ("object" != _typeof$2(i)) return i;
|
||
throw new TypeError("@@toPrimitive must return a primitive value.");
|
||
}
|
||
return ("string" === r ? String : Number)(t);
|
||
}
|
||
__name(_toPrimitive$2, "_toPrimitive$2");
|
||
function render$a(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _component_ToastMessage = resolveComponent("ToastMessage");
|
||
var _component_Portal = resolveComponent("Portal");
|
||
return openBlock(), createBlock(_component_Portal, null, {
|
||
"default": withCtx(function() {
|
||
return [createBaseVNode("div", mergeProps({
|
||
ref: "container",
|
||
"class": _ctx.cx("root"),
|
||
style: _ctx.sx("root", true, {
|
||
position: _ctx.position
|
||
})
|
||
}, _ctx.ptmi("root")), [createVNode(TransitionGroup, mergeProps({
|
||
name: "p-toast-message",
|
||
tag: "div",
|
||
onEnter: $options.onEnter,
|
||
onLeave: $options.onLeave
|
||
}, _objectSpread$2({}, _ctx.ptm("transition"))), {
|
||
"default": withCtx(function() {
|
||
return [(openBlock(true), createElementBlock(Fragment, null, renderList($data.messages, function(msg) {
|
||
return openBlock(), createBlock(_component_ToastMessage, {
|
||
key: msg.id,
|
||
message: msg,
|
||
templates: _ctx.$slots,
|
||
closeIcon: _ctx.closeIcon,
|
||
infoIcon: _ctx.infoIcon,
|
||
warnIcon: _ctx.warnIcon,
|
||
errorIcon: _ctx.errorIcon,
|
||
successIcon: _ctx.successIcon,
|
||
closeButtonProps: _ctx.closeButtonProps,
|
||
unstyled: _ctx.unstyled,
|
||
onClose: _cache[0] || (_cache[0] = function($event) {
|
||
return $options.remove($event);
|
||
}),
|
||
pt: _ctx.pt
|
||
}, null, 8, ["message", "templates", "closeIcon", "infoIcon", "warnIcon", "errorIcon", "successIcon", "closeButtonProps", "unstyled", "pt"]);
|
||
}), 128))];
|
||
}),
|
||
_: 1
|
||
}, 16, ["onEnter", "onLeave"])], 16)];
|
||
}),
|
||
_: 1
|
||
});
|
||
}
|
||
__name(render$a, "render$a");
|
||
script$6.render = render$a;
|
||
const _sfc_main$a = /* @__PURE__ */ defineComponent({
|
||
__name: "GlobalToast",
|
||
setup(__props) {
|
||
const toast = useToast();
|
||
const toastStore = useToastStore();
|
||
const settingStore = useSettingStore();
|
||
watch(
|
||
() => toastStore.messagesToAdd,
|
||
(newMessages) => {
|
||
if (newMessages.length === 0) {
|
||
return;
|
||
}
|
||
newMessages.forEach((message2) => {
|
||
toast.add(message2);
|
||
});
|
||
toastStore.messagesToAdd = [];
|
||
},
|
||
{ deep: true }
|
||
);
|
||
watch(
|
||
() => toastStore.messagesToRemove,
|
||
(messagesToRemove) => {
|
||
if (messagesToRemove.length === 0) {
|
||
return;
|
||
}
|
||
messagesToRemove.forEach((message2) => {
|
||
toast.remove(message2);
|
||
});
|
||
toastStore.messagesToRemove = [];
|
||
},
|
||
{ deep: true }
|
||
);
|
||
watch(
|
||
() => toastStore.removeAllRequested,
|
||
(requested) => {
|
||
if (requested) {
|
||
toast.removeAllGroups();
|
||
toastStore.removeAllRequested = false;
|
||
}
|
||
}
|
||
);
|
||
function updateToastPosition() {
|
||
const styleElement = document.getElementById("dynamic-toast-style") || createStyleElement();
|
||
const rect = document.querySelector(".graph-canvas-container").getBoundingClientRect();
|
||
styleElement.textContent = `
|
||
.p-toast.p-component.p-toast-top-right {
|
||
top: ${rect.top + 20}px !important;
|
||
right: ${window.innerWidth - (rect.left + rect.width) + 20}px !important;
|
||
}
|
||
`;
|
||
}
|
||
__name(updateToastPosition, "updateToastPosition");
|
||
function createStyleElement() {
|
||
const style = document.createElement("style");
|
||
style.id = "dynamic-toast-style";
|
||
document.head.appendChild(style);
|
||
return style;
|
||
}
|
||
__name(createStyleElement, "createStyleElement");
|
||
watch(
|
||
() => settingStore.get("Comfy.UseNewMenu"),
|
||
() => nextTick(updateToastPosition),
|
||
{ immediate: true }
|
||
);
|
||
watch(
|
||
() => settingStore.get("Comfy.Sidebar.Location"),
|
||
() => nextTick(updateToastPosition),
|
||
{ immediate: true }
|
||
);
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createBlock(unref(script$6));
|
||
};
|
||
}
|
||
});
|
||
const _sfc_main$9 = /* @__PURE__ */ defineComponent({
|
||
__name: "UnloadWindowConfirmDialog",
|
||
setup(__props) {
|
||
const settingStore = useSettingStore();
|
||
const handleBeforeUnload = /* @__PURE__ */ __name((event) => {
|
||
if (settingStore.get("Comfy.Window.UnloadConfirmation")) {
|
||
event.preventDefault();
|
||
return true;
|
||
}
|
||
return void 0;
|
||
}, "handleBeforeUnload");
|
||
onMounted(() => {
|
||
window.addEventListener("beforeunload", handleBeforeUnload);
|
||
});
|
||
onBeforeUnmount(() => {
|
||
window.removeEventListener("beforeunload", handleBeforeUnload);
|
||
});
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock("div");
|
||
};
|
||
}
|
||
});
|
||
const DEFAULT_TITLE = "ComfyUI";
|
||
const TITLE_SUFFIX = " - ComfyUI";
|
||
const _sfc_main$8 = /* @__PURE__ */ defineComponent({
|
||
__name: "BrowserTabTitle",
|
||
setup(__props) {
|
||
const executionStore = useExecutionStore();
|
||
const executionText = computed(
|
||
() => executionStore.isIdle ? "" : `[${executionStore.executionProgress}%]`
|
||
);
|
||
const settingStore = useSettingStore();
|
||
const betaMenuEnabled = computed(
|
||
() => settingStore.get("Comfy.UseNewMenu") !== "Disabled"
|
||
);
|
||
const workflowStore = useWorkflowStore();
|
||
const isUnsavedText = computed(
|
||
() => workflowStore.activeWorkflow?.isModified || !workflowStore.activeWorkflow?.isPersisted ? " *" : ""
|
||
);
|
||
const workflowNameText = computed(() => {
|
||
const workflowName = workflowStore.activeWorkflow?.filename;
|
||
return workflowName ? isUnsavedText.value + workflowName + TITLE_SUFFIX : DEFAULT_TITLE;
|
||
});
|
||
const nodeExecutionTitle = computed(
|
||
() => executionStore.executingNode && executionStore.executingNodeProgress ? `${executionText.value}[${executionStore.executingNodeProgress}%] ${executionStore.executingNode.type}` : ""
|
||
);
|
||
const workflowTitle = computed(
|
||
() => executionText.value + (betaMenuEnabled.value ? workflowNameText.value : DEFAULT_TITLE)
|
||
);
|
||
const title = computed(() => nodeExecutionTitle.value || workflowTitle.value);
|
||
useTitle(title);
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock("div");
|
||
};
|
||
}
|
||
});
|
||
const _withScopeId$3 = /* @__PURE__ */ __name((n) => (pushScopeId("data-v-4cb762cb"), n = n(), popScopeId(), n), "_withScopeId$3");
|
||
const _hoisted_1$d = ["onContextmenu", "onMouseup"];
|
||
const _hoisted_2$b = { class: "workflow-label text-sm max-w-[150px] truncate inline-block" };
|
||
const _hoisted_3$9 = { class: "relative" };
|
||
const _hoisted_4$2 = {
|
||
key: 0,
|
||
class: "status-indicator"
|
||
};
|
||
const _sfc_main$7 = /* @__PURE__ */ defineComponent({
|
||
__name: "WorkflowTabs",
|
||
props: {
|
||
class: {}
|
||
},
|
||
setup(__props) {
|
||
const props = __props;
|
||
const { t } = useI18n();
|
||
const workspaceStore = useWorkspaceStore();
|
||
const workflowStore = useWorkflowStore();
|
||
const rightClickedTab = ref(null);
|
||
const menu = ref();
|
||
const showContextMenu = /* @__PURE__ */ __name((event, option2) => {
|
||
rightClickedTab.value = option2;
|
||
menu.value.show(event);
|
||
}, "showContextMenu");
|
||
const workflowToOption = /* @__PURE__ */ __name((workflow) => ({
|
||
value: workflow.path,
|
||
workflow
|
||
}), "workflowToOption");
|
||
const options = computed(
|
||
() => workflowStore.openWorkflows.map(workflowToOption)
|
||
);
|
||
const selectedWorkflow = computed(
|
||
() => workflowStore.activeWorkflow ? workflowToOption(workflowStore.activeWorkflow) : null
|
||
);
|
||
const onWorkflowChange = /* @__PURE__ */ __name((option2) => {
|
||
if (!option2) {
|
||
return;
|
||
}
|
||
if (selectedWorkflow.value?.value === option2.value) {
|
||
return;
|
||
}
|
||
workflowService.openWorkflow(option2.workflow);
|
||
}, "onWorkflowChange");
|
||
const closeWorkflows = /* @__PURE__ */ __name(async (options2) => {
|
||
for (const opt of options2) {
|
||
if (!await workflowService.closeWorkflow(opt.workflow, {
|
||
warnIfUnsaved: !workspaceStore.shiftDown
|
||
})) {
|
||
break;
|
||
}
|
||
}
|
||
}, "closeWorkflows");
|
||
const onCloseWorkflow = /* @__PURE__ */ __name((option2) => {
|
||
closeWorkflows([option2]);
|
||
}, "onCloseWorkflow");
|
||
const contextMenuItems = computed(() => {
|
||
const tab = rightClickedTab.value;
|
||
if (!tab) return [];
|
||
const index = options.value.findIndex((v) => v.workflow === tab.workflow);
|
||
return [
|
||
{
|
||
label: t("tabMenu.duplicateTab"),
|
||
command: /* @__PURE__ */ __name(() => {
|
||
workflowService.duplicateWorkflow(tab.workflow);
|
||
}, "command")
|
||
},
|
||
{
|
||
separator: true
|
||
},
|
||
{
|
||
label: t("tabMenu.closeTab"),
|
||
command: /* @__PURE__ */ __name(() => onCloseWorkflow(tab), "command")
|
||
},
|
||
{
|
||
label: t("tabMenu.closeTabsToLeft"),
|
||
command: /* @__PURE__ */ __name(() => closeWorkflows(options.value.slice(0, index)), "command"),
|
||
disabled: index <= 0
|
||
},
|
||
{
|
||
label: t("tabMenu.closeTabsToRight"),
|
||
command: /* @__PURE__ */ __name(() => closeWorkflows(options.value.slice(index + 1)), "command"),
|
||
disabled: index === options.value.length - 1
|
||
},
|
||
{
|
||
label: t("tabMenu.closeOtherTabs"),
|
||
command: /* @__PURE__ */ __name(() => closeWorkflows([
|
||
...options.value.slice(index + 1),
|
||
...options.value.slice(0, index)
|
||
]), "command"),
|
||
disabled: options.value.length <= 1
|
||
}
|
||
];
|
||
});
|
||
const commandStore = useCommandStore();
|
||
return (_ctx, _cache) => {
|
||
const _directive_tooltip = resolveDirective("tooltip");
|
||
return openBlock(), createElementBlock(Fragment, null, [
|
||
createVNode(unref(script$x), {
|
||
class: normalizeClass(["workflow-tabs bg-transparent inline", props.class]),
|
||
modelValue: selectedWorkflow.value,
|
||
"onUpdate:modelValue": onWorkflowChange,
|
||
options: options.value,
|
||
optionLabel: "label",
|
||
dataKey: "value"
|
||
}, {
|
||
option: withCtx(({ option: option2 }) => [
|
||
createBaseVNode("div", {
|
||
class: "flex p-2 gap-2",
|
||
onContextmenu: /* @__PURE__ */ __name(($event) => showContextMenu($event, option2), "onContextmenu"),
|
||
onMouseup: withModifiers(($event) => onCloseWorkflow(option2), ["middle"])
|
||
}, [
|
||
withDirectives((openBlock(), createElementBlock("span", _hoisted_2$b, [
|
||
createTextVNode(toDisplayString(option2.workflow.filename), 1)
|
||
])), [
|
||
[
|
||
_directive_tooltip,
|
||
option2.workflow.key,
|
||
void 0,
|
||
{ bottom: true }
|
||
]
|
||
]),
|
||
createBaseVNode("div", _hoisted_3$9, [
|
||
!unref(workspaceStore).shiftDown && (option2.workflow.isModified || !option2.workflow.isPersisted) ? (openBlock(), createElementBlock("span", _hoisted_4$2, "•")) : createCommentVNode("", true),
|
||
createVNode(unref(script$f), {
|
||
class: "close-button p-0 w-auto",
|
||
icon: "pi pi-times",
|
||
text: "",
|
||
severity: "secondary",
|
||
size: "small",
|
||
onClick: withModifiers(($event) => onCloseWorkflow(option2), ["stop"])
|
||
}, null, 8, ["onClick"])
|
||
])
|
||
], 40, _hoisted_1$d)
|
||
]),
|
||
_: 1
|
||
}, 8, ["class", "modelValue", "options"]),
|
||
createVNode(unref(script$f), {
|
||
class: "new-blank-workflow-button",
|
||
icon: "pi pi-plus",
|
||
text: "",
|
||
severity: "secondary",
|
||
onClick: _cache[0] || (_cache[0] = () => unref(commandStore).execute("Comfy.NewBlankWorkflow"))
|
||
}),
|
||
createVNode(unref(script$y), {
|
||
ref_key: "menu",
|
||
ref: menu,
|
||
model: contextMenuItems.value
|
||
}, null, 8, ["model"])
|
||
], 64);
|
||
};
|
||
}
|
||
});
|
||
const WorkflowTabs = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["__scopeId", "data-v-4cb762cb"]]);
|
||
var theme$3 = /* @__PURE__ */ __name(function theme6(_ref) {
|
||
var dt = _ref.dt;
|
||
return "\n.p-menubar {\n display: flex;\n align-items: center;\n background: ".concat(dt("menubar.background"), ";\n border: 1px solid ").concat(dt("menubar.border.color"), ";\n border-radius: ").concat(dt("menubar.border.radius"), ";\n color: ").concat(dt("menubar.color"), ";\n padding: ").concat(dt("menubar.padding"), ";\n gap: ").concat(dt("menubar.gap"), ";\n}\n\n.p-menubar-start,\n.p-megamenu-end {\n display: flex;\n align-items: center;\n}\n\n.p-menubar-root-list,\n.p-menubar-submenu {\n display: flex;\n margin: 0;\n padding: 0;\n list-style: none;\n outline: 0 none;\n}\n\n.p-menubar-root-list {\n align-items: center;\n flex-wrap: wrap;\n gap: ").concat(dt("menubar.gap"), ";\n}\n\n.p-menubar-root-list > .p-menubar-item > .p-menubar-item-content {\n border-radius: ").concat(dt("menubar.base.item.border.radius"), ";\n}\n\n.p-menubar-root-list > .p-menubar-item > .p-menubar-item-content > .p-menubar-item-link {\n padding: ").concat(dt("menubar.base.item.padding"), ";\n}\n\n.p-menubar-item-content {\n transition: background ").concat(dt("menubar.transition.duration"), ", color ").concat(dt("menubar.transition.duration"), ";\n border-radius: ").concat(dt("menubar.item.border.radius"), ";\n color: ").concat(dt("menubar.item.color"), ";\n}\n\n.p-menubar-item-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n color: inherit;\n padding: ").concat(dt("menubar.item.padding"), ";\n gap: ").concat(dt("menubar.item.gap"), ";\n user-select: none;\n outline: 0 none;\n}\n\n.p-menubar-item-label {\n line-height: 1;\n}\n\n.p-menubar-item-icon {\n color: ").concat(dt("menubar.item.icon.color"), ";\n}\n\n.p-menubar-submenu-icon {\n color: ").concat(dt("menubar.submenu.icon.color"), ";\n margin-left: auto;\n font-size: ").concat(dt("menubar.submenu.icon.size"), ";\n width: ").concat(dt("menubar.submenu.icon.size"), ";\n height: ").concat(dt("menubar.submenu.icon.size"), ";\n}\n\n.p-menubar-item.p-focus > .p-menubar-item-content {\n color: ").concat(dt("menubar.item.focus.color"), ";\n background: ").concat(dt("menubar.item.focus.background"), ";\n}\n\n.p-menubar-item.p-focus > .p-menubar-item-content .p-menubar-item-icon {\n color: ").concat(dt("menubar.item.icon.focus.color"), ";\n}\n\n.p-menubar-item.p-focus > .p-menubar-item-content .p-menubar-submenu-icon {\n color: ").concat(dt("menubar.submenu.icon.focus.color"), ";\n}\n\n.p-menubar-item:not(.p-disabled) > .p-menubar-item-content:hover {\n color: ").concat(dt("menubar.item.focus.color"), ";\n background: ").concat(dt("menubar.item.focus.background"), ";\n}\n\n.p-menubar-item:not(.p-disabled) > .p-menubar-item-content:hover .p-menubar-item-icon {\n color: ").concat(dt("menubar.item.icon.focus.color"), ";\n}\n\n.p-menubar-item:not(.p-disabled) > .p-menubar-item-content:hover .p-menubar-submenu-icon {\n color: ").concat(dt("menubar.submenu.icon.focus.color"), ";\n}\n\n.p-menubar-item-active > .p-menubar-item-content {\n color: ").concat(dt("menubar.item.active.color"), ";\n background: ").concat(dt("menubar.item.active.background"), ";\n}\n\n.p-menubar-item-active > .p-menubar-item-content .p-menubar-item-icon {\n color: ").concat(dt("menubar.item.icon.active.color"), ";\n}\n\n.p-menubar-item-active > .p-menubar-item-content .p-menubar-submenu-icon {\n color: ").concat(dt("menubar.submenu.icon.active.color"), ";\n}\n\n.p-menubar-submenu {\n display: none;\n position: absolute;\n min-width: 12.5rem;\n z-index: 1;\n background: ").concat(dt("menubar.submenu.background"), ";\n border: 1px solid ").concat(dt("menubar.submenu.border.color"), ";\n border-radius: ").concat(dt("menubar.border.radius"), ";\n box-shadow: ").concat(dt("menubar.submenu.shadow"), ";\n color: ").concat(dt("menubar.submenu.color"), ";\n flex-direction: column;\n padding: ").concat(dt("menubar.submenu.padding"), ";\n gap: ").concat(dt("menubar.submenu.gap"), ";\n}\n\n.p-menubar-submenu .p-menubar-separator {\n border-top: 1px solid ").concat(dt("menubar.separator.border.color"), ";\n}\n\n.p-menubar-submenu .p-menubar-item {\n position: relative;\n}\n\n .p-menubar-submenu > .p-menubar-item-active > .p-menubar-submenu {\n display: block;\n left: 100%;\n top: 0;\n}\n\n.p-menubar-end {\n margin-left: auto;\n align-self: center;\n}\n\n.p-menubar-button {\n display: none;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n width: ").concat(dt("menubar.mobile.button.size"), ";\n height: ").concat(dt("menubar.mobile.button.size"), ";\n position: relative;\n color: ").concat(dt("menubar.mobile.button.color"), ";\n border: 0 none;\n background: transparent;\n border-radius: ").concat(dt("menubar.mobile.button.border.radius"), ";\n transition: background ").concat(dt("menubar.transition.duration"), ", color ").concat(dt("menubar.transition.duration"), ", outline-color ").concat(dt("menubar.transition.duration"), ";\n outline-color: transparent;\n}\n\n.p-menubar-button:hover {\n color: ").concat(dt("menubar.mobile.button.hover.color"), ";\n background: ").concat(dt("menubar.mobile.button.hover.background"), ";\n}\n\n.p-menubar-button:focus-visible {\n box-shadow: ").concat(dt("menubar.mobile.button.focus.ring.shadow"), ";\n outline: ").concat(dt("menubar.mobile.button.focus.ring.width"), " ").concat(dt("menubar.mobile.button.focus.ring.style"), " ").concat(dt("menubar.mobile.button.focus.ring.color"), ";\n outline-offset: ").concat(dt("menubar.mobile.button.focus.ring.offset"), ";\n}\n\n.p-menubar-mobile {\n position: relative;\n}\n\n.p-menubar-mobile .p-menubar-button {\n display: flex;\n}\n\n.p-menubar-mobile .p-menubar-root-list {\n position: absolute;\n display: none;\n width: 100%;\n padding: ").concat(dt("menubar.submenu.padding"), ";\n background: ").concat(dt("menubar.submenu.background"), ";\n border: 1px solid ").concat(dt("menubar.submenu.border.color"), ";\n box-shadow: ").concat(dt("menubar.submenu.shadow"), ";\n}\n\n.p-menubar-mobile .p-menubar-root-list > .p-menubar-item > .p-menubar-item-content {\n border-radius: ").concat(dt("menubar.item.border.radius"), ";\n}\n\n.p-menubar-mobile .p-menubar-root-list > .p-menubar-item > .p-menubar-item-content > .p-menubar-item-link {\n padding: ").concat(dt("menubar.item.padding"), ";\n}\n\n.p-menubar-mobile-active .p-menubar-root-list {\n display: flex;\n flex-direction: column;\n top: 100%;\n left: 0;\n z-index: 1;\n}\n\n.p-menubar-mobile .p-menubar-root-list .p-menubar-item {\n width: 100%;\n position: static;\n}\n\n.p-menubar-mobile .p-menubar-root-list .p-menubar-separator {\n border-top: 1px solid ").concat(dt("menubar.separator.border.color"), ";\n}\n\n.p-menubar-mobile .p-menubar-root-list > .p-menubar-item > .p-menubar-item-content .p-menubar-submenu-icon {\n margin-left: auto;\n transition: transform 0.2s;\n}\n\n.p-menubar-mobile .p-menubar-root-list > .p-menubar-item-active > .p-menubar-item-content .p-menubar-submenu-icon {\n transform: rotate(-180deg);\n}\n\n.p-menubar-mobile .p-menubar-submenu .p-menubar-submenu-icon {\n transition: transform 0.2s;\n transform: rotate(90deg);\n}\n\n.p-menubar-mobile .p-menubar-item-active > .p-menubar-item-content .p-menubar-submenu-icon {\n transform: rotate(-90deg);\n}\n\n.p-menubar-mobile .p-menubar-submenu {\n width: 100%;\n position: static;\n box-shadow: none;\n border: 0 none;\n padding-left: ").concat(dt("menubar.submenu.mobile.indent"), ";\n}\n");
|
||
}, "theme");
|
||
var inlineStyles$1 = {
|
||
submenu: /* @__PURE__ */ __name(function submenu(_ref2) {
|
||
var instance = _ref2.instance, processedItem = _ref2.processedItem;
|
||
return {
|
||
display: instance.isItemActive(processedItem) ? "flex" : "none"
|
||
};
|
||
}, "submenu")
|
||
};
|
||
var classes$3 = {
|
||
root: /* @__PURE__ */ __name(function root8(_ref3) {
|
||
var instance = _ref3.instance;
|
||
return ["p-menubar p-component", {
|
||
"p-menubar-mobile": instance.queryMatches,
|
||
"p-menubar-mobile-active": instance.mobileActive
|
||
}];
|
||
}, "root"),
|
||
start: "p-menubar-start",
|
||
button: "p-menubar-button",
|
||
rootList: "p-menubar-root-list",
|
||
item: /* @__PURE__ */ __name(function item(_ref4) {
|
||
var instance = _ref4.instance, processedItem = _ref4.processedItem;
|
||
return ["p-menubar-item", {
|
||
"p-menubar-item-active": instance.isItemActive(processedItem),
|
||
"p-focus": instance.isItemFocused(processedItem),
|
||
"p-disabled": instance.isItemDisabled(processedItem)
|
||
}];
|
||
}, "item"),
|
||
itemContent: "p-menubar-item-content",
|
||
itemLink: "p-menubar-item-link",
|
||
itemIcon: "p-menubar-item-icon",
|
||
itemLabel: "p-menubar-item-label",
|
||
submenuIcon: "p-menubar-submenu-icon",
|
||
submenu: "p-menubar-submenu",
|
||
separator: "p-menubar-separator",
|
||
end: "p-menubar-end"
|
||
};
|
||
var MenubarStyle = BaseStyle.extend({
|
||
name: "menubar",
|
||
theme: theme$3,
|
||
classes: classes$3,
|
||
inlineStyles: inlineStyles$1
|
||
});
|
||
var script$2$1 = {
|
||
name: "BaseMenubar",
|
||
"extends": script$g,
|
||
props: {
|
||
model: {
|
||
type: Array,
|
||
"default": null
|
||
},
|
||
buttonProps: {
|
||
type: null,
|
||
"default": null
|
||
},
|
||
breakpoint: {
|
||
type: String,
|
||
"default": "960px"
|
||
},
|
||
ariaLabelledby: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
ariaLabel: {
|
||
type: String,
|
||
"default": null
|
||
}
|
||
},
|
||
style: MenubarStyle,
|
||
provide: /* @__PURE__ */ __name(function provide10() {
|
||
return {
|
||
$pcMenubar: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script$1$3 = {
|
||
name: "MenubarSub",
|
||
hostName: "Menubar",
|
||
"extends": script$g,
|
||
emits: ["item-mouseenter", "item-click", "item-mousemove"],
|
||
props: {
|
||
items: {
|
||
type: Array,
|
||
"default": null
|
||
},
|
||
root: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
popup: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
mobileActive: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
templates: {
|
||
type: Object,
|
||
"default": null
|
||
},
|
||
level: {
|
||
type: Number,
|
||
"default": 0
|
||
},
|
||
menuId: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
focusedItemId: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
activeItemPath: {
|
||
type: Object,
|
||
"default": null
|
||
}
|
||
},
|
||
list: null,
|
||
methods: {
|
||
getItemId: /* @__PURE__ */ __name(function getItemId(processedItem) {
|
||
return "".concat(this.menuId, "_").concat(processedItem.key);
|
||
}, "getItemId"),
|
||
getItemKey: /* @__PURE__ */ __name(function getItemKey(processedItem) {
|
||
return this.getItemId(processedItem);
|
||
}, "getItemKey"),
|
||
getItemProp: /* @__PURE__ */ __name(function getItemProp(processedItem, name, params) {
|
||
return processedItem && processedItem.item ? resolve(processedItem.item[name], params) : void 0;
|
||
}, "getItemProp"),
|
||
getItemLabel: /* @__PURE__ */ __name(function getItemLabel(processedItem) {
|
||
return this.getItemProp(processedItem, "label");
|
||
}, "getItemLabel"),
|
||
getItemLabelId: /* @__PURE__ */ __name(function getItemLabelId(processedItem) {
|
||
return "".concat(this.menuId, "_").concat(processedItem.key, "_label");
|
||
}, "getItemLabelId"),
|
||
getPTOptions: /* @__PURE__ */ __name(function getPTOptions4(processedItem, index, key) {
|
||
return this.ptm(key, {
|
||
context: {
|
||
item: processedItem.item,
|
||
index,
|
||
active: this.isItemActive(processedItem),
|
||
focused: this.isItemFocused(processedItem),
|
||
disabled: this.isItemDisabled(processedItem),
|
||
level: this.level
|
||
}
|
||
});
|
||
}, "getPTOptions"),
|
||
isItemActive: /* @__PURE__ */ __name(function isItemActive(processedItem) {
|
||
return this.activeItemPath.some(function(path) {
|
||
return path.key === processedItem.key;
|
||
});
|
||
}, "isItemActive"),
|
||
isItemVisible: /* @__PURE__ */ __name(function isItemVisible(processedItem) {
|
||
return this.getItemProp(processedItem, "visible") !== false;
|
||
}, "isItemVisible"),
|
||
isItemDisabled: /* @__PURE__ */ __name(function isItemDisabled(processedItem) {
|
||
return this.getItemProp(processedItem, "disabled");
|
||
}, "isItemDisabled"),
|
||
isItemFocused: /* @__PURE__ */ __name(function isItemFocused(processedItem) {
|
||
return this.focusedItemId === this.getItemId(processedItem);
|
||
}, "isItemFocused"),
|
||
isItemGroup: /* @__PURE__ */ __name(function isItemGroup(processedItem) {
|
||
return isNotEmpty(processedItem.items);
|
||
}, "isItemGroup"),
|
||
onItemClick: /* @__PURE__ */ __name(function onItemClick(event, processedItem) {
|
||
this.getItemProp(processedItem, "command", {
|
||
originalEvent: event,
|
||
item: processedItem.item
|
||
});
|
||
this.$emit("item-click", {
|
||
originalEvent: event,
|
||
processedItem,
|
||
isFocus: true
|
||
});
|
||
}, "onItemClick"),
|
||
onItemMouseEnter: /* @__PURE__ */ __name(function onItemMouseEnter(event, processedItem) {
|
||
this.$emit("item-mouseenter", {
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
}, "onItemMouseEnter"),
|
||
onItemMouseMove: /* @__PURE__ */ __name(function onItemMouseMove(event, processedItem) {
|
||
this.$emit("item-mousemove", {
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
}, "onItemMouseMove"),
|
||
getAriaPosInset: /* @__PURE__ */ __name(function getAriaPosInset2(index) {
|
||
return index - this.calculateAriaSetSize.slice(0, index).length + 1;
|
||
}, "getAriaPosInset"),
|
||
getMenuItemProps: /* @__PURE__ */ __name(function getMenuItemProps(processedItem, index) {
|
||
return {
|
||
action: mergeProps({
|
||
"class": this.cx("itemLink"),
|
||
tabindex: -1,
|
||
"aria-hidden": true
|
||
}, this.getPTOptions(processedItem, index, "itemLink")),
|
||
icon: mergeProps({
|
||
"class": [this.cx("itemIcon"), this.getItemProp(processedItem, "icon")]
|
||
}, this.getPTOptions(processedItem, index, "itemIcon")),
|
||
label: mergeProps({
|
||
"class": this.cx("itemLabel")
|
||
}, this.getPTOptions(processedItem, index, "itemLabel")),
|
||
submenuicon: mergeProps({
|
||
"class": this.cx("submenuIcon")
|
||
}, this.getPTOptions(processedItem, index, "submenuIcon"))
|
||
};
|
||
}, "getMenuItemProps")
|
||
},
|
||
computed: {
|
||
calculateAriaSetSize: /* @__PURE__ */ __name(function calculateAriaSetSize() {
|
||
var _this = this;
|
||
return this.items.filter(function(processedItem) {
|
||
return _this.isItemVisible(processedItem) && _this.getItemProp(processedItem, "separator");
|
||
});
|
||
}, "calculateAriaSetSize"),
|
||
getAriaSetSize: /* @__PURE__ */ __name(function getAriaSetSize() {
|
||
var _this2 = this;
|
||
return this.items.filter(function(processedItem) {
|
||
return _this2.isItemVisible(processedItem) && !_this2.getItemProp(processedItem, "separator");
|
||
}).length;
|
||
}, "getAriaSetSize")
|
||
},
|
||
components: {
|
||
AngleRightIcon: script$z,
|
||
AngleDownIcon: script$A
|
||
},
|
||
directives: {
|
||
ripple: Ripple
|
||
}
|
||
};
|
||
var _hoisted_1$1$2 = ["id", "aria-label", "aria-disabled", "aria-expanded", "aria-haspopup", "aria-level", "aria-setsize", "aria-posinset", "data-p-active", "data-p-focused", "data-p-disabled"];
|
||
var _hoisted_2$a = ["onClick", "onMouseenter", "onMousemove"];
|
||
var _hoisted_3$8 = ["href", "target"];
|
||
var _hoisted_4$1 = ["id"];
|
||
var _hoisted_5$1 = ["id"];
|
||
function render$1$2(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _component_MenubarSub = resolveComponent("MenubarSub", true);
|
||
var _directive_ripple = resolveDirective("ripple");
|
||
return openBlock(), createElementBlock("ul", mergeProps({
|
||
"class": $props.level === 0 ? _ctx.cx("rootList") : _ctx.cx("submenu")
|
||
}, $props.level === 0 ? _ctx.ptm("rootList") : _ctx.ptm("submenu")), [(openBlock(true), createElementBlock(Fragment, null, renderList($props.items, function(processedItem, index) {
|
||
return openBlock(), createElementBlock(Fragment, {
|
||
key: $options.getItemKey(processedItem)
|
||
}, [$options.isItemVisible(processedItem) && !$options.getItemProp(processedItem, "separator") ? (openBlock(), createElementBlock("li", mergeProps({
|
||
key: 0,
|
||
id: $options.getItemId(processedItem),
|
||
style: $options.getItemProp(processedItem, "style"),
|
||
"class": [_ctx.cx("item", {
|
||
processedItem
|
||
}), $options.getItemProp(processedItem, "class")],
|
||
role: "menuitem",
|
||
"aria-label": $options.getItemLabel(processedItem),
|
||
"aria-disabled": $options.isItemDisabled(processedItem) || void 0,
|
||
"aria-expanded": $options.isItemGroup(processedItem) ? $options.isItemActive(processedItem) : void 0,
|
||
"aria-haspopup": $options.isItemGroup(processedItem) && !$options.getItemProp(processedItem, "to") ? "menu" : void 0,
|
||
"aria-level": $props.level + 1,
|
||
"aria-setsize": $options.getAriaSetSize,
|
||
"aria-posinset": $options.getAriaPosInset(index),
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "item"), {
|
||
"data-p-active": $options.isItemActive(processedItem),
|
||
"data-p-focused": $options.isItemFocused(processedItem),
|
||
"data-p-disabled": $options.isItemDisabled(processedItem)
|
||
}), [createBaseVNode("div", mergeProps({
|
||
"class": _ctx.cx("itemContent"),
|
||
onClick: /* @__PURE__ */ __name(function onClick2($event) {
|
||
return $options.onItemClick($event, processedItem);
|
||
}, "onClick"),
|
||
onMouseenter: /* @__PURE__ */ __name(function onMouseenter($event) {
|
||
return $options.onItemMouseEnter($event, processedItem);
|
||
}, "onMouseenter"),
|
||
onMousemove: /* @__PURE__ */ __name(function onMousemove($event) {
|
||
return $options.onItemMouseMove($event, processedItem);
|
||
}, "onMousemove"),
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "itemContent")), [!$props.templates.item ? withDirectives((openBlock(), createElementBlock("a", mergeProps({
|
||
key: 0,
|
||
href: $options.getItemProp(processedItem, "url"),
|
||
"class": _ctx.cx("itemLink"),
|
||
target: $options.getItemProp(processedItem, "target"),
|
||
tabindex: "-1",
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "itemLink")), [$props.templates.itemicon ? (openBlock(), createBlock(resolveDynamicComponent($props.templates.itemicon), {
|
||
key: 0,
|
||
item: processedItem.item,
|
||
"class": normalizeClass(_ctx.cx("itemIcon"))
|
||
}, null, 8, ["item", "class"])) : $options.getItemProp(processedItem, "icon") ? (openBlock(), createElementBlock("span", mergeProps({
|
||
key: 1,
|
||
"class": [_ctx.cx("itemIcon"), $options.getItemProp(processedItem, "icon")],
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "itemIcon")), null, 16)) : createCommentVNode("", true), createBaseVNode("span", mergeProps({
|
||
id: $options.getItemLabelId(processedItem),
|
||
"class": _ctx.cx("itemLabel"),
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "itemLabel")), toDisplayString($options.getItemLabel(processedItem)), 17, _hoisted_4$1), $options.getItemProp(processedItem, "items") ? (openBlock(), createElementBlock(Fragment, {
|
||
key: 2
|
||
}, [$props.templates.submenuicon ? (openBlock(), createBlock(resolveDynamicComponent($props.templates.submenuicon), {
|
||
key: 0,
|
||
root: $props.root,
|
||
active: $options.isItemActive(processedItem),
|
||
"class": normalizeClass(_ctx.cx("submenuIcon"))
|
||
}, null, 8, ["root", "active", "class"])) : (openBlock(), createBlock(resolveDynamicComponent($props.root ? "AngleDownIcon" : "AngleRightIcon"), mergeProps({
|
||
key: 1,
|
||
"class": _ctx.cx("submenuIcon"),
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "submenuIcon")), null, 16, ["class"]))], 64)) : createCommentVNode("", true)], 16, _hoisted_3$8)), [[_directive_ripple]]) : (openBlock(), createBlock(resolveDynamicComponent($props.templates.item), {
|
||
key: 1,
|
||
item: processedItem.item,
|
||
root: $props.root,
|
||
hasSubmenu: $options.getItemProp(processedItem, "items"),
|
||
label: $options.getItemLabel(processedItem),
|
||
props: $options.getMenuItemProps(processedItem, index)
|
||
}, null, 8, ["item", "root", "hasSubmenu", "label", "props"]))], 16, _hoisted_2$a), $options.isItemVisible(processedItem) && $options.isItemGroup(processedItem) ? (openBlock(), createBlock(_component_MenubarSub, {
|
||
key: 0,
|
||
id: $options.getItemId(processedItem) + "_list",
|
||
menuId: $props.menuId,
|
||
role: "menu",
|
||
style: normalizeStyle(_ctx.sx("submenu", true, {
|
||
processedItem
|
||
})),
|
||
focusedItemId: $props.focusedItemId,
|
||
items: processedItem.items,
|
||
mobileActive: $props.mobileActive,
|
||
activeItemPath: $props.activeItemPath,
|
||
templates: $props.templates,
|
||
level: $props.level + 1,
|
||
"aria-labelledby": $options.getItemLabelId(processedItem),
|
||
pt: _ctx.pt,
|
||
unstyled: _ctx.unstyled,
|
||
onItemClick: _cache[0] || (_cache[0] = function($event) {
|
||
return _ctx.$emit("item-click", $event);
|
||
}),
|
||
onItemMouseenter: _cache[1] || (_cache[1] = function($event) {
|
||
return _ctx.$emit("item-mouseenter", $event);
|
||
}),
|
||
onItemMousemove: _cache[2] || (_cache[2] = function($event) {
|
||
return _ctx.$emit("item-mousemove", $event);
|
||
})
|
||
}, null, 8, ["id", "menuId", "style", "focusedItemId", "items", "mobileActive", "activeItemPath", "templates", "level", "aria-labelledby", "pt", "unstyled"])) : createCommentVNode("", true)], 16, _hoisted_1$1$2)) : createCommentVNode("", true), $options.isItemVisible(processedItem) && $options.getItemProp(processedItem, "separator") ? (openBlock(), createElementBlock("li", mergeProps({
|
||
key: 1,
|
||
id: $options.getItemId(processedItem),
|
||
"class": [_ctx.cx("separator"), $options.getItemProp(processedItem, "class")],
|
||
style: $options.getItemProp(processedItem, "style"),
|
||
role: "separator",
|
||
ref_for: true
|
||
}, _ctx.ptm("separator")), null, 16, _hoisted_5$1)) : createCommentVNode("", true)], 64);
|
||
}), 128))], 16);
|
||
}
|
||
__name(render$1$2, "render$1$2");
|
||
script$1$3.render = render$1$2;
|
||
var script$5 = {
|
||
name: "Menubar",
|
||
"extends": script$2$1,
|
||
inheritAttrs: false,
|
||
emits: ["focus", "blur"],
|
||
matchMediaListener: null,
|
||
data: /* @__PURE__ */ __name(function data6() {
|
||
return {
|
||
id: this.$attrs.id,
|
||
mobileActive: false,
|
||
focused: false,
|
||
focusedItemInfo: {
|
||
index: -1,
|
||
level: 0,
|
||
parentKey: ""
|
||
},
|
||
activeItemPath: [],
|
||
dirty: false,
|
||
query: null,
|
||
queryMatches: false
|
||
};
|
||
}, "data"),
|
||
watch: {
|
||
"$attrs.id": /* @__PURE__ */ __name(function $attrsId2(newValue) {
|
||
this.id = newValue || UniqueComponentId();
|
||
}, "$attrsId"),
|
||
activeItemPath: /* @__PURE__ */ __name(function activeItemPath(newPath) {
|
||
if (isNotEmpty(newPath)) {
|
||
this.bindOutsideClickListener();
|
||
this.bindResizeListener();
|
||
} else {
|
||
this.unbindOutsideClickListener();
|
||
this.unbindResizeListener();
|
||
}
|
||
}, "activeItemPath")
|
||
},
|
||
outsideClickListener: null,
|
||
container: null,
|
||
menubar: null,
|
||
mounted: /* @__PURE__ */ __name(function mounted6() {
|
||
this.id = this.id || UniqueComponentId();
|
||
this.bindMatchMediaListener();
|
||
}, "mounted"),
|
||
beforeUnmount: /* @__PURE__ */ __name(function beforeUnmount6() {
|
||
this.mobileActive = false;
|
||
this.unbindOutsideClickListener();
|
||
this.unbindResizeListener();
|
||
this.unbindMatchMediaListener();
|
||
if (this.container) {
|
||
ZIndex.clear(this.container);
|
||
}
|
||
this.container = null;
|
||
}, "beforeUnmount"),
|
||
methods: {
|
||
getItemProp: /* @__PURE__ */ __name(function getItemProp2(item3, name) {
|
||
return item3 ? resolve(item3[name]) : void 0;
|
||
}, "getItemProp"),
|
||
getItemLabel: /* @__PURE__ */ __name(function getItemLabel2(item3) {
|
||
return this.getItemProp(item3, "label");
|
||
}, "getItemLabel"),
|
||
isItemDisabled: /* @__PURE__ */ __name(function isItemDisabled2(item3) {
|
||
return this.getItemProp(item3, "disabled");
|
||
}, "isItemDisabled"),
|
||
isItemVisible: /* @__PURE__ */ __name(function isItemVisible2(item3) {
|
||
return this.getItemProp(item3, "visible") !== false;
|
||
}, "isItemVisible"),
|
||
isItemGroup: /* @__PURE__ */ __name(function isItemGroup2(item3) {
|
||
return isNotEmpty(this.getItemProp(item3, "items"));
|
||
}, "isItemGroup"),
|
||
isItemSeparator: /* @__PURE__ */ __name(function isItemSeparator(item3) {
|
||
return this.getItemProp(item3, "separator");
|
||
}, "isItemSeparator"),
|
||
getProccessedItemLabel: /* @__PURE__ */ __name(function getProccessedItemLabel(processedItem) {
|
||
return processedItem ? this.getItemLabel(processedItem.item) : void 0;
|
||
}, "getProccessedItemLabel"),
|
||
isProccessedItemGroup: /* @__PURE__ */ __name(function isProccessedItemGroup(processedItem) {
|
||
return processedItem && isNotEmpty(processedItem.items);
|
||
}, "isProccessedItemGroup"),
|
||
toggle: /* @__PURE__ */ __name(function toggle(event) {
|
||
var _this = this;
|
||
if (this.mobileActive) {
|
||
this.mobileActive = false;
|
||
ZIndex.clear(this.menubar);
|
||
this.hide();
|
||
} else {
|
||
this.mobileActive = true;
|
||
ZIndex.set("menu", this.menubar, this.$primevue.config.zIndex.menu);
|
||
setTimeout(function() {
|
||
_this.show();
|
||
}, 1);
|
||
}
|
||
this.bindOutsideClickListener();
|
||
event.preventDefault();
|
||
}, "toggle"),
|
||
show: /* @__PURE__ */ __name(function show2() {
|
||
focus(this.menubar);
|
||
}, "show"),
|
||
hide: /* @__PURE__ */ __name(function hide2(event, isFocus) {
|
||
var _this2 = this;
|
||
if (this.mobileActive) {
|
||
this.mobileActive = false;
|
||
setTimeout(function() {
|
||
focus(_this2.$refs.menubutton);
|
||
}, 0);
|
||
}
|
||
this.activeItemPath = [];
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
level: 0,
|
||
parentKey: ""
|
||
};
|
||
isFocus && focus(this.menubar);
|
||
this.dirty = false;
|
||
}, "hide"),
|
||
onFocus: /* @__PURE__ */ __name(function onFocus3(event) {
|
||
this.focused = true;
|
||
this.focusedItemInfo = this.focusedItemInfo.index !== -1 ? this.focusedItemInfo : {
|
||
index: this.findFirstFocusedItemIndex(),
|
||
level: 0,
|
||
parentKey: ""
|
||
};
|
||
this.$emit("focus", event);
|
||
}, "onFocus"),
|
||
onBlur: /* @__PURE__ */ __name(function onBlur2(event) {
|
||
this.focused = false;
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
level: 0,
|
||
parentKey: ""
|
||
};
|
||
this.searchValue = "";
|
||
this.dirty = false;
|
||
this.$emit("blur", event);
|
||
}, "onBlur"),
|
||
onKeyDown: /* @__PURE__ */ __name(function onKeyDown2(event) {
|
||
var metaKey = event.metaKey || event.ctrlKey;
|
||
switch (event.code) {
|
||
case "ArrowDown":
|
||
this.onArrowDownKey(event);
|
||
break;
|
||
case "ArrowUp":
|
||
this.onArrowUpKey(event);
|
||
break;
|
||
case "ArrowLeft":
|
||
this.onArrowLeftKey(event);
|
||
break;
|
||
case "ArrowRight":
|
||
this.onArrowRightKey(event);
|
||
break;
|
||
case "Home":
|
||
this.onHomeKey(event);
|
||
break;
|
||
case "End":
|
||
this.onEndKey(event);
|
||
break;
|
||
case "Space":
|
||
this.onSpaceKey(event);
|
||
break;
|
||
case "Enter":
|
||
case "NumpadEnter":
|
||
this.onEnterKey(event);
|
||
break;
|
||
case "Escape":
|
||
this.onEscapeKey(event);
|
||
break;
|
||
case "Tab":
|
||
this.onTabKey(event);
|
||
break;
|
||
case "PageDown":
|
||
case "PageUp":
|
||
case "Backspace":
|
||
case "ShiftLeft":
|
||
case "ShiftRight":
|
||
break;
|
||
default:
|
||
if (!metaKey && isPrintableCharacter(event.key)) {
|
||
this.searchItems(event, event.key);
|
||
}
|
||
break;
|
||
}
|
||
}, "onKeyDown"),
|
||
onItemChange: /* @__PURE__ */ __name(function onItemChange(event) {
|
||
var processedItem = event.processedItem, isFocus = event.isFocus;
|
||
if (isEmpty(processedItem)) return;
|
||
var index = processedItem.index, key = processedItem.key, level = processedItem.level, parentKey = processedItem.parentKey, items = processedItem.items;
|
||
var grouped = isNotEmpty(items);
|
||
var activeItemPath3 = this.activeItemPath.filter(function(p) {
|
||
return p.parentKey !== parentKey && p.parentKey !== key;
|
||
});
|
||
grouped && activeItemPath3.push(processedItem);
|
||
this.focusedItemInfo = {
|
||
index,
|
||
level,
|
||
parentKey
|
||
};
|
||
this.activeItemPath = activeItemPath3;
|
||
grouped && (this.dirty = true);
|
||
isFocus && focus(this.menubar);
|
||
}, "onItemChange"),
|
||
onItemClick: /* @__PURE__ */ __name(function onItemClick2(event) {
|
||
var originalEvent = event.originalEvent, processedItem = event.processedItem;
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
var root12 = isEmpty(processedItem.parent);
|
||
var selected = this.isSelected(processedItem);
|
||
if (selected) {
|
||
var index = processedItem.index, key = processedItem.key, level = processedItem.level, parentKey = processedItem.parentKey;
|
||
this.activeItemPath = this.activeItemPath.filter(function(p) {
|
||
return key !== p.key && key.startsWith(p.key);
|
||
});
|
||
this.focusedItemInfo = {
|
||
index,
|
||
level,
|
||
parentKey
|
||
};
|
||
this.dirty = !root12;
|
||
focus(this.menubar);
|
||
} else {
|
||
if (grouped) {
|
||
this.onItemChange(event);
|
||
} else {
|
||
var rootProcessedItem = root12 ? processedItem : this.activeItemPath.find(function(p) {
|
||
return p.parentKey === "";
|
||
});
|
||
this.hide(originalEvent);
|
||
this.changeFocusedItemIndex(originalEvent, rootProcessedItem ? rootProcessedItem.index : -1);
|
||
this.mobileActive = false;
|
||
focus(this.menubar);
|
||
}
|
||
}
|
||
}, "onItemClick"),
|
||
onItemMouseEnter: /* @__PURE__ */ __name(function onItemMouseEnter2(event) {
|
||
if (this.dirty) {
|
||
this.onItemChange(event);
|
||
}
|
||
}, "onItemMouseEnter"),
|
||
onItemMouseMove: /* @__PURE__ */ __name(function onItemMouseMove2(event) {
|
||
if (this.focused) {
|
||
this.changeFocusedItemIndex(event, event.processedItem.index);
|
||
}
|
||
}, "onItemMouseMove"),
|
||
menuButtonClick: /* @__PURE__ */ __name(function menuButtonClick(event) {
|
||
this.toggle(event);
|
||
}, "menuButtonClick"),
|
||
menuButtonKeydown: /* @__PURE__ */ __name(function menuButtonKeydown(event) {
|
||
(event.code === "Enter" || event.code === "NumpadEnter" || event.code === "Space") && this.menuButtonClick(event);
|
||
}, "menuButtonKeydown"),
|
||
onArrowDownKey: /* @__PURE__ */ __name(function onArrowDownKey2(event) {
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var root12 = processedItem ? isEmpty(processedItem.parent) : null;
|
||
if (root12) {
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
if (grouped) {
|
||
this.onItemChange({
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
parentKey: processedItem.key
|
||
};
|
||
this.onArrowRightKey(event);
|
||
}
|
||
} else {
|
||
var itemIndex = this.focusedItemInfo.index !== -1 ? this.findNextItemIndex(this.focusedItemInfo.index) : this.findFirstFocusedItemIndex();
|
||
this.changeFocusedItemIndex(event, itemIndex);
|
||
}
|
||
event.preventDefault();
|
||
}, "onArrowDownKey"),
|
||
onArrowUpKey: /* @__PURE__ */ __name(function onArrowUpKey2(event) {
|
||
var _this3 = this;
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var root12 = isEmpty(processedItem.parent);
|
||
if (root12) {
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
if (grouped) {
|
||
this.onItemChange({
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
parentKey: processedItem.key
|
||
};
|
||
var itemIndex = this.findLastItemIndex();
|
||
this.changeFocusedItemIndex(event, itemIndex);
|
||
}
|
||
} else {
|
||
var parentItem = this.activeItemPath.find(function(p) {
|
||
return p.key === processedItem.parentKey;
|
||
});
|
||
if (this.focusedItemInfo.index === 0) {
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
parentKey: parentItem ? parentItem.parentKey : ""
|
||
};
|
||
this.searchValue = "";
|
||
this.onArrowLeftKey(event);
|
||
this.activeItemPath = this.activeItemPath.filter(function(p) {
|
||
return p.parentKey !== _this3.focusedItemInfo.parentKey;
|
||
});
|
||
} else {
|
||
var _itemIndex = this.focusedItemInfo.index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo.index) : this.findLastFocusedItemIndex();
|
||
this.changeFocusedItemIndex(event, _itemIndex);
|
||
}
|
||
}
|
||
event.preventDefault();
|
||
}, "onArrowUpKey"),
|
||
onArrowLeftKey: /* @__PURE__ */ __name(function onArrowLeftKey3(event) {
|
||
var _this4 = this;
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var parentItem = processedItem ? this.activeItemPath.find(function(p) {
|
||
return p.key === processedItem.parentKey;
|
||
}) : null;
|
||
if (parentItem) {
|
||
this.onItemChange({
|
||
originalEvent: event,
|
||
processedItem: parentItem
|
||
});
|
||
this.activeItemPath = this.activeItemPath.filter(function(p) {
|
||
return p.parentKey !== _this4.focusedItemInfo.parentKey;
|
||
});
|
||
event.preventDefault();
|
||
} else {
|
||
var itemIndex = this.focusedItemInfo.index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo.index) : this.findLastFocusedItemIndex();
|
||
this.changeFocusedItemIndex(event, itemIndex);
|
||
event.preventDefault();
|
||
}
|
||
}, "onArrowLeftKey"),
|
||
onArrowRightKey: /* @__PURE__ */ __name(function onArrowRightKey3(event) {
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var parentItem = processedItem ? this.activeItemPath.find(function(p) {
|
||
return p.key === processedItem.parentKey;
|
||
}) : null;
|
||
if (parentItem) {
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
if (grouped) {
|
||
this.onItemChange({
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
parentKey: processedItem.key
|
||
};
|
||
this.onArrowDownKey(event);
|
||
}
|
||
} else {
|
||
var itemIndex = this.focusedItemInfo.index !== -1 ? this.findNextItemIndex(this.focusedItemInfo.index) : this.findFirstFocusedItemIndex();
|
||
this.changeFocusedItemIndex(event, itemIndex);
|
||
event.preventDefault();
|
||
}
|
||
}, "onArrowRightKey"),
|
||
onHomeKey: /* @__PURE__ */ __name(function onHomeKey3(event) {
|
||
this.changeFocusedItemIndex(event, this.findFirstItemIndex());
|
||
event.preventDefault();
|
||
}, "onHomeKey"),
|
||
onEndKey: /* @__PURE__ */ __name(function onEndKey3(event) {
|
||
this.changeFocusedItemIndex(event, this.findLastItemIndex());
|
||
event.preventDefault();
|
||
}, "onEndKey"),
|
||
onEnterKey: /* @__PURE__ */ __name(function onEnterKey3(event) {
|
||
if (this.focusedItemInfo.index !== -1) {
|
||
var element = findSingle(this.menubar, 'li[id="'.concat("".concat(this.focusedItemId), '"]'));
|
||
var anchorElement = element && findSingle(element, 'a[data-pc-section="itemlink"]');
|
||
anchorElement ? anchorElement.click() : element && element.click();
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
!grouped && (this.focusedItemInfo.index = this.findFirstFocusedItemIndex());
|
||
}
|
||
event.preventDefault();
|
||
}, "onEnterKey"),
|
||
onSpaceKey: /* @__PURE__ */ __name(function onSpaceKey(event) {
|
||
this.onEnterKey(event);
|
||
}, "onSpaceKey"),
|
||
onEscapeKey: /* @__PURE__ */ __name(function onEscapeKey2(event) {
|
||
if (this.focusedItemInfo.level !== 0) {
|
||
var _focusedItemInfo = this.focusedItemInfo;
|
||
this.hide(event, false);
|
||
this.focusedItemInfo = {
|
||
index: Number(_focusedItemInfo.parentKey.split("_")[0]),
|
||
level: 0,
|
||
parentKey: ""
|
||
};
|
||
}
|
||
event.preventDefault();
|
||
}, "onEscapeKey"),
|
||
onTabKey: /* @__PURE__ */ __name(function onTabKey2(event) {
|
||
if (this.focusedItemInfo.index !== -1) {
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
!grouped && this.onItemChange({
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
}
|
||
this.hide();
|
||
}, "onTabKey"),
|
||
bindOutsideClickListener: /* @__PURE__ */ __name(function bindOutsideClickListener2() {
|
||
var _this5 = this;
|
||
if (!this.outsideClickListener) {
|
||
this.outsideClickListener = function(event) {
|
||
var isOutsideContainer = _this5.container && !_this5.container.contains(event.target);
|
||
var isOutsideTarget = !(_this5.target && (_this5.target === event.target || _this5.target.contains(event.target)));
|
||
if (isOutsideContainer && isOutsideTarget) {
|
||
_this5.hide();
|
||
}
|
||
};
|
||
document.addEventListener("click", this.outsideClickListener);
|
||
}
|
||
}, "bindOutsideClickListener"),
|
||
unbindOutsideClickListener: /* @__PURE__ */ __name(function unbindOutsideClickListener2() {
|
||
if (this.outsideClickListener) {
|
||
document.removeEventListener("click", this.outsideClickListener);
|
||
this.outsideClickListener = null;
|
||
}
|
||
}, "unbindOutsideClickListener"),
|
||
bindResizeListener: /* @__PURE__ */ __name(function bindResizeListener2() {
|
||
var _this6 = this;
|
||
if (!this.resizeListener) {
|
||
this.resizeListener = function(event) {
|
||
if (!isTouchDevice()) {
|
||
_this6.hide(event, true);
|
||
}
|
||
_this6.mobileActive = false;
|
||
};
|
||
window.addEventListener("resize", this.resizeListener);
|
||
}
|
||
}, "bindResizeListener"),
|
||
unbindResizeListener: /* @__PURE__ */ __name(function unbindResizeListener2() {
|
||
if (this.resizeListener) {
|
||
window.removeEventListener("resize", this.resizeListener);
|
||
this.resizeListener = null;
|
||
}
|
||
}, "unbindResizeListener"),
|
||
bindMatchMediaListener: /* @__PURE__ */ __name(function bindMatchMediaListener() {
|
||
var _this7 = this;
|
||
if (!this.matchMediaListener) {
|
||
var query = matchMedia("(max-width: ".concat(this.breakpoint, ")"));
|
||
this.query = query;
|
||
this.queryMatches = query.matches;
|
||
this.matchMediaListener = function() {
|
||
_this7.queryMatches = query.matches;
|
||
_this7.mobileActive = false;
|
||
};
|
||
this.query.addEventListener("change", this.matchMediaListener);
|
||
}
|
||
}, "bindMatchMediaListener"),
|
||
unbindMatchMediaListener: /* @__PURE__ */ __name(function unbindMatchMediaListener() {
|
||
if (this.matchMediaListener) {
|
||
this.query.removeEventListener("change", this.matchMediaListener);
|
||
this.matchMediaListener = null;
|
||
}
|
||
}, "unbindMatchMediaListener"),
|
||
isItemMatched: /* @__PURE__ */ __name(function isItemMatched(processedItem) {
|
||
var _this$getProccessedIt;
|
||
return this.isValidItem(processedItem) && ((_this$getProccessedIt = this.getProccessedItemLabel(processedItem)) === null || _this$getProccessedIt === void 0 ? void 0 : _this$getProccessedIt.toLocaleLowerCase().startsWith(this.searchValue.toLocaleLowerCase()));
|
||
}, "isItemMatched"),
|
||
isValidItem: /* @__PURE__ */ __name(function isValidItem(processedItem) {
|
||
return !!processedItem && !this.isItemDisabled(processedItem.item) && !this.isItemSeparator(processedItem.item) && this.isItemVisible(processedItem.item);
|
||
}, "isValidItem"),
|
||
isValidSelectedItem: /* @__PURE__ */ __name(function isValidSelectedItem(processedItem) {
|
||
return this.isValidItem(processedItem) && this.isSelected(processedItem);
|
||
}, "isValidSelectedItem"),
|
||
isSelected: /* @__PURE__ */ __name(function isSelected2(processedItem) {
|
||
return this.activeItemPath.some(function(p) {
|
||
return p.key === processedItem.key;
|
||
});
|
||
}, "isSelected"),
|
||
findFirstItemIndex: /* @__PURE__ */ __name(function findFirstItemIndex() {
|
||
var _this8 = this;
|
||
return this.visibleItems.findIndex(function(processedItem) {
|
||
return _this8.isValidItem(processedItem);
|
||
});
|
||
}, "findFirstItemIndex"),
|
||
findLastItemIndex: /* @__PURE__ */ __name(function findLastItemIndex() {
|
||
var _this9 = this;
|
||
return findLastIndex(this.visibleItems, function(processedItem) {
|
||
return _this9.isValidItem(processedItem);
|
||
});
|
||
}, "findLastItemIndex"),
|
||
findNextItemIndex: /* @__PURE__ */ __name(function findNextItemIndex(index) {
|
||
var _this10 = this;
|
||
var matchedItemIndex = index < this.visibleItems.length - 1 ? this.visibleItems.slice(index + 1).findIndex(function(processedItem) {
|
||
return _this10.isValidItem(processedItem);
|
||
}) : -1;
|
||
return matchedItemIndex > -1 ? matchedItemIndex + index + 1 : index;
|
||
}, "findNextItemIndex"),
|
||
findPrevItemIndex: /* @__PURE__ */ __name(function findPrevItemIndex(index) {
|
||
var _this11 = this;
|
||
var matchedItemIndex = index > 0 ? findLastIndex(this.visibleItems.slice(0, index), function(processedItem) {
|
||
return _this11.isValidItem(processedItem);
|
||
}) : -1;
|
||
return matchedItemIndex > -1 ? matchedItemIndex : index;
|
||
}, "findPrevItemIndex"),
|
||
findSelectedItemIndex: /* @__PURE__ */ __name(function findSelectedItemIndex() {
|
||
var _this12 = this;
|
||
return this.visibleItems.findIndex(function(processedItem) {
|
||
return _this12.isValidSelectedItem(processedItem);
|
||
});
|
||
}, "findSelectedItemIndex"),
|
||
findFirstFocusedItemIndex: /* @__PURE__ */ __name(function findFirstFocusedItemIndex() {
|
||
var selectedIndex = this.findSelectedItemIndex();
|
||
return selectedIndex < 0 ? this.findFirstItemIndex() : selectedIndex;
|
||
}, "findFirstFocusedItemIndex"),
|
||
findLastFocusedItemIndex: /* @__PURE__ */ __name(function findLastFocusedItemIndex() {
|
||
var selectedIndex = this.findSelectedItemIndex();
|
||
return selectedIndex < 0 ? this.findLastItemIndex() : selectedIndex;
|
||
}, "findLastFocusedItemIndex"),
|
||
searchItems: /* @__PURE__ */ __name(function searchItems(event, _char) {
|
||
var _this13 = this;
|
||
this.searchValue = (this.searchValue || "") + _char;
|
||
var itemIndex = -1;
|
||
var matched = false;
|
||
if (this.focusedItemInfo.index !== -1) {
|
||
itemIndex = this.visibleItems.slice(this.focusedItemInfo.index).findIndex(function(processedItem) {
|
||
return _this13.isItemMatched(processedItem);
|
||
});
|
||
itemIndex = itemIndex === -1 ? this.visibleItems.slice(0, this.focusedItemInfo.index).findIndex(function(processedItem) {
|
||
return _this13.isItemMatched(processedItem);
|
||
}) : itemIndex + this.focusedItemInfo.index;
|
||
} else {
|
||
itemIndex = this.visibleItems.findIndex(function(processedItem) {
|
||
return _this13.isItemMatched(processedItem);
|
||
});
|
||
}
|
||
if (itemIndex !== -1) {
|
||
matched = true;
|
||
}
|
||
if (itemIndex === -1 && this.focusedItemInfo.index === -1) {
|
||
itemIndex = this.findFirstFocusedItemIndex();
|
||
}
|
||
if (itemIndex !== -1) {
|
||
this.changeFocusedItemIndex(event, itemIndex);
|
||
}
|
||
if (this.searchTimeout) {
|
||
clearTimeout(this.searchTimeout);
|
||
}
|
||
this.searchTimeout = setTimeout(function() {
|
||
_this13.searchValue = "";
|
||
_this13.searchTimeout = null;
|
||
}, 500);
|
||
return matched;
|
||
}, "searchItems"),
|
||
changeFocusedItemIndex: /* @__PURE__ */ __name(function changeFocusedItemIndex(event, index) {
|
||
if (this.focusedItemInfo.index !== index) {
|
||
this.focusedItemInfo.index = index;
|
||
this.scrollInView();
|
||
}
|
||
}, "changeFocusedItemIndex"),
|
||
scrollInView: /* @__PURE__ */ __name(function scrollInView3() {
|
||
var index = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : -1;
|
||
var id2 = index !== -1 ? "".concat(this.id, "_").concat(index) : this.focusedItemId;
|
||
var element = findSingle(this.menubar, 'li[id="'.concat(id2, '"]'));
|
||
if (element) {
|
||
element.scrollIntoView && element.scrollIntoView({
|
||
block: "nearest",
|
||
inline: "start"
|
||
});
|
||
}
|
||
}, "scrollInView"),
|
||
createProcessedItems: /* @__PURE__ */ __name(function createProcessedItems(items) {
|
||
var _this14 = this;
|
||
var level = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0;
|
||
var parent = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
|
||
var parentKey = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : "";
|
||
var processedItems3 = [];
|
||
items && items.forEach(function(item3, index) {
|
||
var key = (parentKey !== "" ? parentKey + "_" : "") + index;
|
||
var newItem = {
|
||
item: item3,
|
||
index,
|
||
level,
|
||
key,
|
||
parent,
|
||
parentKey
|
||
};
|
||
newItem["items"] = _this14.createProcessedItems(item3.items, level + 1, newItem, key);
|
||
processedItems3.push(newItem);
|
||
});
|
||
return processedItems3;
|
||
}, "createProcessedItems"),
|
||
containerRef: /* @__PURE__ */ __name(function containerRef(el) {
|
||
this.container = el;
|
||
}, "containerRef"),
|
||
menubarRef: /* @__PURE__ */ __name(function menubarRef(el) {
|
||
this.menubar = el ? el.$el : void 0;
|
||
}, "menubarRef")
|
||
},
|
||
computed: {
|
||
processedItems: /* @__PURE__ */ __name(function processedItems() {
|
||
return this.createProcessedItems(this.model || []);
|
||
}, "processedItems"),
|
||
visibleItems: /* @__PURE__ */ __name(function visibleItems() {
|
||
var _this15 = this;
|
||
var processedItem = this.activeItemPath.find(function(p) {
|
||
return p.key === _this15.focusedItemInfo.parentKey;
|
||
});
|
||
return processedItem ? processedItem.items : this.processedItems;
|
||
}, "visibleItems"),
|
||
focusedItemId: /* @__PURE__ */ __name(function focusedItemId() {
|
||
return this.focusedItemInfo.index !== -1 ? "".concat(this.id).concat(isNotEmpty(this.focusedItemInfo.parentKey) ? "_" + this.focusedItemInfo.parentKey : "", "_").concat(this.focusedItemInfo.index) : null;
|
||
}, "focusedItemId")
|
||
},
|
||
components: {
|
||
MenubarSub: script$1$3,
|
||
BarsIcon: script$B
|
||
}
|
||
};
|
||
function _typeof(o) {
|
||
"@babel/helpers - typeof";
|
||
return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(o2) {
|
||
return typeof o2;
|
||
} : function(o2) {
|
||
return o2 && "function" == typeof Symbol && o2.constructor === Symbol && o2 !== Symbol.prototype ? "symbol" : typeof o2;
|
||
}, _typeof(o);
|
||
}
|
||
__name(_typeof, "_typeof");
|
||
function ownKeys(e, r) {
|
||
var t = Object.keys(e);
|
||
if (Object.getOwnPropertySymbols) {
|
||
var o = Object.getOwnPropertySymbols(e);
|
||
r && (o = o.filter(function(r2) {
|
||
return Object.getOwnPropertyDescriptor(e, r2).enumerable;
|
||
})), t.push.apply(t, o);
|
||
}
|
||
return t;
|
||
}
|
||
__name(ownKeys, "ownKeys");
|
||
function _objectSpread(e) {
|
||
for (var r = 1; r < arguments.length; r++) {
|
||
var t = null != arguments[r] ? arguments[r] : {};
|
||
r % 2 ? ownKeys(Object(t), true).forEach(function(r2) {
|
||
_defineProperty(e, r2, t[r2]);
|
||
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function(r2) {
|
||
Object.defineProperty(e, r2, Object.getOwnPropertyDescriptor(t, r2));
|
||
});
|
||
}
|
||
return e;
|
||
}
|
||
__name(_objectSpread, "_objectSpread");
|
||
function _defineProperty(e, r, t) {
|
||
return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: true, configurable: true, writable: true }) : e[r] = t, e;
|
||
}
|
||
__name(_defineProperty, "_defineProperty");
|
||
function _toPropertyKey(t) {
|
||
var i = _toPrimitive(t, "string");
|
||
return "symbol" == _typeof(i) ? i : i + "";
|
||
}
|
||
__name(_toPropertyKey, "_toPropertyKey");
|
||
function _toPrimitive(t, r) {
|
||
if ("object" != _typeof(t) || !t) return t;
|
||
var e = t[Symbol.toPrimitive];
|
||
if (void 0 !== e) {
|
||
var i = e.call(t, r || "default");
|
||
if ("object" != _typeof(i)) return i;
|
||
throw new TypeError("@@toPrimitive must return a primitive value.");
|
||
}
|
||
return ("string" === r ? String : Number)(t);
|
||
}
|
||
__name(_toPrimitive, "_toPrimitive");
|
||
var _hoisted_1$c = ["aria-haspopup", "aria-expanded", "aria-controls", "aria-label"];
|
||
function render$9(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _component_BarsIcon = resolveComponent("BarsIcon");
|
||
var _component_MenubarSub = resolveComponent("MenubarSub");
|
||
return openBlock(), createElementBlock("div", mergeProps({
|
||
ref: $options.containerRef,
|
||
"class": _ctx.cx("root")
|
||
}, _ctx.ptmi("root")), [_ctx.$slots.start ? (openBlock(), createElementBlock("div", mergeProps({
|
||
key: 0,
|
||
"class": _ctx.cx("start")
|
||
}, _ctx.ptm("start")), [renderSlot(_ctx.$slots, "start")], 16)) : createCommentVNode("", true), renderSlot(_ctx.$slots, _ctx.$slots.button ? "button" : "menubutton", {
|
||
id: $data.id,
|
||
"class": normalizeClass(_ctx.cx("button")),
|
||
toggleCallback: /* @__PURE__ */ __name(function toggleCallback(event) {
|
||
return $options.menuButtonClick(event);
|
||
}, "toggleCallback")
|
||
}, function() {
|
||
var _ctx$$primevue$config;
|
||
return [_ctx.model && _ctx.model.length > 0 ? (openBlock(), createElementBlock("a", mergeProps({
|
||
key: 0,
|
||
ref: "menubutton",
|
||
role: "button",
|
||
tabindex: "0",
|
||
"class": _ctx.cx("button"),
|
||
"aria-haspopup": _ctx.model.length && _ctx.model.length > 0 ? true : false,
|
||
"aria-expanded": $data.mobileActive,
|
||
"aria-controls": $data.id,
|
||
"aria-label": (_ctx$$primevue$config = _ctx.$primevue.config.locale.aria) === null || _ctx$$primevue$config === void 0 ? void 0 : _ctx$$primevue$config.navigation,
|
||
onClick: _cache[0] || (_cache[0] = function($event) {
|
||
return $options.menuButtonClick($event);
|
||
}),
|
||
onKeydown: _cache[1] || (_cache[1] = function($event) {
|
||
return $options.menuButtonKeydown($event);
|
||
})
|
||
}, _objectSpread(_objectSpread({}, _ctx.buttonProps), _ctx.ptm("button"))), [renderSlot(_ctx.$slots, _ctx.$slots.buttonicon ? "buttonicon" : "menubuttonicon", {}, function() {
|
||
return [createVNode(_component_BarsIcon, normalizeProps(guardReactiveProps(_ctx.ptm("buttonicon"))), null, 16)];
|
||
})], 16, _hoisted_1$c)) : createCommentVNode("", true)];
|
||
}), createVNode(_component_MenubarSub, {
|
||
ref: $options.menubarRef,
|
||
id: $data.id + "_list",
|
||
role: "menubar",
|
||
items: $options.processedItems,
|
||
templates: _ctx.$slots,
|
||
root: true,
|
||
mobileActive: $data.mobileActive,
|
||
tabindex: "0",
|
||
"aria-activedescendant": $data.focused ? $options.focusedItemId : void 0,
|
||
menuId: $data.id,
|
||
focusedItemId: $data.focused ? $options.focusedItemId : void 0,
|
||
activeItemPath: $data.activeItemPath,
|
||
level: 0,
|
||
"aria-labelledby": _ctx.ariaLabelledby,
|
||
"aria-label": _ctx.ariaLabel,
|
||
pt: _ctx.pt,
|
||
unstyled: _ctx.unstyled,
|
||
onFocus: $options.onFocus,
|
||
onBlur: $options.onBlur,
|
||
onKeydown: $options.onKeyDown,
|
||
onItemClick: $options.onItemClick,
|
||
onItemMouseenter: $options.onItemMouseEnter,
|
||
onItemMousemove: $options.onItemMouseMove
|
||
}, null, 8, ["id", "items", "templates", "mobileActive", "aria-activedescendant", "menuId", "focusedItemId", "activeItemPath", "aria-labelledby", "aria-label", "pt", "unstyled", "onFocus", "onBlur", "onKeydown", "onItemClick", "onItemMouseenter", "onItemMousemove"]), _ctx.$slots.end ? (openBlock(), createElementBlock("div", mergeProps({
|
||
key: 1,
|
||
"class": _ctx.cx("end")
|
||
}, _ctx.ptm("end")), [renderSlot(_ctx.$slots, "end")], 16)) : createCommentVNode("", true)], 16);
|
||
}
|
||
__name(render$9, "render$9");
|
||
script$5.render = render$9;
|
||
const _withScopeId$2 = /* @__PURE__ */ __name((n) => (pushScopeId("data-v-a2b12676"), n = n(), popScopeId(), n), "_withScopeId$2");
|
||
const _hoisted_1$b = ["href"];
|
||
const _hoisted_2$9 = { class: "p-menubar-item-label" };
|
||
const _hoisted_3$7 = {
|
||
key: 1,
|
||
class: "ml-auto border border-surface rounded text-muted text-xs p-1 keybinding-tag"
|
||
};
|
||
const _sfc_main$6 = /* @__PURE__ */ defineComponent({
|
||
__name: "CommandMenubar",
|
||
setup(__props) {
|
||
const settingStore = useSettingStore();
|
||
const dropdownDirection = computed(
|
||
() => settingStore.get("Comfy.UseNewMenu") === "Top" ? "down" : "up"
|
||
);
|
||
const menuItemsStore = useMenuItemStore();
|
||
const { t } = useI18n();
|
||
const translateMenuItem = /* @__PURE__ */ __name((item3) => {
|
||
const label = typeof item3.label === "function" ? item3.label() : item3.label;
|
||
const translatedLabel = label ? t(`menuLabels.${normalizeI18nKey(label)}`, label) : void 0;
|
||
return {
|
||
...item3,
|
||
label: translatedLabel,
|
||
items: item3.items?.map(translateMenuItem)
|
||
};
|
||
}, "translateMenuItem");
|
||
const translatedItems = computed(
|
||
() => menuItemsStore.menuItems.map(translateMenuItem)
|
||
);
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createBlock(unref(script$5), {
|
||
model: translatedItems.value,
|
||
class: "top-menubar border-none p-0 bg-transparent",
|
||
pt: {
|
||
rootList: "gap-0 flex-nowrap w-auto",
|
||
submenu: `dropdown-direction-${dropdownDirection.value}`,
|
||
item: "relative"
|
||
}
|
||
}, {
|
||
item: withCtx(({ item: item3, props }) => [
|
||
createBaseVNode("a", mergeProps({ class: "p-menubar-item-link" }, props.action, {
|
||
href: item3.url,
|
||
target: "_blank"
|
||
}), [
|
||
item3.icon ? (openBlock(), createElementBlock("span", {
|
||
key: 0,
|
||
class: normalizeClass(["p-menubar-item-icon", item3.icon])
|
||
}, null, 2)) : createCommentVNode("", true),
|
||
createBaseVNode("span", _hoisted_2$9, toDisplayString(item3.label), 1),
|
||
item3?.comfyCommand?.keybinding ? (openBlock(), createElementBlock("span", _hoisted_3$7, toDisplayString(item3.comfyCommand.keybinding.combo.toString()), 1)) : createCommentVNode("", true)
|
||
], 16, _hoisted_1$b)
|
||
]),
|
||
_: 1
|
||
}, 8, ["model", "pt"]);
|
||
};
|
||
}
|
||
});
|
||
const CommandMenubar = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["__scopeId", "data-v-a2b12676"]]);
|
||
var theme$2 = /* @__PURE__ */ __name(function theme7(_ref) {
|
||
var dt = _ref.dt;
|
||
return "\n.p-panel {\n border: 1px solid ".concat(dt("panel.border.color"), ";\n border-radius: ").concat(dt("panel.border.radius"), ";\n background: ").concat(dt("panel.background"), ";\n color: ").concat(dt("panel.color"), ";\n}\n\n.p-panel-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: ").concat(dt("panel.header.padding"), ";\n background: ").concat(dt("panel.header.background"), ";\n color: ").concat(dt("panel.header.color"), ";\n border-style: solid;\n border-width: ").concat(dt("panel.header.border.width"), ";\n border-color: ").concat(dt("panel.header.border.color"), ";\n border-radius: ").concat(dt("panel.header.border.radius"), ";\n}\n\n.p-panel-toggleable .p-panel-header {\n padding: ").concat(dt("panel.toggleable.header.padding"), ";\n}\n\n.p-panel-title {\n line-height: 1;\n font-weight: ").concat(dt("panel.title.font.weight"), ";\n}\n\n.p-panel-content {\n padding: ").concat(dt("panel.content.padding"), ";\n}\n\n.p-panel-footer {\n padding: ").concat(dt("panel.footer.padding"), ";\n}\n");
|
||
}, "theme");
|
||
var classes$2 = {
|
||
root: /* @__PURE__ */ __name(function root9(_ref2) {
|
||
var props = _ref2.props;
|
||
return ["p-panel p-component", {
|
||
"p-panel-toggleable": props.toggleable
|
||
}];
|
||
}, "root"),
|
||
header: "p-panel-header",
|
||
title: "p-panel-title",
|
||
headerActions: "p-panel-header-actions",
|
||
pcToggleButton: "p-panel-toggle-button",
|
||
contentContainer: "p-panel-content-container",
|
||
content: "p-panel-content",
|
||
footer: "p-panel-footer"
|
||
};
|
||
var PanelStyle = BaseStyle.extend({
|
||
name: "panel",
|
||
theme: theme$2,
|
||
classes: classes$2
|
||
});
|
||
var script$1$2 = {
|
||
name: "BasePanel",
|
||
"extends": script$g,
|
||
props: {
|
||
header: String,
|
||
toggleable: Boolean,
|
||
collapsed: Boolean,
|
||
toggleButtonProps: {
|
||
type: Object,
|
||
"default": /* @__PURE__ */ __name(function _default() {
|
||
return {
|
||
severity: "secondary",
|
||
text: true,
|
||
rounded: true
|
||
};
|
||
}, "_default")
|
||
}
|
||
},
|
||
style: PanelStyle,
|
||
provide: /* @__PURE__ */ __name(function provide11() {
|
||
return {
|
||
$pcPanel: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script$4 = {
|
||
name: "Panel",
|
||
"extends": script$1$2,
|
||
inheritAttrs: false,
|
||
emits: ["update:collapsed", "toggle"],
|
||
data: /* @__PURE__ */ __name(function data7() {
|
||
return {
|
||
id: this.$attrs.id,
|
||
d_collapsed: this.collapsed
|
||
};
|
||
}, "data"),
|
||
watch: {
|
||
"$attrs.id": /* @__PURE__ */ __name(function $attrsId3(newValue) {
|
||
this.id = newValue || UniqueComponentId();
|
||
}, "$attrsId"),
|
||
collapsed: /* @__PURE__ */ __name(function collapsed(newValue) {
|
||
this.d_collapsed = newValue;
|
||
}, "collapsed")
|
||
},
|
||
mounted: /* @__PURE__ */ __name(function mounted7() {
|
||
this.id = this.id || UniqueComponentId();
|
||
}, "mounted"),
|
||
methods: {
|
||
toggle: /* @__PURE__ */ __name(function toggle2(event) {
|
||
this.d_collapsed = !this.d_collapsed;
|
||
this.$emit("update:collapsed", this.d_collapsed);
|
||
this.$emit("toggle", {
|
||
originalEvent: event,
|
||
value: this.d_collapsed
|
||
});
|
||
}, "toggle"),
|
||
onKeyDown: /* @__PURE__ */ __name(function onKeyDown3(event) {
|
||
if (event.code === "Enter" || event.code === "NumpadEnter" || event.code === "Space") {
|
||
this.toggle(event);
|
||
event.preventDefault();
|
||
}
|
||
}, "onKeyDown")
|
||
},
|
||
computed: {
|
||
buttonAriaLabel: /* @__PURE__ */ __name(function buttonAriaLabel() {
|
||
return this.toggleButtonProps && this.toggleButtonProps.ariaLabel ? this.toggleButtonProps.ariaLabel : this.header;
|
||
}, "buttonAriaLabel")
|
||
},
|
||
components: {
|
||
PlusIcon: script$C,
|
||
MinusIcon: script$D,
|
||
Button: script$f
|
||
},
|
||
directives: {
|
||
ripple: Ripple
|
||
}
|
||
};
|
||
var _hoisted_1$a = ["id"];
|
||
var _hoisted_2$8 = ["id", "aria-labelledby"];
|
||
function render$8(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _component_Button = resolveComponent("Button");
|
||
return openBlock(), createElementBlock("div", mergeProps({
|
||
"class": _ctx.cx("root")
|
||
}, _ctx.ptmi("root")), [createBaseVNode("div", mergeProps({
|
||
"class": _ctx.cx("header")
|
||
}, _ctx.ptm("header")), [renderSlot(_ctx.$slots, "header", {
|
||
id: $data.id + "_header",
|
||
"class": normalizeClass(_ctx.cx("title"))
|
||
}, function() {
|
||
return [_ctx.header ? (openBlock(), createElementBlock("span", mergeProps({
|
||
key: 0,
|
||
id: $data.id + "_header",
|
||
"class": _ctx.cx("title")
|
||
}, _ctx.ptm("title")), toDisplayString(_ctx.header), 17, _hoisted_1$a)) : createCommentVNode("", true)];
|
||
}), createBaseVNode("div", mergeProps({
|
||
"class": _ctx.cx("headerActions")
|
||
}, _ctx.ptm("headerActions")), [renderSlot(_ctx.$slots, "icons"), _ctx.toggleable ? (openBlock(), createBlock(_component_Button, mergeProps({
|
||
key: 0,
|
||
id: $data.id + "_header",
|
||
"class": _ctx.cx("pcToggleButton"),
|
||
"aria-label": $options.buttonAriaLabel,
|
||
"aria-controls": $data.id + "_content",
|
||
"aria-expanded": !$data.d_collapsed,
|
||
unstyled: _ctx.unstyled,
|
||
onClick: $options.toggle,
|
||
onKeydown: $options.onKeyDown
|
||
}, _ctx.toggleButtonProps, {
|
||
pt: _ctx.ptm("pcToggleButton")
|
||
}), {
|
||
icon: withCtx(function(slotProps) {
|
||
return [renderSlot(_ctx.$slots, _ctx.$slots.toggleicon ? "toggleicon" : "togglericon", {
|
||
collapsed: $data.d_collapsed
|
||
}, function() {
|
||
return [(openBlock(), createBlock(resolveDynamicComponent($data.d_collapsed ? "PlusIcon" : "MinusIcon"), mergeProps({
|
||
"class": slotProps["class"]
|
||
}, _ctx.ptm("pcToggleButton")["icon"]), null, 16, ["class"]))];
|
||
})];
|
||
}),
|
||
_: 3
|
||
}, 16, ["id", "class", "aria-label", "aria-controls", "aria-expanded", "unstyled", "onClick", "onKeydown", "pt"])) : createCommentVNode("", true)], 16)], 16), createVNode(Transition, mergeProps({
|
||
name: "p-toggleable-content"
|
||
}, _ctx.ptm("transition")), {
|
||
"default": withCtx(function() {
|
||
return [withDirectives(createBaseVNode("div", mergeProps({
|
||
id: $data.id + "_content",
|
||
"class": _ctx.cx("contentContainer"),
|
||
role: "region",
|
||
"aria-labelledby": $data.id + "_header"
|
||
}, _ctx.ptm("contentContainer")), [createBaseVNode("div", mergeProps({
|
||
"class": _ctx.cx("content")
|
||
}, _ctx.ptm("content")), [renderSlot(_ctx.$slots, "default")], 16), _ctx.$slots.footer ? (openBlock(), createElementBlock("div", mergeProps({
|
||
key: 0,
|
||
"class": _ctx.cx("footer")
|
||
}, _ctx.ptm("footer")), [renderSlot(_ctx.$slots, "footer")], 16)) : createCommentVNode("", true)], 16, _hoisted_2$8), [[vShow, !$data.d_collapsed]])];
|
||
}),
|
||
_: 3
|
||
}, 16)], 16);
|
||
}
|
||
__name(render$8, "render$8");
|
||
script$4.render = render$8;
|
||
const _hoisted_1$9 = {
|
||
viewBox: "0 0 24 24",
|
||
width: "1.2em",
|
||
height: "1.2em"
|
||
};
|
||
const _hoisted_2$7 = /* @__PURE__ */ createBaseVNode("path", {
|
||
fill: "none",
|
||
stroke: "currentColor",
|
||
"stroke-linecap": "round",
|
||
"stroke-linejoin": "round",
|
||
"stroke-width": "2",
|
||
d: "M6 4v16m4-16l10 8l-10 8z"
|
||
}, null, -1);
|
||
const _hoisted_3$6 = [
|
||
_hoisted_2$7
|
||
];
|
||
function render$7(_ctx, _cache) {
|
||
return openBlock(), createElementBlock("svg", _hoisted_1$9, [..._hoisted_3$6]);
|
||
}
|
||
__name(render$7, "render$7");
|
||
const __unplugin_components_3 = markRaw({ name: "lucide-step-forward", render: render$7 });
|
||
const _hoisted_1$8 = {
|
||
viewBox: "0 0 24 24",
|
||
width: "1.2em",
|
||
height: "1.2em"
|
||
};
|
||
const _hoisted_2$6 = /* @__PURE__ */ createBaseVNode("path", {
|
||
fill: "none",
|
||
stroke: "currentColor",
|
||
"stroke-linecap": "round",
|
||
"stroke-linejoin": "round",
|
||
"stroke-width": "2",
|
||
d: "m13 19l9-7l-9-7zM2 19l9-7l-9-7z"
|
||
}, null, -1);
|
||
const _hoisted_3$5 = [
|
||
_hoisted_2$6
|
||
];
|
||
function render$6(_ctx, _cache) {
|
||
return openBlock(), createElementBlock("svg", _hoisted_1$8, [..._hoisted_3$5]);
|
||
}
|
||
__name(render$6, "render$6");
|
||
const __unplugin_components_2 = markRaw({ name: "lucide-fast-forward", render: render$6 });
|
||
const _hoisted_1$7 = {
|
||
viewBox: "0 0 24 24",
|
||
width: "1.2em",
|
||
height: "1.2em"
|
||
};
|
||
const _hoisted_2$5 = /* @__PURE__ */ createBaseVNode("path", {
|
||
fill: "none",
|
||
stroke: "currentColor",
|
||
"stroke-linecap": "round",
|
||
"stroke-linejoin": "round",
|
||
"stroke-width": "2",
|
||
d: "m6 3l14 9l-14 9z"
|
||
}, null, -1);
|
||
const _hoisted_3$4 = [
|
||
_hoisted_2$5
|
||
];
|
||
function render$5(_ctx, _cache) {
|
||
return openBlock(), createElementBlock("svg", _hoisted_1$7, [..._hoisted_3$4]);
|
||
}
|
||
__name(render$5, "render$5");
|
||
const __unplugin_components_1$1 = markRaw({ name: "lucide-play", render: render$5 });
|
||
const _hoisted_1$6 = {
|
||
viewBox: "0 0 24 24",
|
||
width: "1.2em",
|
||
height: "1.2em"
|
||
};
|
||
const _hoisted_2$4 = /* @__PURE__ */ createBaseVNode("g", {
|
||
fill: "none",
|
||
stroke: "currentColor",
|
||
"stroke-linecap": "round",
|
||
"stroke-linejoin": "round",
|
||
"stroke-width": "2"
|
||
}, [
|
||
/* @__PURE__ */ createBaseVNode("path", { d: "M16 12H3m13 6H3m7-12H3m18 12V8a2 2 0 0 0-2-2h-5" }),
|
||
/* @__PURE__ */ createBaseVNode("path", { d: "m16 8l-2-2l2-2" })
|
||
], -1);
|
||
const _hoisted_3$3 = [
|
||
_hoisted_2$4
|
||
];
|
||
function render$4(_ctx, _cache) {
|
||
return openBlock(), createElementBlock("svg", _hoisted_1$6, [..._hoisted_3$3]);
|
||
}
|
||
__name(render$4, "render$4");
|
||
const __unplugin_components_0$1 = markRaw({ name: "lucide-list-start", render: render$4 });
|
||
var theme$1 = /* @__PURE__ */ __name(function theme8(_ref) {
|
||
var dt = _ref.dt;
|
||
return "\n.p-tieredmenu {\n background: ".concat(dt("tieredmenu.background"), ";\n color: ").concat(dt("tieredmenu.color"), ";\n border: 1px solid ").concat(dt("tieredmenu.border.color"), ";\n border-radius: ").concat(dt("tieredmenu.border.radius"), ";\n min-width: 12.5rem;\n}\n\n.p-tieredmenu-root-list,\n.p-tieredmenu-submenu {\n margin: 0;\n padding: ").concat(dt("tieredmenu.list.padding"), ";\n list-style: none;\n outline: 0 none;\n display: flex;\n flex-direction: column;\n gap: ").concat(dt("tieredmenu.list.gap"), ";\n}\n\n.p-tieredmenu-submenu {\n position: absolute;\n min-width: 100%;\n z-index: 1;\n background: ").concat(dt("tieredmenu.background"), ";\n color: ").concat(dt("tieredmenu.color"), ";\n border: 1px solid ").concat(dt("tieredmenu.border.color"), ";\n border-radius: ").concat(dt("tieredmenu.border.radius"), ";\n box-shadow: ").concat(dt("tieredmenu.shadow"), ";\n}\n\n.p-tieredmenu-item {\n position: relative;\n}\n\n.p-tieredmenu-item-content {\n transition: background ").concat(dt("tieredmenu.transition.duration"), ", color ").concat(dt("tieredmenu.transition.duration"), ";\n border-radius: ").concat(dt("tieredmenu.item.border.radius"), ";\n color: ").concat(dt("tieredmenu.item.color"), ";\n}\n\n.p-tieredmenu-item-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n color: inherit;\n padding: ").concat(dt("tieredmenu.item.padding"), ";\n gap: ").concat(dt("tieredmenu.item.gap"), ";\n user-select: none;\n outline: 0 none;\n}\n\n.p-tieredmenu-item-label {\n line-height: 1;\n}\n\n.p-tieredmenu-item-icon {\n color: ").concat(dt("tieredmenu.item.icon.color"), ";\n}\n\n.p-tieredmenu-submenu-icon {\n color: ").concat(dt("tieredmenu.submenu.icon.color"), ";\n margin-left: auto;\n font-size: ").concat(dt("tieredmenu.submenu.icon.size"), ";\n width: ").concat(dt("tieredmenu.submenu.icon.size"), ";\n height: ").concat(dt("tieredmenu.submenu.icon.size"), ";\n}\n\n.p-tieredmenu-item.p-focus > .p-tieredmenu-item-content {\n color: ").concat(dt("tieredmenu.item.focus.color"), ";\n background: ").concat(dt("tieredmenu.item.focus.background"), ";\n}\n\n.p-tieredmenu-item.p-focus > .p-tieredmenu-item-content .p-tieredmenu-item-icon {\n color: ").concat(dt("tieredmenu.item.icon.focus.color"), ";\n}\n\n.p-tieredmenu-item.p-focus > .p-tieredmenu-item-content .p-tieredmenu-submenu-icon {\n color: ").concat(dt("tieredmenu.submenu.icon.focus.color"), ";\n}\n\n.p-tieredmenu-item:not(.p-disabled) > .p-tieredmenu-item-content:hover {\n color: ").concat(dt("tieredmenu.item.focus.color"), ";\n background: ").concat(dt("tieredmenu.item.focus.background"), ";\n}\n\n.p-tieredmenu-item:not(.p-disabled) > .p-tieredmenu-item-content:hover .p-tieredmenu-item-icon {\n color: ").concat(dt("tieredmenu.item.icon.focus.color"), ";\n}\n\n.p-tieredmenu-item:not(.p-disabled) > .p-tieredmenu-item-content:hover .p-tieredmenu-submenu-icon {\n color: ").concat(dt("tieredmenu.submenu.icon.focus.color"), ";\n}\n\n.p-tieredmenu-item-active > .p-tieredmenu-item-content {\n color: ").concat(dt("tieredmenu.item.active.color"), ";\n background: ").concat(dt("tieredmenu.item.active.background"), ";\n}\n\n.p-tieredmenu-item-active > .p-tieredmenu-item-content .p-tieredmenu-item-icon {\n color: ").concat(dt("tieredmenu.item.icon.active.color"), ";\n}\n\n.p-tieredmenu-item-active > .p-tieredmenu-item-content .p-tieredmenu-submenu-icon {\n color: ").concat(dt("tieredmenu.submenu.icon.active.color"), ";\n}\n\n.p-tieredmenu-separator {\n border-top: 1px solid ").concat(dt("tieredmenu.separator.border.color"), ";\n}\n\n.p-tieredmenu-overlay {\n box-shadow: ").concat(dt("tieredmenu.shadow"), ";\n}\n\n.p-tieredmenu-enter-from,\n.p-tieredmenu-leave-active {\n opacity: 0;\n}\n\n.p-tieredmenu-enter-active {\n transition: opacity 250ms;\n}\n");
|
||
}, "theme");
|
||
var inlineStyles = {
|
||
submenu: /* @__PURE__ */ __name(function submenu2(_ref2) {
|
||
var instance = _ref2.instance, processedItem = _ref2.processedItem;
|
||
return {
|
||
display: instance.isItemActive(processedItem) ? "flex" : "none"
|
||
};
|
||
}, "submenu")
|
||
};
|
||
var classes$1 = {
|
||
root: /* @__PURE__ */ __name(function root10(_ref3) {
|
||
_ref3.instance;
|
||
var props = _ref3.props;
|
||
return ["p-tieredmenu p-component", {
|
||
"p-tieredmenu-overlay": props.popup
|
||
}];
|
||
}, "root"),
|
||
start: "p-tieredmenu-start",
|
||
rootList: "p-tieredmenu-root-list",
|
||
item: /* @__PURE__ */ __name(function item2(_ref4) {
|
||
var instance = _ref4.instance, processedItem = _ref4.processedItem;
|
||
return ["p-tieredmenu-item", {
|
||
"p-tieredmenu-item-active": instance.isItemActive(processedItem),
|
||
"p-focus": instance.isItemFocused(processedItem),
|
||
"p-disabled": instance.isItemDisabled(processedItem)
|
||
}];
|
||
}, "item"),
|
||
itemContent: "p-tieredmenu-item-content",
|
||
itemLink: "p-tieredmenu-item-link",
|
||
itemIcon: "p-tieredmenu-item-icon",
|
||
itemLabel: "p-tieredmenu-item-label",
|
||
submenuIcon: "p-tieredmenu-submenu-icon",
|
||
submenu: "p-tieredmenu-submenu",
|
||
separator: "p-tieredmenu-separator",
|
||
end: "p-tieredmenu-end"
|
||
};
|
||
var TieredMenuStyle = BaseStyle.extend({
|
||
name: "tieredmenu",
|
||
theme: theme$1,
|
||
classes: classes$1,
|
||
inlineStyles
|
||
});
|
||
var script$2 = {
|
||
name: "BaseTieredMenu",
|
||
"extends": script$g,
|
||
props: {
|
||
popup: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
model: {
|
||
type: Array,
|
||
"default": null
|
||
},
|
||
appendTo: {
|
||
type: [String, Object],
|
||
"default": "body"
|
||
},
|
||
autoZIndex: {
|
||
type: Boolean,
|
||
"default": true
|
||
},
|
||
baseZIndex: {
|
||
type: Number,
|
||
"default": 0
|
||
},
|
||
disabled: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
tabindex: {
|
||
type: Number,
|
||
"default": 0
|
||
},
|
||
ariaLabelledby: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
ariaLabel: {
|
||
type: String,
|
||
"default": null
|
||
}
|
||
},
|
||
style: TieredMenuStyle,
|
||
provide: /* @__PURE__ */ __name(function provide12() {
|
||
return {
|
||
$pcTieredMenu: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script$1$1 = {
|
||
name: "TieredMenuSub",
|
||
hostName: "TieredMenu",
|
||
"extends": script$g,
|
||
emits: ["item-click", "item-mouseenter", "item-mousemove"],
|
||
container: null,
|
||
props: {
|
||
menuId: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
focusedItemId: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
items: {
|
||
type: Array,
|
||
"default": null
|
||
},
|
||
visible: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
level: {
|
||
type: Number,
|
||
"default": 0
|
||
},
|
||
templates: {
|
||
type: Object,
|
||
"default": null
|
||
},
|
||
activeItemPath: {
|
||
type: Object,
|
||
"default": null
|
||
},
|
||
tabindex: {
|
||
type: Number,
|
||
"default": 0
|
||
}
|
||
},
|
||
methods: {
|
||
getItemId: /* @__PURE__ */ __name(function getItemId2(processedItem) {
|
||
return "".concat(this.menuId, "_").concat(processedItem.key);
|
||
}, "getItemId"),
|
||
getItemKey: /* @__PURE__ */ __name(function getItemKey2(processedItem) {
|
||
return this.getItemId(processedItem);
|
||
}, "getItemKey"),
|
||
getItemProp: /* @__PURE__ */ __name(function getItemProp3(processedItem, name, params) {
|
||
return processedItem && processedItem.item ? resolve(processedItem.item[name], params) : void 0;
|
||
}, "getItemProp"),
|
||
getItemLabel: /* @__PURE__ */ __name(function getItemLabel3(processedItem) {
|
||
return this.getItemProp(processedItem, "label");
|
||
}, "getItemLabel"),
|
||
getItemLabelId: /* @__PURE__ */ __name(function getItemLabelId2(processedItem) {
|
||
return "".concat(this.menuId, "_").concat(processedItem.key, "_label");
|
||
}, "getItemLabelId"),
|
||
getPTOptions: /* @__PURE__ */ __name(function getPTOptions5(processedItem, index, key) {
|
||
return this.ptm(key, {
|
||
context: {
|
||
item: processedItem.item,
|
||
index,
|
||
active: this.isItemActive(processedItem),
|
||
focused: this.isItemFocused(processedItem),
|
||
disabled: this.isItemDisabled(processedItem)
|
||
}
|
||
});
|
||
}, "getPTOptions"),
|
||
isItemActive: /* @__PURE__ */ __name(function isItemActive2(processedItem) {
|
||
return this.activeItemPath.some(function(path) {
|
||
return path.key === processedItem.key;
|
||
});
|
||
}, "isItemActive"),
|
||
isItemVisible: /* @__PURE__ */ __name(function isItemVisible3(processedItem) {
|
||
return this.getItemProp(processedItem, "visible") !== false;
|
||
}, "isItemVisible"),
|
||
isItemDisabled: /* @__PURE__ */ __name(function isItemDisabled3(processedItem) {
|
||
return this.getItemProp(processedItem, "disabled");
|
||
}, "isItemDisabled"),
|
||
isItemFocused: /* @__PURE__ */ __name(function isItemFocused2(processedItem) {
|
||
return this.focusedItemId === this.getItemId(processedItem);
|
||
}, "isItemFocused"),
|
||
isItemGroup: /* @__PURE__ */ __name(function isItemGroup3(processedItem) {
|
||
return isNotEmpty(processedItem.items);
|
||
}, "isItemGroup"),
|
||
onEnter: /* @__PURE__ */ __name(function onEnter2() {
|
||
nestedPosition(this.container, this.level);
|
||
}, "onEnter"),
|
||
onItemClick: /* @__PURE__ */ __name(function onItemClick3(event, processedItem) {
|
||
this.getItemProp(processedItem, "command", {
|
||
originalEvent: event,
|
||
item: processedItem.item
|
||
});
|
||
this.$emit("item-click", {
|
||
originalEvent: event,
|
||
processedItem,
|
||
isFocus: true
|
||
});
|
||
}, "onItemClick"),
|
||
onItemMouseEnter: /* @__PURE__ */ __name(function onItemMouseEnter3(event, processedItem) {
|
||
this.$emit("item-mouseenter", {
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
}, "onItemMouseEnter"),
|
||
onItemMouseMove: /* @__PURE__ */ __name(function onItemMouseMove3(event, processedItem) {
|
||
this.$emit("item-mousemove", {
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
}, "onItemMouseMove"),
|
||
getAriaSetSize: /* @__PURE__ */ __name(function getAriaSetSize2() {
|
||
var _this = this;
|
||
return this.items.filter(function(processedItem) {
|
||
return _this.isItemVisible(processedItem) && !_this.getItemProp(processedItem, "separator");
|
||
}).length;
|
||
}, "getAriaSetSize"),
|
||
getAriaPosInset: /* @__PURE__ */ __name(function getAriaPosInset3(index) {
|
||
var _this2 = this;
|
||
return index - this.items.slice(0, index).filter(function(processedItem) {
|
||
return _this2.isItemVisible(processedItem) && _this2.getItemProp(processedItem, "separator");
|
||
}).length + 1;
|
||
}, "getAriaPosInset"),
|
||
getMenuItemProps: /* @__PURE__ */ __name(function getMenuItemProps2(processedItem, index) {
|
||
return {
|
||
action: mergeProps({
|
||
"class": this.cx("itemLink"),
|
||
tabindex: -1,
|
||
"aria-hidden": true
|
||
}, this.getPTOptions(processedItem, index, "itemLink")),
|
||
icon: mergeProps({
|
||
"class": [this.cx("itemIcon"), this.getItemProp(processedItem, "icon")]
|
||
}, this.getPTOptions(processedItem, index, "itemIcon")),
|
||
label: mergeProps({
|
||
"class": this.cx("itemLabel")
|
||
}, this.getPTOptions(processedItem, index, "itemLabel")),
|
||
submenuicon: mergeProps({
|
||
"class": this.cx("submenuIcon")
|
||
}, this.getPTOptions(processedItem, index, "submenuIcon"))
|
||
};
|
||
}, "getMenuItemProps"),
|
||
containerRef: /* @__PURE__ */ __name(function containerRef2(el) {
|
||
this.container = el;
|
||
}, "containerRef")
|
||
},
|
||
components: {
|
||
AngleRightIcon: script$z
|
||
},
|
||
directives: {
|
||
ripple: Ripple
|
||
}
|
||
};
|
||
var _hoisted_1$1$1 = ["tabindex"];
|
||
var _hoisted_2$3 = ["id", "aria-label", "aria-disabled", "aria-expanded", "aria-haspopup", "aria-level", "aria-setsize", "aria-posinset", "data-p-active", "data-p-focused", "data-p-disabled"];
|
||
var _hoisted_3$2 = ["onClick", "onMouseenter", "onMousemove"];
|
||
var _hoisted_4 = ["href", "target"];
|
||
var _hoisted_5 = ["id"];
|
||
var _hoisted_6 = ["id"];
|
||
function render$1$1(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _component_AngleRightIcon = resolveComponent("AngleRightIcon");
|
||
var _component_TieredMenuSub = resolveComponent("TieredMenuSub", true);
|
||
var _directive_ripple = resolveDirective("ripple");
|
||
return openBlock(), createBlock(Transition, mergeProps({
|
||
name: "p-tieredmenu",
|
||
onEnter: $options.onEnter
|
||
}, _ctx.ptm("menu.transition")), {
|
||
"default": withCtx(function() {
|
||
return [($props.level === 0 ? true : $props.visible) ? (openBlock(), createElementBlock("ul", mergeProps({
|
||
key: 0,
|
||
ref: $options.containerRef,
|
||
"class": $props.level === 0 ? _ctx.cx("rootList") : _ctx.cx("submenu"),
|
||
tabindex: $props.tabindex
|
||
}, $props.level === 0 ? _ctx.ptm("rootList") : _ctx.ptm("submenu")), [(openBlock(true), createElementBlock(Fragment, null, renderList($props.items, function(processedItem, index) {
|
||
return openBlock(), createElementBlock(Fragment, {
|
||
key: $options.getItemKey(processedItem)
|
||
}, [$options.isItemVisible(processedItem) && !$options.getItemProp(processedItem, "separator") ? (openBlock(), createElementBlock("li", mergeProps({
|
||
key: 0,
|
||
id: $options.getItemId(processedItem),
|
||
style: $options.getItemProp(processedItem, "style"),
|
||
"class": [_ctx.cx("item", {
|
||
processedItem
|
||
}), $options.getItemProp(processedItem, "class")],
|
||
role: "menuitem",
|
||
"aria-label": $options.getItemLabel(processedItem),
|
||
"aria-disabled": $options.isItemDisabled(processedItem) || void 0,
|
||
"aria-expanded": $options.isItemGroup(processedItem) ? $options.isItemActive(processedItem) : void 0,
|
||
"aria-haspopup": $options.isItemGroup(processedItem) && !$options.getItemProp(processedItem, "to") ? "menu" : void 0,
|
||
"aria-level": $props.level + 1,
|
||
"aria-setsize": $options.getAriaSetSize(),
|
||
"aria-posinset": $options.getAriaPosInset(index),
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "item"), {
|
||
"data-p-active": $options.isItemActive(processedItem),
|
||
"data-p-focused": $options.isItemFocused(processedItem),
|
||
"data-p-disabled": $options.isItemDisabled(processedItem)
|
||
}), [createBaseVNode("div", mergeProps({
|
||
"class": _ctx.cx("itemContent"),
|
||
onClick: /* @__PURE__ */ __name(function onClick2($event) {
|
||
return $options.onItemClick($event, processedItem);
|
||
}, "onClick"),
|
||
onMouseenter: /* @__PURE__ */ __name(function onMouseenter($event) {
|
||
return $options.onItemMouseEnter($event, processedItem);
|
||
}, "onMouseenter"),
|
||
onMousemove: /* @__PURE__ */ __name(function onMousemove($event) {
|
||
return $options.onItemMouseMove($event, processedItem);
|
||
}, "onMousemove"),
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "itemContent")), [!$props.templates.item ? withDirectives((openBlock(), createElementBlock("a", mergeProps({
|
||
key: 0,
|
||
href: $options.getItemProp(processedItem, "url"),
|
||
"class": _ctx.cx("itemLink"),
|
||
target: $options.getItemProp(processedItem, "target"),
|
||
tabindex: "-1",
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "itemLink")), [$props.templates.itemicon ? (openBlock(), createBlock(resolveDynamicComponent($props.templates.itemicon), {
|
||
key: 0,
|
||
item: processedItem.item,
|
||
"class": normalizeClass(_ctx.cx("itemIcon"))
|
||
}, null, 8, ["item", "class"])) : $options.getItemProp(processedItem, "icon") ? (openBlock(), createElementBlock("span", mergeProps({
|
||
key: 1,
|
||
"class": [_ctx.cx("itemIcon"), $options.getItemProp(processedItem, "icon")],
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "itemIcon")), null, 16)) : createCommentVNode("", true), createBaseVNode("span", mergeProps({
|
||
id: $options.getItemLabelId(processedItem),
|
||
"class": _ctx.cx("itemLabel"),
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "itemLabel")), toDisplayString($options.getItemLabel(processedItem)), 17, _hoisted_5), $options.getItemProp(processedItem, "items") ? (openBlock(), createElementBlock(Fragment, {
|
||
key: 2
|
||
}, [$props.templates.submenuicon ? (openBlock(), createBlock(resolveDynamicComponent($props.templates.submenuicon), mergeProps({
|
||
key: 0,
|
||
"class": _ctx.cx("submenuIcon"),
|
||
active: $options.isItemActive(processedItem),
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "submenuIcon")), null, 16, ["class", "active"])) : (openBlock(), createBlock(_component_AngleRightIcon, mergeProps({
|
||
key: 1,
|
||
"class": _ctx.cx("submenuIcon"),
|
||
ref_for: true
|
||
}, $options.getPTOptions(processedItem, index, "submenuIcon")), null, 16, ["class"]))], 64)) : createCommentVNode("", true)], 16, _hoisted_4)), [[_directive_ripple]]) : (openBlock(), createBlock(resolveDynamicComponent($props.templates.item), {
|
||
key: 1,
|
||
item: processedItem.item,
|
||
hasSubmenu: $options.getItemProp(processedItem, "items"),
|
||
label: $options.getItemLabel(processedItem),
|
||
props: $options.getMenuItemProps(processedItem, index)
|
||
}, null, 8, ["item", "hasSubmenu", "label", "props"]))], 16, _hoisted_3$2), $options.isItemVisible(processedItem) && $options.isItemGroup(processedItem) ? (openBlock(), createBlock(_component_TieredMenuSub, {
|
||
key: 0,
|
||
id: $options.getItemId(processedItem) + "_list",
|
||
style: normalizeStyle(_ctx.sx("submenu", true, {
|
||
processedItem
|
||
})),
|
||
"aria-labelledby": $options.getItemLabelId(processedItem),
|
||
role: "menu",
|
||
menuId: $props.menuId,
|
||
focusedItemId: $props.focusedItemId,
|
||
items: processedItem.items,
|
||
templates: $props.templates,
|
||
activeItemPath: $props.activeItemPath,
|
||
level: $props.level + 1,
|
||
visible: $options.isItemActive(processedItem) && $options.isItemGroup(processedItem),
|
||
pt: _ctx.pt,
|
||
unstyled: _ctx.unstyled,
|
||
onItemClick: _cache[0] || (_cache[0] = function($event) {
|
||
return _ctx.$emit("item-click", $event);
|
||
}),
|
||
onItemMouseenter: _cache[1] || (_cache[1] = function($event) {
|
||
return _ctx.$emit("item-mouseenter", $event);
|
||
}),
|
||
onItemMousemove: _cache[2] || (_cache[2] = function($event) {
|
||
return _ctx.$emit("item-mousemove", $event);
|
||
})
|
||
}, null, 8, ["id", "style", "aria-labelledby", "menuId", "focusedItemId", "items", "templates", "activeItemPath", "level", "visible", "pt", "unstyled"])) : createCommentVNode("", true)], 16, _hoisted_2$3)) : createCommentVNode("", true), $options.isItemVisible(processedItem) && $options.getItemProp(processedItem, "separator") ? (openBlock(), createElementBlock("li", mergeProps({
|
||
key: 1,
|
||
id: $options.getItemId(processedItem),
|
||
style: $options.getItemProp(processedItem, "style"),
|
||
"class": [_ctx.cx("separator"), $options.getItemProp(processedItem, "class")],
|
||
role: "separator",
|
||
ref_for: true
|
||
}, _ctx.ptm("separator")), null, 16, _hoisted_6)) : createCommentVNode("", true)], 64);
|
||
}), 128))], 16, _hoisted_1$1$1)) : createCommentVNode("", true)];
|
||
}),
|
||
_: 1
|
||
}, 16, ["onEnter"]);
|
||
}
|
||
__name(render$1$1, "render$1$1");
|
||
script$1$1.render = render$1$1;
|
||
var script$3 = {
|
||
name: "TieredMenu",
|
||
"extends": script$2,
|
||
inheritAttrs: false,
|
||
emits: ["focus", "blur", "before-show", "before-hide", "hide", "show"],
|
||
outsideClickListener: null,
|
||
scrollHandler: null,
|
||
resizeListener: null,
|
||
target: null,
|
||
container: null,
|
||
menubar: null,
|
||
searchTimeout: null,
|
||
searchValue: null,
|
||
data: /* @__PURE__ */ __name(function data8() {
|
||
return {
|
||
id: this.$attrs.id,
|
||
focused: false,
|
||
focusedItemInfo: {
|
||
index: -1,
|
||
level: 0,
|
||
parentKey: ""
|
||
},
|
||
activeItemPath: [],
|
||
visible: !this.popup,
|
||
submenuVisible: false,
|
||
dirty: false
|
||
};
|
||
}, "data"),
|
||
watch: {
|
||
"$attrs.id": /* @__PURE__ */ __name(function $attrsId4(newValue) {
|
||
this.id = newValue || UniqueComponentId();
|
||
}, "$attrsId"),
|
||
activeItemPath: /* @__PURE__ */ __name(function activeItemPath2(newPath) {
|
||
if (!this.popup) {
|
||
if (isNotEmpty(newPath)) {
|
||
this.bindOutsideClickListener();
|
||
this.bindResizeListener();
|
||
} else {
|
||
this.unbindOutsideClickListener();
|
||
this.unbindResizeListener();
|
||
}
|
||
}
|
||
}, "activeItemPath")
|
||
},
|
||
mounted: /* @__PURE__ */ __name(function mounted8() {
|
||
this.id = this.id || UniqueComponentId();
|
||
}, "mounted"),
|
||
beforeUnmount: /* @__PURE__ */ __name(function beforeUnmount7() {
|
||
this.unbindOutsideClickListener();
|
||
this.unbindResizeListener();
|
||
if (this.scrollHandler) {
|
||
this.scrollHandler.destroy();
|
||
this.scrollHandler = null;
|
||
}
|
||
if (this.container && this.autoZIndex) {
|
||
ZIndex.clear(this.container);
|
||
}
|
||
this.target = null;
|
||
this.container = null;
|
||
}, "beforeUnmount"),
|
||
methods: {
|
||
getItemProp: /* @__PURE__ */ __name(function getItemProp4(item3, name) {
|
||
return item3 ? resolve(item3[name]) : void 0;
|
||
}, "getItemProp"),
|
||
getItemLabel: /* @__PURE__ */ __name(function getItemLabel4(item3) {
|
||
return this.getItemProp(item3, "label");
|
||
}, "getItemLabel"),
|
||
isItemDisabled: /* @__PURE__ */ __name(function isItemDisabled4(item3) {
|
||
return this.getItemProp(item3, "disabled");
|
||
}, "isItemDisabled"),
|
||
isItemVisible: /* @__PURE__ */ __name(function isItemVisible4(item3) {
|
||
return this.getItemProp(item3, "visible") !== false;
|
||
}, "isItemVisible"),
|
||
isItemGroup: /* @__PURE__ */ __name(function isItemGroup4(item3) {
|
||
return isNotEmpty(this.getItemProp(item3, "items"));
|
||
}, "isItemGroup"),
|
||
isItemSeparator: /* @__PURE__ */ __name(function isItemSeparator2(item3) {
|
||
return this.getItemProp(item3, "separator");
|
||
}, "isItemSeparator"),
|
||
getProccessedItemLabel: /* @__PURE__ */ __name(function getProccessedItemLabel2(processedItem) {
|
||
return processedItem ? this.getItemLabel(processedItem.item) : void 0;
|
||
}, "getProccessedItemLabel"),
|
||
isProccessedItemGroup: /* @__PURE__ */ __name(function isProccessedItemGroup2(processedItem) {
|
||
return processedItem && isNotEmpty(processedItem.items);
|
||
}, "isProccessedItemGroup"),
|
||
toggle: /* @__PURE__ */ __name(function toggle3(event) {
|
||
this.visible ? this.hide(event, true) : this.show(event);
|
||
}, "toggle"),
|
||
show: /* @__PURE__ */ __name(function show3(event, isFocus) {
|
||
if (this.popup) {
|
||
this.$emit("before-show");
|
||
this.visible = true;
|
||
this.target = this.target || event.currentTarget;
|
||
this.relatedTarget = event.relatedTarget || null;
|
||
}
|
||
isFocus && focus(this.menubar);
|
||
}, "show"),
|
||
hide: /* @__PURE__ */ __name(function hide3(event, isFocus) {
|
||
if (this.popup) {
|
||
this.$emit("before-hide");
|
||
this.visible = false;
|
||
}
|
||
this.activeItemPath = [];
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
level: 0,
|
||
parentKey: ""
|
||
};
|
||
isFocus && focus(this.relatedTarget || this.target || this.menubar);
|
||
this.dirty = false;
|
||
}, "hide"),
|
||
onFocus: /* @__PURE__ */ __name(function onFocus4(event) {
|
||
this.focused = true;
|
||
if (!this.popup) {
|
||
this.focusedItemInfo = this.focusedItemInfo.index !== -1 ? this.focusedItemInfo : {
|
||
index: this.findFirstFocusedItemIndex(),
|
||
level: 0,
|
||
parentKey: ""
|
||
};
|
||
}
|
||
this.$emit("focus", event);
|
||
}, "onFocus"),
|
||
onBlur: /* @__PURE__ */ __name(function onBlur3(event) {
|
||
this.focused = false;
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
level: 0,
|
||
parentKey: ""
|
||
};
|
||
this.searchValue = "";
|
||
this.dirty = false;
|
||
this.$emit("blur", event);
|
||
}, "onBlur"),
|
||
onKeyDown: /* @__PURE__ */ __name(function onKeyDown4(event) {
|
||
if (this.disabled) {
|
||
event.preventDefault();
|
||
return;
|
||
}
|
||
var metaKey = event.metaKey || event.ctrlKey;
|
||
switch (event.code) {
|
||
case "ArrowDown":
|
||
this.onArrowDownKey(event);
|
||
break;
|
||
case "ArrowUp":
|
||
this.onArrowUpKey(event);
|
||
break;
|
||
case "ArrowLeft":
|
||
this.onArrowLeftKey(event);
|
||
break;
|
||
case "ArrowRight":
|
||
this.onArrowRightKey(event);
|
||
break;
|
||
case "Home":
|
||
this.onHomeKey(event);
|
||
break;
|
||
case "End":
|
||
this.onEndKey(event);
|
||
break;
|
||
case "Space":
|
||
this.onSpaceKey(event);
|
||
break;
|
||
case "Enter":
|
||
case "NumpadEnter":
|
||
this.onEnterKey(event);
|
||
break;
|
||
case "Escape":
|
||
this.onEscapeKey(event);
|
||
break;
|
||
case "Tab":
|
||
this.onTabKey(event);
|
||
break;
|
||
case "PageDown":
|
||
case "PageUp":
|
||
case "Backspace":
|
||
case "ShiftLeft":
|
||
case "ShiftRight":
|
||
break;
|
||
default:
|
||
if (!metaKey && isPrintableCharacter(event.key)) {
|
||
this.searchItems(event, event.key);
|
||
}
|
||
break;
|
||
}
|
||
}, "onKeyDown"),
|
||
onItemChange: /* @__PURE__ */ __name(function onItemChange2(event) {
|
||
var processedItem = event.processedItem, isFocus = event.isFocus;
|
||
if (isEmpty(processedItem)) return;
|
||
var index = processedItem.index, key = processedItem.key, level = processedItem.level, parentKey = processedItem.parentKey, items = processedItem.items;
|
||
var grouped = isNotEmpty(items);
|
||
var activeItemPath3 = this.activeItemPath.filter(function(p) {
|
||
return p.parentKey !== parentKey && p.parentKey !== key;
|
||
});
|
||
if (grouped) {
|
||
activeItemPath3.push(processedItem);
|
||
this.submenuVisible = true;
|
||
}
|
||
this.focusedItemInfo = {
|
||
index,
|
||
level,
|
||
parentKey
|
||
};
|
||
this.activeItemPath = activeItemPath3;
|
||
grouped && (this.dirty = true);
|
||
isFocus && focus(this.menubar);
|
||
}, "onItemChange"),
|
||
onOverlayClick: /* @__PURE__ */ __name(function onOverlayClick2(event) {
|
||
OverlayEventBus.emit("overlay-click", {
|
||
originalEvent: event,
|
||
target: this.target
|
||
});
|
||
}, "onOverlayClick"),
|
||
onItemClick: /* @__PURE__ */ __name(function onItemClick4(event) {
|
||
var originalEvent = event.originalEvent, processedItem = event.processedItem;
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
var root12 = isEmpty(processedItem.parent);
|
||
var selected = this.isSelected(processedItem);
|
||
if (selected) {
|
||
var index = processedItem.index, key = processedItem.key, level = processedItem.level, parentKey = processedItem.parentKey;
|
||
this.activeItemPath = this.activeItemPath.filter(function(p) {
|
||
return key !== p.key && key.startsWith(p.key);
|
||
});
|
||
this.focusedItemInfo = {
|
||
index,
|
||
level,
|
||
parentKey
|
||
};
|
||
this.dirty = !root12;
|
||
focus(this.menubar);
|
||
} else {
|
||
if (grouped) {
|
||
this.onItemChange(event);
|
||
} else {
|
||
var rootProcessedItem = root12 ? processedItem : this.activeItemPath.find(function(p) {
|
||
return p.parentKey === "";
|
||
});
|
||
this.hide(originalEvent);
|
||
this.changeFocusedItemIndex(originalEvent, rootProcessedItem ? rootProcessedItem.index : -1);
|
||
focus(this.menubar);
|
||
}
|
||
}
|
||
}, "onItemClick"),
|
||
onItemMouseEnter: /* @__PURE__ */ __name(function onItemMouseEnter4(event) {
|
||
if (this.dirty) {
|
||
this.onItemChange(event);
|
||
}
|
||
}, "onItemMouseEnter"),
|
||
onItemMouseMove: /* @__PURE__ */ __name(function onItemMouseMove4(event) {
|
||
if (this.focused) {
|
||
this.changeFocusedItemIndex(event, event.processedItem.index);
|
||
}
|
||
}, "onItemMouseMove"),
|
||
onArrowDownKey: /* @__PURE__ */ __name(function onArrowDownKey3(event) {
|
||
var itemIndex = this.focusedItemInfo.index !== -1 ? this.findNextItemIndex(this.focusedItemInfo.index) : this.findFirstFocusedItemIndex();
|
||
this.changeFocusedItemIndex(event, itemIndex);
|
||
event.preventDefault();
|
||
}, "onArrowDownKey"),
|
||
onArrowUpKey: /* @__PURE__ */ __name(function onArrowUpKey3(event) {
|
||
if (event.altKey) {
|
||
if (this.focusedItemInfo.index !== -1) {
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
!grouped && this.onItemChange({
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
}
|
||
this.popup && this.hide(event, true);
|
||
event.preventDefault();
|
||
} else {
|
||
var itemIndex = this.focusedItemInfo.index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo.index) : this.findLastFocusedItemIndex();
|
||
this.changeFocusedItemIndex(event, itemIndex);
|
||
event.preventDefault();
|
||
}
|
||
}, "onArrowUpKey"),
|
||
onArrowLeftKey: /* @__PURE__ */ __name(function onArrowLeftKey4(event) {
|
||
var _this = this;
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var parentItem = this.activeItemPath.find(function(p) {
|
||
return p.key === processedItem.parentKey;
|
||
});
|
||
var root12 = isEmpty(processedItem.parent);
|
||
if (!root12) {
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
parentKey: parentItem ? parentItem.parentKey : ""
|
||
};
|
||
this.searchValue = "";
|
||
this.onArrowDownKey(event);
|
||
}
|
||
this.activeItemPath = this.activeItemPath.filter(function(p) {
|
||
return p.parentKey !== _this.focusedItemInfo.parentKey;
|
||
});
|
||
event.preventDefault();
|
||
}, "onArrowLeftKey"),
|
||
onArrowRightKey: /* @__PURE__ */ __name(function onArrowRightKey4(event) {
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
if (grouped) {
|
||
this.onItemChange({
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
this.focusedItemInfo = {
|
||
index: -1,
|
||
parentKey: processedItem.key
|
||
};
|
||
this.searchValue = "";
|
||
this.onArrowDownKey(event);
|
||
}
|
||
event.preventDefault();
|
||
}, "onArrowRightKey"),
|
||
onHomeKey: /* @__PURE__ */ __name(function onHomeKey4(event) {
|
||
this.changeFocusedItemIndex(event, this.findFirstItemIndex());
|
||
event.preventDefault();
|
||
}, "onHomeKey"),
|
||
onEndKey: /* @__PURE__ */ __name(function onEndKey4(event) {
|
||
this.changeFocusedItemIndex(event, this.findLastItemIndex());
|
||
event.preventDefault();
|
||
}, "onEndKey"),
|
||
onEnterKey: /* @__PURE__ */ __name(function onEnterKey4(event) {
|
||
if (this.focusedItemInfo.index !== -1) {
|
||
var element = findSingle(this.menubar, 'li[id="'.concat("".concat(this.focusedItemId), '"]'));
|
||
var anchorElement = element && findSingle(element, '[data-pc-section="itemlink"]');
|
||
anchorElement ? anchorElement.click() : element && element.click();
|
||
if (!this.popup) {
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
!grouped && (this.focusedItemInfo.index = this.findFirstFocusedItemIndex());
|
||
}
|
||
}
|
||
event.preventDefault();
|
||
}, "onEnterKey"),
|
||
onSpaceKey: /* @__PURE__ */ __name(function onSpaceKey2(event) {
|
||
this.onEnterKey(event);
|
||
}, "onSpaceKey"),
|
||
onEscapeKey: /* @__PURE__ */ __name(function onEscapeKey3(event) {
|
||
if (this.popup || this.focusedItemInfo.level !== 0) {
|
||
var _focusedItemInfo = this.focusedItemInfo;
|
||
this.hide(event, false);
|
||
this.focusedItemInfo = {
|
||
index: Number(_focusedItemInfo.parentKey.split("_")[0]),
|
||
level: 0,
|
||
parentKey: ""
|
||
};
|
||
this.popup && focus(this.target);
|
||
}
|
||
event.preventDefault();
|
||
}, "onEscapeKey"),
|
||
onTabKey: /* @__PURE__ */ __name(function onTabKey3(event) {
|
||
if (this.focusedItemInfo.index !== -1) {
|
||
var processedItem = this.visibleItems[this.focusedItemInfo.index];
|
||
var grouped = this.isProccessedItemGroup(processedItem);
|
||
!grouped && this.onItemChange({
|
||
originalEvent: event,
|
||
processedItem
|
||
});
|
||
}
|
||
this.hide();
|
||
}, "onTabKey"),
|
||
onEnter: /* @__PURE__ */ __name(function onEnter3(el) {
|
||
if (this.autoZIndex) {
|
||
ZIndex.set("menu", el, this.baseZIndex + this.$primevue.config.zIndex.menu);
|
||
}
|
||
addStyle(el, {
|
||
position: "absolute",
|
||
top: "0",
|
||
left: "0"
|
||
});
|
||
this.alignOverlay();
|
||
focus(this.menubar);
|
||
this.scrollInView();
|
||
}, "onEnter"),
|
||
onAfterEnter: /* @__PURE__ */ __name(function onAfterEnter() {
|
||
this.bindOutsideClickListener();
|
||
this.bindScrollListener();
|
||
this.bindResizeListener();
|
||
this.$emit("show");
|
||
}, "onAfterEnter"),
|
||
onLeave: /* @__PURE__ */ __name(function onLeave2() {
|
||
this.unbindOutsideClickListener();
|
||
this.unbindScrollListener();
|
||
this.unbindResizeListener();
|
||
this.$emit("hide");
|
||
this.container = null;
|
||
this.dirty = false;
|
||
}, "onLeave"),
|
||
onAfterLeave: /* @__PURE__ */ __name(function onAfterLeave(el) {
|
||
if (this.autoZIndex) {
|
||
ZIndex.clear(el);
|
||
}
|
||
}, "onAfterLeave"),
|
||
alignOverlay: /* @__PURE__ */ __name(function alignOverlay2() {
|
||
absolutePosition(this.container, this.target);
|
||
var targetWidth = getOuterWidth(this.target);
|
||
if (targetWidth > getOuterWidth(this.container)) {
|
||
this.container.style.minWidth = getOuterWidth(this.target) + "px";
|
||
}
|
||
}, "alignOverlay"),
|
||
bindOutsideClickListener: /* @__PURE__ */ __name(function bindOutsideClickListener3() {
|
||
var _this2 = this;
|
||
if (!this.outsideClickListener) {
|
||
this.outsideClickListener = function(event) {
|
||
var isOutsideContainer = _this2.container && !_this2.container.contains(event.target);
|
||
var isOutsideTarget = _this2.popup ? !(_this2.target && (_this2.target === event.target || _this2.target.contains(event.target))) : true;
|
||
if (isOutsideContainer && isOutsideTarget) {
|
||
_this2.hide();
|
||
}
|
||
};
|
||
document.addEventListener("click", this.outsideClickListener);
|
||
}
|
||
}, "bindOutsideClickListener"),
|
||
unbindOutsideClickListener: /* @__PURE__ */ __name(function unbindOutsideClickListener3() {
|
||
if (this.outsideClickListener) {
|
||
document.removeEventListener("click", this.outsideClickListener);
|
||
this.outsideClickListener = null;
|
||
}
|
||
}, "unbindOutsideClickListener"),
|
||
bindScrollListener: /* @__PURE__ */ __name(function bindScrollListener2() {
|
||
var _this3 = this;
|
||
if (!this.scrollHandler) {
|
||
this.scrollHandler = new ConnectedOverlayScrollHandler(this.target, function(event) {
|
||
_this3.hide(event, true);
|
||
});
|
||
}
|
||
this.scrollHandler.bindScrollListener();
|
||
}, "bindScrollListener"),
|
||
unbindScrollListener: /* @__PURE__ */ __name(function unbindScrollListener2() {
|
||
if (this.scrollHandler) {
|
||
this.scrollHandler.unbindScrollListener();
|
||
}
|
||
}, "unbindScrollListener"),
|
||
bindResizeListener: /* @__PURE__ */ __name(function bindResizeListener3() {
|
||
var _this4 = this;
|
||
if (!this.resizeListener) {
|
||
this.resizeListener = function(event) {
|
||
if (!isTouchDevice()) {
|
||
_this4.hide(event, true);
|
||
}
|
||
};
|
||
window.addEventListener("resize", this.resizeListener);
|
||
}
|
||
}, "bindResizeListener"),
|
||
unbindResizeListener: /* @__PURE__ */ __name(function unbindResizeListener3() {
|
||
if (this.resizeListener) {
|
||
window.removeEventListener("resize", this.resizeListener);
|
||
this.resizeListener = null;
|
||
}
|
||
}, "unbindResizeListener"),
|
||
isItemMatched: /* @__PURE__ */ __name(function isItemMatched2(processedItem) {
|
||
var _this$getProccessedIt;
|
||
return this.isValidItem(processedItem) && ((_this$getProccessedIt = this.getProccessedItemLabel(processedItem)) === null || _this$getProccessedIt === void 0 ? void 0 : _this$getProccessedIt.toLocaleLowerCase().startsWith(this.searchValue.toLocaleLowerCase()));
|
||
}, "isItemMatched"),
|
||
isValidItem: /* @__PURE__ */ __name(function isValidItem2(processedItem) {
|
||
return !!processedItem && !this.isItemDisabled(processedItem.item) && !this.isItemSeparator(processedItem.item) && this.isItemVisible(processedItem.item);
|
||
}, "isValidItem"),
|
||
isValidSelectedItem: /* @__PURE__ */ __name(function isValidSelectedItem2(processedItem) {
|
||
return this.isValidItem(processedItem) && this.isSelected(processedItem);
|
||
}, "isValidSelectedItem"),
|
||
isSelected: /* @__PURE__ */ __name(function isSelected3(processedItem) {
|
||
return this.activeItemPath.some(function(p) {
|
||
return p.key === processedItem.key;
|
||
});
|
||
}, "isSelected"),
|
||
findFirstItemIndex: /* @__PURE__ */ __name(function findFirstItemIndex2() {
|
||
var _this5 = this;
|
||
return this.visibleItems.findIndex(function(processedItem) {
|
||
return _this5.isValidItem(processedItem);
|
||
});
|
||
}, "findFirstItemIndex"),
|
||
findLastItemIndex: /* @__PURE__ */ __name(function findLastItemIndex2() {
|
||
var _this6 = this;
|
||
return findLastIndex(this.visibleItems, function(processedItem) {
|
||
return _this6.isValidItem(processedItem);
|
||
});
|
||
}, "findLastItemIndex"),
|
||
findNextItemIndex: /* @__PURE__ */ __name(function findNextItemIndex2(index) {
|
||
var _this7 = this;
|
||
var matchedItemIndex = index < this.visibleItems.length - 1 ? this.visibleItems.slice(index + 1).findIndex(function(processedItem) {
|
||
return _this7.isValidItem(processedItem);
|
||
}) : -1;
|
||
return matchedItemIndex > -1 ? matchedItemIndex + index + 1 : index;
|
||
}, "findNextItemIndex"),
|
||
findPrevItemIndex: /* @__PURE__ */ __name(function findPrevItemIndex2(index) {
|
||
var _this8 = this;
|
||
var matchedItemIndex = index > 0 ? findLastIndex(this.visibleItems.slice(0, index), function(processedItem) {
|
||
return _this8.isValidItem(processedItem);
|
||
}) : -1;
|
||
return matchedItemIndex > -1 ? matchedItemIndex : index;
|
||
}, "findPrevItemIndex"),
|
||
findSelectedItemIndex: /* @__PURE__ */ __name(function findSelectedItemIndex2() {
|
||
var _this9 = this;
|
||
return this.visibleItems.findIndex(function(processedItem) {
|
||
return _this9.isValidSelectedItem(processedItem);
|
||
});
|
||
}, "findSelectedItemIndex"),
|
||
findFirstFocusedItemIndex: /* @__PURE__ */ __name(function findFirstFocusedItemIndex2() {
|
||
var selectedIndex = this.findSelectedItemIndex();
|
||
return selectedIndex < 0 ? this.findFirstItemIndex() : selectedIndex;
|
||
}, "findFirstFocusedItemIndex"),
|
||
findLastFocusedItemIndex: /* @__PURE__ */ __name(function findLastFocusedItemIndex2() {
|
||
var selectedIndex = this.findSelectedItemIndex();
|
||
return selectedIndex < 0 ? this.findLastItemIndex() : selectedIndex;
|
||
}, "findLastFocusedItemIndex"),
|
||
searchItems: /* @__PURE__ */ __name(function searchItems2(event, _char) {
|
||
var _this10 = this;
|
||
this.searchValue = (this.searchValue || "") + _char;
|
||
var itemIndex = -1;
|
||
var matched = false;
|
||
if (this.focusedItemInfo.index !== -1) {
|
||
itemIndex = this.visibleItems.slice(this.focusedItemInfo.index).findIndex(function(processedItem) {
|
||
return _this10.isItemMatched(processedItem);
|
||
});
|
||
itemIndex = itemIndex === -1 ? this.visibleItems.slice(0, this.focusedItemInfo.index).findIndex(function(processedItem) {
|
||
return _this10.isItemMatched(processedItem);
|
||
}) : itemIndex + this.focusedItemInfo.index;
|
||
} else {
|
||
itemIndex = this.visibleItems.findIndex(function(processedItem) {
|
||
return _this10.isItemMatched(processedItem);
|
||
});
|
||
}
|
||
if (itemIndex !== -1) {
|
||
matched = true;
|
||
}
|
||
if (itemIndex === -1 && this.focusedItemInfo.index === -1) {
|
||
itemIndex = this.findFirstFocusedItemIndex();
|
||
}
|
||
if (itemIndex !== -1) {
|
||
this.changeFocusedItemIndex(event, itemIndex);
|
||
}
|
||
if (this.searchTimeout) {
|
||
clearTimeout(this.searchTimeout);
|
||
}
|
||
this.searchTimeout = setTimeout(function() {
|
||
_this10.searchValue = "";
|
||
_this10.searchTimeout = null;
|
||
}, 500);
|
||
return matched;
|
||
}, "searchItems"),
|
||
changeFocusedItemIndex: /* @__PURE__ */ __name(function changeFocusedItemIndex2(event, index) {
|
||
if (this.focusedItemInfo.index !== index) {
|
||
this.focusedItemInfo.index = index;
|
||
this.scrollInView();
|
||
}
|
||
}, "changeFocusedItemIndex"),
|
||
scrollInView: /* @__PURE__ */ __name(function scrollInView4() {
|
||
var index = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : -1;
|
||
var id2 = index !== -1 ? "".concat(this.id, "_").concat(index) : this.focusedItemId;
|
||
var element = findSingle(this.menubar, 'li[id="'.concat(id2, '"]'));
|
||
if (element) {
|
||
element.scrollIntoView && element.scrollIntoView({
|
||
block: "nearest",
|
||
inline: "start"
|
||
});
|
||
}
|
||
}, "scrollInView"),
|
||
createProcessedItems: /* @__PURE__ */ __name(function createProcessedItems2(items) {
|
||
var _this11 = this;
|
||
var level = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0;
|
||
var parent = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
|
||
var parentKey = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : "";
|
||
var processedItems3 = [];
|
||
items && items.forEach(function(item3, index) {
|
||
var key = (parentKey !== "" ? parentKey + "_" : "") + index;
|
||
var newItem = {
|
||
item: item3,
|
||
index,
|
||
level,
|
||
key,
|
||
parent,
|
||
parentKey
|
||
};
|
||
newItem["items"] = _this11.createProcessedItems(item3.items, level + 1, newItem, key);
|
||
processedItems3.push(newItem);
|
||
});
|
||
return processedItems3;
|
||
}, "createProcessedItems"),
|
||
containerRef: /* @__PURE__ */ __name(function containerRef3(el) {
|
||
this.container = el;
|
||
}, "containerRef"),
|
||
menubarRef: /* @__PURE__ */ __name(function menubarRef2(el) {
|
||
this.menubar = el ? el.$el : void 0;
|
||
}, "menubarRef")
|
||
},
|
||
computed: {
|
||
processedItems: /* @__PURE__ */ __name(function processedItems2() {
|
||
return this.createProcessedItems(this.model || []);
|
||
}, "processedItems"),
|
||
visibleItems: /* @__PURE__ */ __name(function visibleItems2() {
|
||
var _this12 = this;
|
||
var processedItem = this.activeItemPath.find(function(p) {
|
||
return p.key === _this12.focusedItemInfo.parentKey;
|
||
});
|
||
return processedItem ? processedItem.items : this.processedItems;
|
||
}, "visibleItems"),
|
||
focusedItemId: /* @__PURE__ */ __name(function focusedItemId2() {
|
||
return this.focusedItemInfo.index !== -1 ? "".concat(this.id).concat(isNotEmpty(this.focusedItemInfo.parentKey) ? "_" + this.focusedItemInfo.parentKey : "", "_").concat(this.focusedItemInfo.index) : null;
|
||
}, "focusedItemId")
|
||
},
|
||
components: {
|
||
TieredMenuSub: script$1$1,
|
||
Portal: script$m
|
||
}
|
||
};
|
||
var _hoisted_1$5 = ["id"];
|
||
function render$3(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _component_TieredMenuSub = resolveComponent("TieredMenuSub");
|
||
var _component_Portal = resolveComponent("Portal");
|
||
return openBlock(), createBlock(_component_Portal, {
|
||
appendTo: _ctx.appendTo,
|
||
disabled: !_ctx.popup
|
||
}, {
|
||
"default": withCtx(function() {
|
||
return [createVNode(Transition, mergeProps({
|
||
name: "p-connected-overlay",
|
||
onEnter: $options.onEnter,
|
||
onAfterEnter: $options.onAfterEnter,
|
||
onLeave: $options.onLeave,
|
||
onAfterLeave: $options.onAfterLeave
|
||
}, _ctx.ptm("transition")), {
|
||
"default": withCtx(function() {
|
||
return [$data.visible ? (openBlock(), createElementBlock("div", mergeProps({
|
||
key: 0,
|
||
ref: $options.containerRef,
|
||
id: $data.id,
|
||
"class": _ctx.cx("root"),
|
||
onClick: _cache[0] || (_cache[0] = function() {
|
||
return $options.onOverlayClick && $options.onOverlayClick.apply($options, arguments);
|
||
})
|
||
}, _ctx.ptmi("root")), [_ctx.$slots.start ? (openBlock(), createElementBlock("div", mergeProps({
|
||
key: 0,
|
||
"class": _ctx.cx("start")
|
||
}, _ctx.ptm("start")), [renderSlot(_ctx.$slots, "start")], 16)) : createCommentVNode("", true), createVNode(_component_TieredMenuSub, {
|
||
ref: $options.menubarRef,
|
||
id: $data.id + "_list",
|
||
tabindex: !_ctx.disabled ? _ctx.tabindex : -1,
|
||
role: "menubar",
|
||
"aria-label": _ctx.ariaLabel,
|
||
"aria-labelledby": _ctx.ariaLabelledby,
|
||
"aria-disabled": _ctx.disabled || void 0,
|
||
"aria-orientation": "vertical",
|
||
"aria-activedescendant": $data.focused ? $options.focusedItemId : void 0,
|
||
menuId: $data.id,
|
||
focusedItemId: $data.focused ? $options.focusedItemId : void 0,
|
||
items: $options.processedItems,
|
||
templates: _ctx.$slots,
|
||
activeItemPath: $data.activeItemPath,
|
||
level: 0,
|
||
visible: $data.submenuVisible,
|
||
pt: _ctx.pt,
|
||
unstyled: _ctx.unstyled,
|
||
onFocus: $options.onFocus,
|
||
onBlur: $options.onBlur,
|
||
onKeydown: $options.onKeyDown,
|
||
onItemClick: $options.onItemClick,
|
||
onItemMouseenter: $options.onItemMouseEnter,
|
||
onItemMousemove: $options.onItemMouseMove
|
||
}, null, 8, ["id", "tabindex", "aria-label", "aria-labelledby", "aria-disabled", "aria-activedescendant", "menuId", "focusedItemId", "items", "templates", "activeItemPath", "visible", "pt", "unstyled", "onFocus", "onBlur", "onKeydown", "onItemClick", "onItemMouseenter", "onItemMousemove"]), _ctx.$slots.end ? (openBlock(), createElementBlock("div", mergeProps({
|
||
key: 1,
|
||
"class": _ctx.cx("end")
|
||
}, _ctx.ptm("end")), [renderSlot(_ctx.$slots, "end")], 16)) : createCommentVNode("", true)], 16, _hoisted_1$5)) : createCommentVNode("", true)];
|
||
}),
|
||
_: 3
|
||
}, 16, ["onEnter", "onAfterEnter", "onLeave", "onAfterLeave"])];
|
||
}),
|
||
_: 3
|
||
}, 8, ["appendTo", "disabled"]);
|
||
}
|
||
__name(render$3, "render$3");
|
||
script$3.render = render$3;
|
||
var theme9 = /* @__PURE__ */ __name(function theme10(_ref) {
|
||
var dt = _ref.dt;
|
||
return "\n.p-splitbutton {\n display: inline-flex;\n position: relative;\n border-radius: ".concat(dt("splitbutton.border.radius"), ";\n}\n\n.p-splitbutton-button {\n border-top-right-radius: 0;\n border-bottom-right-radius: 0;\n border-right: 0 none;\n}\n\n.p-splitbutton-button:focus-visible,\n.p-splitbutton-dropdown:focus-visible {\n z-index: 1;\n}\n\n.p-splitbutton-button:not(:disabled):hover,\n.p-splitbutton-button:not(:disabled):active {\n border-right: 0 none;\n}\n\n.p-splitbutton-dropdown {\n border-top-left-radius: 0;\n border-bottom-left-radius: 0;\n}\n\n.p-splitbutton .p-menu {\n min-width: 100%;\n}\n\n.p-splitbutton-fluid {\n display: flex;\n}\n\n.p-splitbutton-rounded .p-splitbutton-dropdown {\n border-top-right-radius: ").concat(dt("splitbutton.rounded.border.radius"), ";\n border-bottom-right-radius: ").concat(dt("splitbutton.rounded.border.radius"), ";\n}\n\n.p-splitbutton-rounded .p-splitbutton-button {\n border-top-left-radius: ").concat(dt("splitbutton.rounded.border.radius"), ";\n border-bottom-left-radius: ").concat(dt("splitbutton.rounded.border.radius"), ";\n}\n\n.p-splitbutton-raised {\n box-shadow: ").concat(dt("splitbutton.raised.shadow"), ";\n}\n");
|
||
}, "theme");
|
||
var classes = {
|
||
root: /* @__PURE__ */ __name(function root11(_ref2) {
|
||
var instance = _ref2.instance, props = _ref2.props;
|
||
return ["p-splitbutton p-component", {
|
||
"p-splitbutton-raised": props.raised,
|
||
"p-splitbutton-rounded": props.rounded,
|
||
"p-splitbutton-fluid": instance.hasFluid
|
||
}];
|
||
}, "root"),
|
||
pcButton: "p-splitbutton-button",
|
||
pcDropdown: "p-splitbutton-dropdown"
|
||
};
|
||
var SplitButtonStyle = BaseStyle.extend({
|
||
name: "splitbutton",
|
||
theme: theme9,
|
||
classes
|
||
});
|
||
var script$1 = {
|
||
name: "BaseSplitButton",
|
||
"extends": script$g,
|
||
props: {
|
||
label: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
icon: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
model: {
|
||
type: Array,
|
||
"default": null
|
||
},
|
||
autoZIndex: {
|
||
type: Boolean,
|
||
"default": true
|
||
},
|
||
baseZIndex: {
|
||
type: Number,
|
||
"default": 0
|
||
},
|
||
appendTo: {
|
||
type: [String, Object],
|
||
"default": "body"
|
||
},
|
||
disabled: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
fluid: {
|
||
type: Boolean,
|
||
"default": null
|
||
},
|
||
"class": {
|
||
type: null,
|
||
"default": null
|
||
},
|
||
style: {
|
||
type: null,
|
||
"default": null
|
||
},
|
||
buttonProps: {
|
||
type: null,
|
||
"default": null
|
||
},
|
||
menuButtonProps: {
|
||
type: null,
|
||
"default": null
|
||
},
|
||
menuButtonIcon: {
|
||
type: String,
|
||
"default": void 0
|
||
},
|
||
dropdownIcon: {
|
||
type: String,
|
||
"default": void 0
|
||
},
|
||
severity: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
raised: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
rounded: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
text: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
outlined: {
|
||
type: Boolean,
|
||
"default": false
|
||
},
|
||
size: {
|
||
type: String,
|
||
"default": null
|
||
},
|
||
plain: {
|
||
type: Boolean,
|
||
"default": false
|
||
}
|
||
},
|
||
style: SplitButtonStyle,
|
||
provide: /* @__PURE__ */ __name(function provide13() {
|
||
return {
|
||
$pcSplitButton: this,
|
||
$parentInstance: this
|
||
};
|
||
}, "provide")
|
||
};
|
||
var script = {
|
||
name: "SplitButton",
|
||
"extends": script$1,
|
||
inheritAttrs: false,
|
||
emits: ["click"],
|
||
inject: {
|
||
$pcFluid: {
|
||
"default": null
|
||
}
|
||
},
|
||
data: /* @__PURE__ */ __name(function data9() {
|
||
return {
|
||
id: this.$attrs.id,
|
||
isExpanded: false
|
||
};
|
||
}, "data"),
|
||
watch: {
|
||
"$attrs.id": /* @__PURE__ */ __name(function $attrsId5(newValue) {
|
||
this.id = newValue || UniqueComponentId();
|
||
}, "$attrsId")
|
||
},
|
||
mounted: /* @__PURE__ */ __name(function mounted9() {
|
||
var _this = this;
|
||
this.id = this.id || UniqueComponentId();
|
||
this.$watch("$refs.menu.visible", function(newValue) {
|
||
_this.isExpanded = newValue;
|
||
});
|
||
}, "mounted"),
|
||
methods: {
|
||
onDropdownButtonClick: /* @__PURE__ */ __name(function onDropdownButtonClick(event) {
|
||
if (event) {
|
||
event.preventDefault();
|
||
}
|
||
this.$refs.menu.toggle({
|
||
currentTarget: this.$el,
|
||
relatedTarget: this.$refs.button.$el
|
||
});
|
||
this.isExpanded = this.$refs.menu.visible;
|
||
}, "onDropdownButtonClick"),
|
||
onDropdownKeydown: /* @__PURE__ */ __name(function onDropdownKeydown(event) {
|
||
if (event.code === "ArrowDown" || event.code === "ArrowUp") {
|
||
this.onDropdownButtonClick();
|
||
event.preventDefault();
|
||
}
|
||
}, "onDropdownKeydown"),
|
||
onDefaultButtonClick: /* @__PURE__ */ __name(function onDefaultButtonClick(event) {
|
||
if (this.isExpanded) {
|
||
this.$refs.menu.hide(event);
|
||
}
|
||
this.$emit("click", event);
|
||
}, "onDefaultButtonClick")
|
||
},
|
||
computed: {
|
||
containerClass: /* @__PURE__ */ __name(function containerClass() {
|
||
return [this.cx("root"), this["class"]];
|
||
}, "containerClass"),
|
||
hasFluid: /* @__PURE__ */ __name(function hasFluid2() {
|
||
return isEmpty(this.fluid) ? !!this.$pcFluid : this.fluid;
|
||
}, "hasFluid")
|
||
},
|
||
components: {
|
||
PVSButton: script$f,
|
||
PVSMenu: script$3,
|
||
ChevronDownIcon: script$n
|
||
}
|
||
};
|
||
var _hoisted_1$4 = ["data-p-severity"];
|
||
function render$2(_ctx, _cache, $props, $setup, $data, $options) {
|
||
var _component_PVSButton = resolveComponent("PVSButton");
|
||
var _component_PVSMenu = resolveComponent("PVSMenu");
|
||
return openBlock(), createElementBlock("div", mergeProps({
|
||
"class": $options.containerClass,
|
||
style: _ctx.style
|
||
}, _ctx.ptmi("root"), {
|
||
"data-p-severity": _ctx.severity
|
||
}), [createVNode(_component_PVSButton, mergeProps({
|
||
type: "button",
|
||
"class": _ctx.cx("pcButton"),
|
||
label: _ctx.label,
|
||
disabled: _ctx.disabled,
|
||
severity: _ctx.severity,
|
||
text: _ctx.text,
|
||
icon: _ctx.icon,
|
||
outlined: _ctx.outlined,
|
||
size: _ctx.size,
|
||
fluid: _ctx.fluid,
|
||
"aria-label": _ctx.label,
|
||
onClick: $options.onDefaultButtonClick
|
||
}, _ctx.buttonProps, {
|
||
pt: _ctx.ptm("pcButton"),
|
||
unstyled: _ctx.unstyled
|
||
}), createSlots({
|
||
"default": withCtx(function() {
|
||
return [renderSlot(_ctx.$slots, "default")];
|
||
}),
|
||
_: 2
|
||
}, [_ctx.$slots.icon ? {
|
||
name: "icon",
|
||
fn: withCtx(function(slotProps) {
|
||
return [renderSlot(_ctx.$slots, "icon", {
|
||
"class": normalizeClass(slotProps["class"])
|
||
}, function() {
|
||
return [createBaseVNode("span", mergeProps({
|
||
"class": [_ctx.icon, slotProps["class"]]
|
||
}, _ctx.ptm("pcButton")["icon"], {
|
||
"data-pc-section": "buttonicon"
|
||
}), null, 16)];
|
||
})];
|
||
}),
|
||
key: "0"
|
||
} : void 0]), 1040, ["class", "label", "disabled", "severity", "text", "icon", "outlined", "size", "fluid", "aria-label", "onClick", "pt", "unstyled"]), createVNode(_component_PVSButton, mergeProps({
|
||
ref: "button",
|
||
type: "button",
|
||
"class": _ctx.cx("pcDropdown"),
|
||
disabled: _ctx.disabled,
|
||
"aria-haspopup": "true",
|
||
"aria-expanded": $data.isExpanded,
|
||
"aria-controls": $data.id + "_overlay",
|
||
onClick: $options.onDropdownButtonClick,
|
||
onKeydown: $options.onDropdownKeydown,
|
||
severity: _ctx.severity,
|
||
text: _ctx.text,
|
||
outlined: _ctx.outlined,
|
||
size: _ctx.size,
|
||
unstyled: _ctx.unstyled
|
||
}, _ctx.menuButtonProps, {
|
||
pt: _ctx.ptm("pcDropdown")
|
||
}), {
|
||
icon: withCtx(function(slotProps) {
|
||
return [renderSlot(_ctx.$slots, _ctx.$slots.dropdownicon ? "dropdownicon" : "menubuttonicon", {
|
||
"class": normalizeClass(slotProps["class"])
|
||
}, function() {
|
||
return [(openBlock(), createBlock(resolveDynamicComponent(_ctx.menuButtonIcon || _ctx.dropdownIcon ? "span" : "ChevronDownIcon"), mergeProps({
|
||
"class": [_ctx.dropdownIcon || _ctx.menuButtonIcon, slotProps["class"]]
|
||
}, _ctx.ptm("pcDropdown")["icon"], {
|
||
"data-pc-section": "menubuttonicon"
|
||
}), null, 16, ["class"]))];
|
||
})];
|
||
}),
|
||
_: 3
|
||
}, 16, ["class", "disabled", "aria-expanded", "aria-controls", "onClick", "onKeydown", "severity", "text", "outlined", "size", "unstyled", "pt"]), createVNode(_component_PVSMenu, {
|
||
ref: "menu",
|
||
id: $data.id + "_overlay",
|
||
model: _ctx.model,
|
||
popup: true,
|
||
autoZIndex: _ctx.autoZIndex,
|
||
baseZIndex: _ctx.baseZIndex,
|
||
appendTo: _ctx.appendTo,
|
||
unstyled: _ctx.unstyled,
|
||
pt: _ctx.ptm("pcMenu")
|
||
}, createSlots({
|
||
_: 2
|
||
}, [_ctx.$slots.menuitemicon ? {
|
||
name: "itemicon",
|
||
fn: withCtx(function(slotProps) {
|
||
return [renderSlot(_ctx.$slots, "menuitemicon", {
|
||
item: slotProps.item,
|
||
"class": normalizeClass(slotProps["class"])
|
||
})];
|
||
}),
|
||
key: "0"
|
||
} : void 0, _ctx.$slots.item ? {
|
||
name: "item",
|
||
fn: withCtx(function(slotProps) {
|
||
return [renderSlot(_ctx.$slots, "item", {
|
||
item: slotProps.item,
|
||
hasSubmenu: slotProps.hasSubmenu,
|
||
label: slotProps.label,
|
||
props: slotProps.props
|
||
})];
|
||
}),
|
||
key: "1"
|
||
} : void 0]), 1032, ["id", "model", "autoZIndex", "baseZIndex", "appendTo", "unstyled", "pt"])], 16, _hoisted_1$4);
|
||
}
|
||
__name(render$2, "render$2");
|
||
script.render = render$2;
|
||
const minQueueCount = 1;
|
||
const _sfc_main$5 = /* @__PURE__ */ defineComponent({
|
||
__name: "BatchCountEdit",
|
||
props: {
|
||
class: { default: "" }
|
||
},
|
||
setup(__props) {
|
||
const props = __props;
|
||
const queueSettingsStore = useQueueSettingsStore();
|
||
const { batchCount } = storeToRefs(queueSettingsStore);
|
||
const settingStore = useSettingStore();
|
||
const maxQueueCount = computed(
|
||
() => settingStore.get("Comfy.QueueButton.BatchCountLimit")
|
||
);
|
||
const handleClick = /* @__PURE__ */ __name((increment) => {
|
||
let newCount;
|
||
if (increment) {
|
||
const originalCount = batchCount.value - 1;
|
||
newCount = originalCount * 2;
|
||
} else {
|
||
const originalCount = batchCount.value + 1;
|
||
newCount = Math.floor(originalCount / 2);
|
||
}
|
||
batchCount.value = newCount;
|
||
}, "handleClick");
|
||
return (_ctx, _cache) => {
|
||
const _directive_tooltip = resolveDirective("tooltip");
|
||
return withDirectives((openBlock(), createElementBlock("div", {
|
||
class: normalizeClass(["batch-count", props.class])
|
||
}, [
|
||
createVNode(unref(script$E), {
|
||
class: "w-14",
|
||
modelValue: unref(batchCount),
|
||
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(batchCount) ? batchCount.value = $event : null),
|
||
min: minQueueCount,
|
||
max: maxQueueCount.value,
|
||
fluid: "",
|
||
showButtons: "",
|
||
pt: {
|
||
incrementButton: {
|
||
class: "w-6",
|
||
onmousedown: /* @__PURE__ */ __name(() => {
|
||
handleClick(true);
|
||
}, "onmousedown")
|
||
},
|
||
decrementButton: {
|
||
class: "w-6",
|
||
onmousedown: /* @__PURE__ */ __name(() => {
|
||
handleClick(false);
|
||
}, "onmousedown")
|
||
}
|
||
}
|
||
}, null, 8, ["modelValue", "max", "pt"])
|
||
], 2)), [
|
||
[
|
||
_directive_tooltip,
|
||
_ctx.$t("menu.batchCount"),
|
||
void 0,
|
||
{ bottom: true }
|
||
]
|
||
]);
|
||
};
|
||
}
|
||
});
|
||
const BatchCountEdit = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["__scopeId", "data-v-713442be"]]);
|
||
const _withScopeId$1 = /* @__PURE__ */ __name((n) => (pushScopeId("data-v-d3897845"), n = n(), popScopeId(), n), "_withScopeId$1");
|
||
const _hoisted_1$3 = { class: "queue-button-group flex" };
|
||
const _sfc_main$4 = /* @__PURE__ */ defineComponent({
|
||
__name: "ComfyQueueButton",
|
||
setup(__props) {
|
||
const workspaceStore = useWorkspaceStore();
|
||
const queueCountStore = storeToRefs(useQueuePendingTaskCountStore());
|
||
const { mode: queueMode } = storeToRefs(useQueueSettingsStore());
|
||
const { t } = useI18n();
|
||
const queueModeMenuItemLookup = computed(() => ({
|
||
disabled: {
|
||
key: "disabled",
|
||
label: t("menu.queue"),
|
||
tooltip: t("menu.disabledTooltip"),
|
||
command: /* @__PURE__ */ __name(() => {
|
||
queueMode.value = "disabled";
|
||
}, "command")
|
||
},
|
||
instant: {
|
||
key: "instant",
|
||
label: `${t("menu.queue")} (${t("menu.instant")})`,
|
||
tooltip: t("menu.instantTooltip"),
|
||
command: /* @__PURE__ */ __name(() => {
|
||
queueMode.value = "instant";
|
||
}, "command")
|
||
},
|
||
change: {
|
||
key: "change",
|
||
label: `${t("menu.queue")} (${t("menu.onChange")})`,
|
||
tooltip: t("menu.onChangeTooltip"),
|
||
command: /* @__PURE__ */ __name(() => {
|
||
queueMode.value = "change";
|
||
}, "command")
|
||
}
|
||
}));
|
||
const activeQueueModeMenuItem = computed(
|
||
() => queueModeMenuItemLookup.value[queueMode.value]
|
||
);
|
||
const queueModeMenuItems = computed(
|
||
() => Object.values(queueModeMenuItemLookup.value)
|
||
);
|
||
const executingPrompt = computed(() => !!queueCountStore.count.value);
|
||
const hasPendingTasks = computed(() => queueCountStore.count.value > 1);
|
||
const commandStore = useCommandStore();
|
||
const queuePrompt = /* @__PURE__ */ __name((e) => {
|
||
const commandId = e.shiftKey ? "Comfy.QueuePromptFront" : "Comfy.QueuePrompt";
|
||
commandStore.execute(commandId);
|
||
}, "queuePrompt");
|
||
return (_ctx, _cache) => {
|
||
const _component_i_lucide58list_start = __unplugin_components_0$1;
|
||
const _component_i_lucide58play = __unplugin_components_1$1;
|
||
const _component_i_lucide58fast_forward = __unplugin_components_2;
|
||
const _component_i_lucide58step_forward = __unplugin_components_3;
|
||
const _directive_tooltip = resolveDirective("tooltip");
|
||
return openBlock(), createElementBlock("div", _hoisted_1$3, [
|
||
withDirectives((openBlock(), createBlock(unref(script), {
|
||
class: "comfyui-queue-button",
|
||
label: activeQueueModeMenuItem.value.label,
|
||
severity: "primary",
|
||
size: "small",
|
||
onClick: queuePrompt,
|
||
model: queueModeMenuItems.value,
|
||
"data-testid": "queue-button"
|
||
}, {
|
||
icon: withCtx(() => [
|
||
unref(workspaceStore).shiftDown ? (openBlock(), createBlock(_component_i_lucide58list_start, { key: 0 })) : unref(queueMode) === "disabled" ? (openBlock(), createBlock(_component_i_lucide58play, { key: 1 })) : unref(queueMode) === "instant" ? (openBlock(), createBlock(_component_i_lucide58fast_forward, { key: 2 })) : unref(queueMode) === "change" ? (openBlock(), createBlock(_component_i_lucide58step_forward, { key: 3 })) : createCommentVNode("", true)
|
||
]),
|
||
item: withCtx(({ item: item3 }) => [
|
||
withDirectives(createVNode(unref(script$f), {
|
||
label: item3.label,
|
||
icon: item3.icon,
|
||
severity: item3.key === unref(queueMode) ? "primary" : "secondary",
|
||
size: "small",
|
||
text: ""
|
||
}, null, 8, ["label", "icon", "severity"]), [
|
||
[_directive_tooltip, item3.tooltip]
|
||
])
|
||
]),
|
||
_: 1
|
||
}, 8, ["label", "model"])), [
|
||
[
|
||
_directive_tooltip,
|
||
unref(workspaceStore).shiftDown ? _ctx.$t("menu.queueWorkflowFront") : _ctx.$t("menu.queueWorkflow"),
|
||
void 0,
|
||
{ bottom: true }
|
||
]
|
||
]),
|
||
createVNode(BatchCountEdit),
|
||
createVNode(unref(script$7), { class: "execution-actions flex flex-nowrap" }, {
|
||
default: withCtx(() => [
|
||
withDirectives(createVNode(unref(script$f), {
|
||
icon: "pi pi-times",
|
||
severity: executingPrompt.value ? "danger" : "secondary",
|
||
disabled: !executingPrompt.value,
|
||
text: "",
|
||
onClick: _cache[0] || (_cache[0] = () => unref(commandStore).execute("Comfy.Interrupt"))
|
||
}, null, 8, ["severity", "disabled"]), [
|
||
[
|
||
_directive_tooltip,
|
||
_ctx.$t("menu.interrupt"),
|
||
void 0,
|
||
{ bottom: true }
|
||
]
|
||
]),
|
||
withDirectives(createVNode(unref(script$f), {
|
||
icon: "pi pi-stop",
|
||
severity: hasPendingTasks.value ? "danger" : "secondary",
|
||
disabled: !hasPendingTasks.value,
|
||
text: "",
|
||
onClick: _cache[1] || (_cache[1] = () => unref(commandStore).execute("Comfy.ClearPendingTasks"))
|
||
}, null, 8, ["severity", "disabled"]), [
|
||
[
|
||
_directive_tooltip,
|
||
_ctx.$t("sideToolbar.queueTab.clearPendingTasks"),
|
||
void 0,
|
||
{ bottom: true }
|
||
]
|
||
])
|
||
]),
|
||
_: 1
|
||
})
|
||
]);
|
||
};
|
||
}
|
||
});
|
||
const ComfyQueueButton = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["__scopeId", "data-v-d3897845"]]);
|
||
const overlapThreshold = 20;
|
||
const _sfc_main$3 = /* @__PURE__ */ defineComponent({
|
||
__name: "ComfyActionbar",
|
||
setup(__props) {
|
||
const settingsStore = useSettingStore();
|
||
const visible = computed(
|
||
() => settingsStore.get("Comfy.UseNewMenu") !== "Disabled"
|
||
);
|
||
const panelRef = ref(null);
|
||
const dragHandleRef = ref(null);
|
||
const isDocked = useLocalStorage("Comfy.MenuPosition.Docked", false);
|
||
const storedPosition = useLocalStorage("Comfy.MenuPosition.Floating", {
|
||
x: 0,
|
||
y: 0
|
||
});
|
||
const {
|
||
x,
|
||
y,
|
||
style,
|
||
isDragging
|
||
} = useDraggable(panelRef, {
|
||
initialValue: { x: 0, y: 0 },
|
||
handle: dragHandleRef,
|
||
containerElement: document.body
|
||
});
|
||
watchDebounced(
|
||
[x, y],
|
||
([newX, newY]) => {
|
||
storedPosition.value = { x: newX, y: newY };
|
||
},
|
||
{ debounce: 300 }
|
||
);
|
||
const setInitialPosition = /* @__PURE__ */ __name(() => {
|
||
if (x.value !== 0 || y.value !== 0) {
|
||
return;
|
||
}
|
||
if (storedPosition.value.x !== 0 || storedPosition.value.y !== 0) {
|
||
x.value = storedPosition.value.x;
|
||
y.value = storedPosition.value.y;
|
||
captureLastDragState();
|
||
return;
|
||
}
|
||
if (panelRef.value) {
|
||
const screenWidth = window.innerWidth;
|
||
const screenHeight = window.innerHeight;
|
||
const menuWidth = panelRef.value.offsetWidth;
|
||
const menuHeight = panelRef.value.offsetHeight;
|
||
if (menuWidth === 0 || menuHeight === 0) {
|
||
return;
|
||
}
|
||
x.value = (screenWidth - menuWidth) / 2;
|
||
y.value = screenHeight - menuHeight - 10;
|
||
captureLastDragState();
|
||
}
|
||
}, "setInitialPosition");
|
||
onMounted(setInitialPosition);
|
||
watch(visible, (newVisible) => {
|
||
if (newVisible) {
|
||
nextTick(setInitialPosition);
|
||
}
|
||
});
|
||
const lastDragState = ref({
|
||
x: x.value,
|
||
y: y.value,
|
||
windowWidth: window.innerWidth,
|
||
windowHeight: window.innerHeight
|
||
});
|
||
const captureLastDragState = /* @__PURE__ */ __name(() => {
|
||
lastDragState.value = {
|
||
x: x.value,
|
||
y: y.value,
|
||
windowWidth: window.innerWidth,
|
||
windowHeight: window.innerHeight
|
||
};
|
||
}, "captureLastDragState");
|
||
watch(
|
||
isDragging,
|
||
(newIsDragging) => {
|
||
if (!newIsDragging) {
|
||
captureLastDragState();
|
||
}
|
||
},
|
||
{ immediate: true }
|
||
);
|
||
const adjustMenuPosition = /* @__PURE__ */ __name(() => {
|
||
if (panelRef.value) {
|
||
const screenWidth = window.innerWidth;
|
||
const screenHeight = window.innerHeight;
|
||
const menuWidth = panelRef.value.offsetWidth;
|
||
const menuHeight = panelRef.value.offsetHeight;
|
||
const distanceLeft = lastDragState.value.x;
|
||
const distanceRight = lastDragState.value.windowWidth - (lastDragState.value.x + menuWidth);
|
||
const distanceTop = lastDragState.value.y;
|
||
const distanceBottom = lastDragState.value.windowHeight - (lastDragState.value.y + menuHeight);
|
||
const distances = [
|
||
{ edge: "left", distance: distanceLeft },
|
||
{ edge: "right", distance: distanceRight },
|
||
{ edge: "top", distance: distanceTop },
|
||
{ edge: "bottom", distance: distanceBottom }
|
||
];
|
||
const closestEdge = distances.reduce(
|
||
(min, curr) => curr.distance < min.distance ? curr : min
|
||
);
|
||
const verticalRatio = lastDragState.value.y / lastDragState.value.windowHeight;
|
||
const horizontalRatio = lastDragState.value.x / lastDragState.value.windowWidth;
|
||
if (closestEdge.edge === "left") {
|
||
x.value = closestEdge.distance;
|
||
y.value = verticalRatio * screenHeight;
|
||
} else if (closestEdge.edge === "right") {
|
||
x.value = screenWidth - menuWidth - closestEdge.distance;
|
||
y.value = verticalRatio * screenHeight;
|
||
} else if (closestEdge.edge === "top") {
|
||
x.value = horizontalRatio * screenWidth;
|
||
y.value = closestEdge.distance;
|
||
} else {
|
||
x.value = horizontalRatio * screenWidth;
|
||
y.value = screenHeight - menuHeight - closestEdge.distance;
|
||
}
|
||
x.value = lodashExports.clamp(x.value, 0, screenWidth - menuWidth);
|
||
y.value = lodashExports.clamp(y.value, 0, screenHeight - menuHeight);
|
||
}
|
||
}, "adjustMenuPosition");
|
||
useEventListener(window, "resize", adjustMenuPosition);
|
||
const topMenuRef = inject("topMenuRef");
|
||
const topMenuBounds = useElementBounding(topMenuRef);
|
||
const isOverlappingWithTopMenu = computed(() => {
|
||
if (!panelRef.value) {
|
||
return false;
|
||
}
|
||
const { height } = panelRef.value.getBoundingClientRect();
|
||
const actionbarBottom = y.value + height;
|
||
const topMenuBottom = topMenuBounds.bottom.value;
|
||
const overlapPixels = Math.min(actionbarBottom, topMenuBottom) - Math.max(y.value, topMenuBounds.top.value);
|
||
return overlapPixels > overlapThreshold;
|
||
});
|
||
watch(isDragging, (newIsDragging) => {
|
||
if (!newIsDragging) {
|
||
isDocked.value = isOverlappingWithTopMenu.value;
|
||
} else {
|
||
isDocked.value = false;
|
||
}
|
||
});
|
||
const eventBus = useEventBus("topMenu");
|
||
watch([isDragging, isOverlappingWithTopMenu], ([dragging, overlapping]) => {
|
||
eventBus.emit("updateHighlight", {
|
||
isDragging: dragging,
|
||
isOverlapping: overlapping
|
||
});
|
||
});
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createBlock(unref(script$4), {
|
||
class: normalizeClass(["actionbar w-fit", { "is-dragging": unref(isDragging), "is-docked": unref(isDocked) }]),
|
||
style: normalizeStyle(unref(style))
|
||
}, {
|
||
default: withCtx(() => [
|
||
createBaseVNode("div", {
|
||
class: "actionbar-content flex items-center",
|
||
ref_key: "panelRef",
|
||
ref: panelRef
|
||
}, [
|
||
createBaseVNode("span", {
|
||
class: "drag-handle cursor-move mr-2 p-0!",
|
||
ref_key: "dragHandleRef",
|
||
ref: dragHandleRef
|
||
}, null, 512),
|
||
createVNode(ComfyQueueButton)
|
||
], 512)
|
||
]),
|
||
_: 1
|
||
}, 8, ["style", "class"]);
|
||
};
|
||
}
|
||
});
|
||
const Actionbar = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-542a7001"]]);
|
||
const _hoisted_1$2 = {
|
||
viewBox: "0 0 24 24",
|
||
width: "1.2em",
|
||
height: "1.2em"
|
||
};
|
||
const _hoisted_2$2 = /* @__PURE__ */ createBaseVNode("path", {
|
||
fill: "currentColor",
|
||
d: "M5 21q-.825 0-1.412-.587T3 19V5q0-.825.588-1.412T5 3h14q.825 0 1.413.588T21 5v14q0 .825-.587 1.413T19 21zm0-5v3h14v-3zm0-2h14V5H5zm0 2v3z"
|
||
}, null, -1);
|
||
const _hoisted_3$1 = [
|
||
_hoisted_2$2
|
||
];
|
||
function render$1(_ctx, _cache) {
|
||
return openBlock(), createElementBlock("svg", _hoisted_1$2, [..._hoisted_3$1]);
|
||
}
|
||
__name(render$1, "render$1");
|
||
const __unplugin_components_1 = markRaw({ name: "material-symbols-dock-to-bottom-outline", render: render$1 });
|
||
const _hoisted_1$1 = {
|
||
viewBox: "0 0 24 24",
|
||
width: "1.2em",
|
||
height: "1.2em"
|
||
};
|
||
const _hoisted_2$1 = /* @__PURE__ */ createBaseVNode("path", {
|
||
fill: "currentColor",
|
||
d: "M5 21q-.825 0-1.412-.587T3 19V5q0-.825.588-1.412T5 3h14q.825 0 1.413.588T21 5v14q0 .825-.587 1.413T19 21zm0-7h14V5H5z"
|
||
}, null, -1);
|
||
const _hoisted_3 = [
|
||
_hoisted_2$1
|
||
];
|
||
function render(_ctx, _cache) {
|
||
return openBlock(), createElementBlock("svg", _hoisted_1$1, [..._hoisted_3]);
|
||
}
|
||
__name(render, "render");
|
||
const __unplugin_components_0 = markRaw({ name: "material-symbols-dock-to-bottom", render });
|
||
const _sfc_main$2 = /* @__PURE__ */ defineComponent({
|
||
__name: "BottomPanelToggleButton",
|
||
setup(__props) {
|
||
const bottomPanelStore = useBottomPanelStore();
|
||
return (_ctx, _cache) => {
|
||
const _component_i_material_symbols58dock_to_bottom = __unplugin_components_0;
|
||
const _component_i_material_symbols58dock_to_bottom_outline = __unplugin_components_1;
|
||
const _directive_tooltip = resolveDirective("tooltip");
|
||
return withDirectives((openBlock(), createBlock(unref(script$f), {
|
||
severity: "secondary",
|
||
text: "",
|
||
onClick: unref(bottomPanelStore).toggleBottomPanel
|
||
}, {
|
||
icon: withCtx(() => [
|
||
unref(bottomPanelStore).bottomPanelVisible ? (openBlock(), createBlock(_component_i_material_symbols58dock_to_bottom, { key: 0 })) : (openBlock(), createBlock(_component_i_material_symbols58dock_to_bottom_outline, { key: 1 }))
|
||
]),
|
||
_: 1
|
||
}, 8, ["onClick"])), [
|
||
[vShow, unref(bottomPanelStore).bottomPanelTabs.length > 0],
|
||
[_directive_tooltip, { value: _ctx.$t("menu.toggleBottomPanel"), showDelay: 300 }]
|
||
]);
|
||
};
|
||
}
|
||
});
|
||
const _withScopeId = /* @__PURE__ */ __name((n) => (pushScopeId("data-v-d792da31"), n = n(), popScopeId(), n), "_withScopeId");
|
||
const _hoisted_1 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createBaseVNode("h1", { class: "comfyui-logo mx-2" }, "ComfyUI", -1));
|
||
const _hoisted_2 = { class: "flex-grow" };
|
||
const _sfc_main$1 = /* @__PURE__ */ defineComponent({
|
||
__name: "TopMenubar",
|
||
setup(__props) {
|
||
const workspaceState = useWorkspaceStore();
|
||
const settingStore = useSettingStore();
|
||
const workflowTabsPosition = computed(
|
||
() => settingStore.get("Comfy.Workflow.WorkflowTabsPosition")
|
||
);
|
||
const betaMenuEnabled = computed(
|
||
() => settingStore.get("Comfy.UseNewMenu") !== "Disabled"
|
||
);
|
||
const teleportTarget = computed(
|
||
() => settingStore.get("Comfy.UseNewMenu") === "Top" ? ".comfyui-body-top" : ".comfyui-body-bottom"
|
||
);
|
||
const menuRight = ref(null);
|
||
onMounted(() => {
|
||
if (menuRight.value) {
|
||
menuRight.value.appendChild(app.menu.element);
|
||
}
|
||
});
|
||
const topMenuRef = ref(null);
|
||
provide("topMenuRef", topMenuRef);
|
||
const eventBus = useEventBus("topMenu");
|
||
const isDropZone = ref(false);
|
||
const isDroppable = ref(false);
|
||
eventBus.on((event, payload) => {
|
||
if (event === "updateHighlight") {
|
||
isDropZone.value = payload.isDragging;
|
||
isDroppable.value = payload.isOverlapping && payload.isDragging;
|
||
}
|
||
});
|
||
return (_ctx, _cache) => {
|
||
const _directive_tooltip = resolveDirective("tooltip");
|
||
return openBlock(), createBlock(Teleport, { to: teleportTarget.value }, [
|
||
withDirectives(createBaseVNode("div", {
|
||
ref_key: "topMenuRef",
|
||
ref: topMenuRef,
|
||
class: normalizeClass(["comfyui-menu flex items-center", { dropzone: isDropZone.value, "dropzone-active": isDroppable.value }])
|
||
}, [
|
||
_hoisted_1,
|
||
createVNode(CommandMenubar),
|
||
createVNode(unref(script$F), {
|
||
layout: "vertical",
|
||
class: "mx-2"
|
||
}),
|
||
createBaseVNode("div", _hoisted_2, [
|
||
workflowTabsPosition.value === "Topbar" ? (openBlock(), createBlock(WorkflowTabs, { key: 0 })) : createCommentVNode("", true)
|
||
]),
|
||
createBaseVNode("div", {
|
||
class: "comfyui-menu-right",
|
||
ref_key: "menuRight",
|
||
ref: menuRight
|
||
}, null, 512),
|
||
createVNode(Actionbar),
|
||
createVNode(_sfc_main$2),
|
||
withDirectives(createVNode(unref(script$f), {
|
||
icon: "pi pi-bars",
|
||
severity: "secondary",
|
||
text: "",
|
||
onClick: _cache[0] || (_cache[0] = ($event) => unref(workspaceState).focusMode = true),
|
||
onContextmenu: unref(showNativeMenu)
|
||
}, null, 8, ["onContextmenu"]), [
|
||
[_directive_tooltip, { value: _ctx.$t("menu.hideMenu"), showDelay: 300 }]
|
||
])
|
||
], 2), [
|
||
[vShow, betaMenuEnabled.value && !unref(workspaceState).focusMode]
|
||
])
|
||
], 8, ["to"]);
|
||
};
|
||
}
|
||
});
|
||
const TopMenubar = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-d792da31"]]);
|
||
function setupAutoQueueHandler() {
|
||
const queueCountStore = useQueuePendingTaskCountStore();
|
||
const queueSettingsStore = useQueueSettingsStore();
|
||
let graphHasChanged = false;
|
||
let internalCount = 0;
|
||
api.addEventListener("graphChanged", () => {
|
||
if (queueSettingsStore.mode === "change") {
|
||
if (internalCount) {
|
||
graphHasChanged = true;
|
||
} else {
|
||
graphHasChanged = false;
|
||
app.queuePrompt(0, queueSettingsStore.batchCount);
|
||
internalCount++;
|
||
}
|
||
}
|
||
});
|
||
queueCountStore.$subscribe(
|
||
() => {
|
||
internalCount = queueCountStore.count;
|
||
if (!internalCount && !app.lastExecutionError) {
|
||
if (queueSettingsStore.mode === "instant" || queueSettingsStore.mode === "change" && graphHasChanged) {
|
||
graphHasChanged = false;
|
||
app.queuePrompt(0, queueSettingsStore.batchCount);
|
||
}
|
||
}
|
||
},
|
||
{ detached: true }
|
||
);
|
||
}
|
||
__name(setupAutoQueueHandler, "setupAutoQueueHandler");
|
||
var LatentPreviewMethod = /* @__PURE__ */ ((LatentPreviewMethod2) => {
|
||
LatentPreviewMethod2["NoPreviews"] = "none";
|
||
LatentPreviewMethod2["Auto"] = "auto";
|
||
LatentPreviewMethod2["Latent2RGB"] = "latent2rgb";
|
||
LatentPreviewMethod2["TAESD"] = "taesd";
|
||
return LatentPreviewMethod2;
|
||
})(LatentPreviewMethod || {});
|
||
var LogLevel = /* @__PURE__ */ ((LogLevel2) => {
|
||
LogLevel2["DEBUG"] = "DEBUG";
|
||
LogLevel2["INFO"] = "INFO";
|
||
LogLevel2["WARNING"] = "WARNING";
|
||
LogLevel2["ERROR"] = "ERROR";
|
||
LogLevel2["CRITICAL"] = "CRITICAL";
|
||
return LogLevel2;
|
||
})(LogLevel || {});
|
||
var HashFunction = /* @__PURE__ */ ((HashFunction2) => {
|
||
HashFunction2["MD5"] = "md5";
|
||
HashFunction2["SHA1"] = "sha1";
|
||
HashFunction2["SHA256"] = "sha256";
|
||
HashFunction2["SHA512"] = "sha512";
|
||
return HashFunction2;
|
||
})(HashFunction || {});
|
||
var AutoLaunch = /* @__PURE__ */ ((AutoLaunch2) => {
|
||
AutoLaunch2["Auto"] = "auto";
|
||
AutoLaunch2["Disable"] = "disable";
|
||
AutoLaunch2["Enable"] = "enable";
|
||
return AutoLaunch2;
|
||
})(AutoLaunch || {});
|
||
var CudaMalloc = /* @__PURE__ */ ((CudaMalloc2) => {
|
||
CudaMalloc2["Auto"] = "auto";
|
||
CudaMalloc2["Disable"] = "disable";
|
||
CudaMalloc2["Enable"] = "enable";
|
||
return CudaMalloc2;
|
||
})(CudaMalloc || {});
|
||
var FloatingPointPrecision = /* @__PURE__ */ ((FloatingPointPrecision2) => {
|
||
FloatingPointPrecision2["AUTO"] = "auto";
|
||
FloatingPointPrecision2["FP64"] = "fp64";
|
||
FloatingPointPrecision2["FP32"] = "fp32";
|
||
FloatingPointPrecision2["FP16"] = "fp16";
|
||
FloatingPointPrecision2["BF16"] = "bf16";
|
||
FloatingPointPrecision2["FP8E4M3FN"] = "fp8_e4m3fn";
|
||
FloatingPointPrecision2["FP8E5M2"] = "fp8_e5m2";
|
||
return FloatingPointPrecision2;
|
||
})(FloatingPointPrecision || {});
|
||
var CrossAttentionMethod = /* @__PURE__ */ ((CrossAttentionMethod2) => {
|
||
CrossAttentionMethod2["Auto"] = "auto";
|
||
CrossAttentionMethod2["Split"] = "split";
|
||
CrossAttentionMethod2["Quad"] = "quad";
|
||
CrossAttentionMethod2["Pytorch"] = "pytorch";
|
||
return CrossAttentionMethod2;
|
||
})(CrossAttentionMethod || {});
|
||
var VramManagement = /* @__PURE__ */ ((VramManagement2) => {
|
||
VramManagement2["Auto"] = "auto";
|
||
VramManagement2["GPUOnly"] = "gpu-only";
|
||
VramManagement2["HighVram"] = "highvram";
|
||
VramManagement2["NormalVram"] = "normalvram";
|
||
VramManagement2["LowVram"] = "lowvram";
|
||
VramManagement2["NoVram"] = "novram";
|
||
VramManagement2["CPU"] = "cpu";
|
||
return VramManagement2;
|
||
})(VramManagement || {});
|
||
const WEB_ONLY_CONFIG_ITEMS = [
|
||
// Launch behavior
|
||
{
|
||
id: "auto-launch",
|
||
name: "Automatically opens in the browser on startup",
|
||
category: ["Launch"],
|
||
type: "combo",
|
||
options: Object.values(AutoLaunch),
|
||
defaultValue: AutoLaunch.Auto,
|
||
getValue: /* @__PURE__ */ __name((value) => {
|
||
switch (value) {
|
||
case AutoLaunch.Auto:
|
||
return {};
|
||
case AutoLaunch.Enable:
|
||
return {
|
||
["auto-launch"]: true
|
||
};
|
||
case AutoLaunch.Disable:
|
||
return {
|
||
["disable-auto-launch"]: true
|
||
};
|
||
}
|
||
}, "getValue")
|
||
}
|
||
];
|
||
const SERVER_CONFIG_ITEMS = [
|
||
// Network settings
|
||
{
|
||
id: "listen",
|
||
name: "Host: The IP address to listen on",
|
||
category: ["Network"],
|
||
type: "text",
|
||
defaultValue: "127.0.0.1"
|
||
},
|
||
{
|
||
id: "port",
|
||
name: "Port: The port to listen on",
|
||
category: ["Network"],
|
||
type: "number",
|
||
// The default launch port for desktop app is 8000 instead of 8188.
|
||
defaultValue: 8e3
|
||
},
|
||
{
|
||
id: "tls-keyfile",
|
||
name: "TLS Key File: Path to TLS key file for HTTPS",
|
||
category: ["Network"],
|
||
type: "text",
|
||
defaultValue: ""
|
||
},
|
||
{
|
||
id: "tls-certfile",
|
||
name: "TLS Certificate File: Path to TLS certificate file for HTTPS",
|
||
category: ["Network"],
|
||
type: "text",
|
||
defaultValue: ""
|
||
},
|
||
{
|
||
id: "enable-cors-header",
|
||
name: 'Enable CORS header: Use "*" for all origins or specify domain',
|
||
category: ["Network"],
|
||
type: "text",
|
||
defaultValue: ""
|
||
},
|
||
{
|
||
id: "max-upload-size",
|
||
name: "Maximum upload size (MB)",
|
||
category: ["Network"],
|
||
type: "number",
|
||
defaultValue: 100
|
||
},
|
||
// CUDA settings
|
||
{
|
||
id: "cuda-device",
|
||
name: "CUDA device index to use",
|
||
category: ["CUDA"],
|
||
type: "number",
|
||
defaultValue: null
|
||
},
|
||
{
|
||
id: "cuda-malloc",
|
||
name: "Use CUDA malloc for memory allocation",
|
||
category: ["CUDA"],
|
||
type: "combo",
|
||
options: Object.values(CudaMalloc),
|
||
defaultValue: CudaMalloc.Auto,
|
||
getValue: /* @__PURE__ */ __name((value) => {
|
||
switch (value) {
|
||
case CudaMalloc.Auto:
|
||
return {};
|
||
case CudaMalloc.Enable:
|
||
return {
|
||
["cuda-malloc"]: true
|
||
};
|
||
case CudaMalloc.Disable:
|
||
return {
|
||
["disable-cuda-malloc"]: true
|
||
};
|
||
}
|
||
}, "getValue")
|
||
},
|
||
// Precision settings
|
||
{
|
||
id: "global-precision",
|
||
name: "Global floating point precision",
|
||
category: ["Inference"],
|
||
type: "combo",
|
||
options: [
|
||
FloatingPointPrecision.AUTO,
|
||
FloatingPointPrecision.FP32,
|
||
FloatingPointPrecision.FP16
|
||
],
|
||
defaultValue: FloatingPointPrecision.AUTO,
|
||
tooltip: "Global floating point precision",
|
||
getValue: /* @__PURE__ */ __name((value) => {
|
||
switch (value) {
|
||
case FloatingPointPrecision.AUTO:
|
||
return {};
|
||
case FloatingPointPrecision.FP32:
|
||
return {
|
||
["force-fp32"]: true
|
||
};
|
||
case FloatingPointPrecision.FP16:
|
||
return {
|
||
["force-fp16"]: true
|
||
};
|
||
default:
|
||
return {};
|
||
}
|
||
}, "getValue")
|
||
},
|
||
// UNET precision
|
||
{
|
||
id: "unet-precision",
|
||
name: "UNET precision",
|
||
category: ["Inference"],
|
||
type: "combo",
|
||
options: [
|
||
FloatingPointPrecision.AUTO,
|
||
FloatingPointPrecision.FP64,
|
||
FloatingPointPrecision.FP32,
|
||
FloatingPointPrecision.FP16,
|
||
FloatingPointPrecision.BF16,
|
||
FloatingPointPrecision.FP8E4M3FN,
|
||
FloatingPointPrecision.FP8E5M2
|
||
],
|
||
defaultValue: FloatingPointPrecision.AUTO,
|
||
tooltip: "UNET precision",
|
||
getValue: /* @__PURE__ */ __name((value) => {
|
||
switch (value) {
|
||
case FloatingPointPrecision.AUTO:
|
||
return {};
|
||
default:
|
||
return {
|
||
[`${value.toLowerCase()}-unet`]: true
|
||
};
|
||
}
|
||
}, "getValue")
|
||
},
|
||
// VAE settings
|
||
{
|
||
id: "vae-precision",
|
||
name: "VAE precision",
|
||
category: ["Inference"],
|
||
type: "combo",
|
||
options: [
|
||
FloatingPointPrecision.AUTO,
|
||
FloatingPointPrecision.FP16,
|
||
FloatingPointPrecision.FP32,
|
||
FloatingPointPrecision.BF16
|
||
],
|
||
defaultValue: FloatingPointPrecision.AUTO,
|
||
tooltip: "VAE precision",
|
||
getValue: /* @__PURE__ */ __name((value) => {
|
||
switch (value) {
|
||
case FloatingPointPrecision.AUTO:
|
||
return {};
|
||
default:
|
||
return {
|
||
[`${value.toLowerCase()}-vae`]: true
|
||
};
|
||
}
|
||
}, "getValue")
|
||
},
|
||
{
|
||
id: "cpu-vae",
|
||
name: "Run VAE on CPU",
|
||
category: ["Inference"],
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
// Text Encoder settings
|
||
{
|
||
id: "text-encoder-precision",
|
||
name: "Text Encoder precision",
|
||
category: ["Inference"],
|
||
type: "combo",
|
||
options: [
|
||
FloatingPointPrecision.AUTO,
|
||
FloatingPointPrecision.FP8E4M3FN,
|
||
FloatingPointPrecision.FP8E5M2,
|
||
FloatingPointPrecision.FP16,
|
||
FloatingPointPrecision.FP32
|
||
],
|
||
defaultValue: FloatingPointPrecision.AUTO,
|
||
tooltip: "Text Encoder precision",
|
||
getValue: /* @__PURE__ */ __name((value) => {
|
||
switch (value) {
|
||
case FloatingPointPrecision.AUTO:
|
||
return {};
|
||
default:
|
||
return {
|
||
[`${value.toLowerCase()}-text-enc`]: true
|
||
};
|
||
}
|
||
}, "getValue")
|
||
},
|
||
// Memory and performance settings
|
||
{
|
||
id: "force-channels-last",
|
||
name: "Force channels-last memory format",
|
||
category: ["Memory"],
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
{
|
||
id: "directml",
|
||
name: "DirectML device index",
|
||
category: ["Memory"],
|
||
type: "number",
|
||
defaultValue: null
|
||
},
|
||
{
|
||
id: "disable-ipex-optimize",
|
||
name: "Disable IPEX optimization",
|
||
category: ["Memory"],
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
// Preview settings
|
||
{
|
||
id: "preview-method",
|
||
name: "Method used for latent previews",
|
||
category: ["Preview"],
|
||
type: "combo",
|
||
options: Object.values(LatentPreviewMethod),
|
||
defaultValue: LatentPreviewMethod.NoPreviews
|
||
},
|
||
{
|
||
id: "preview-size",
|
||
name: "Size of preview images",
|
||
category: ["Preview"],
|
||
type: "slider",
|
||
defaultValue: 512,
|
||
attrs: {
|
||
min: 128,
|
||
max: 2048,
|
||
step: 128
|
||
}
|
||
},
|
||
// Cache settings
|
||
{
|
||
id: "cache-classic",
|
||
name: "Use classic cache system",
|
||
category: ["Cache"],
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
{
|
||
id: "cache-lru",
|
||
name: "Use LRU caching with a maximum of N node results cached.",
|
||
category: ["Cache"],
|
||
type: "number",
|
||
defaultValue: null,
|
||
tooltip: "May use more RAM/VRAM."
|
||
},
|
||
// Attention settings
|
||
{
|
||
id: "cross-attention-method",
|
||
name: "Cross attention method",
|
||
category: ["Attention"],
|
||
type: "combo",
|
||
options: Object.values(CrossAttentionMethod),
|
||
defaultValue: CrossAttentionMethod.Auto,
|
||
getValue: /* @__PURE__ */ __name((value) => {
|
||
switch (value) {
|
||
case CrossAttentionMethod.Auto:
|
||
return {};
|
||
default:
|
||
return {
|
||
[`use-${value.toLowerCase()}-cross-attention`]: true
|
||
};
|
||
}
|
||
}, "getValue")
|
||
},
|
||
{
|
||
id: "disable-xformers",
|
||
name: "Disable xFormers optimization",
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
{
|
||
id: "force-upcast-attention",
|
||
name: "Force attention upcast",
|
||
category: ["Attention"],
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
{
|
||
id: "dont-upcast-attention",
|
||
name: "Prevent attention upcast",
|
||
category: ["Attention"],
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
// VRAM management
|
||
{
|
||
id: "vram-management",
|
||
name: "VRAM management mode",
|
||
category: ["Memory"],
|
||
type: "combo",
|
||
options: Object.values(VramManagement),
|
||
defaultValue: VramManagement.Auto,
|
||
getValue: /* @__PURE__ */ __name((value) => {
|
||
switch (value) {
|
||
case VramManagement.Auto:
|
||
return {};
|
||
default:
|
||
return {
|
||
[value]: true
|
||
};
|
||
}
|
||
}, "getValue")
|
||
},
|
||
{
|
||
id: "reserve-vram",
|
||
name: "Reserved VRAM (GB)",
|
||
category: ["Memory"],
|
||
type: "number",
|
||
defaultValue: null,
|
||
tooltip: "Set the amount of vram in GB you want to reserve for use by your OS/other software. By default some amount is reverved depending on your OS."
|
||
},
|
||
// Misc settings
|
||
{
|
||
id: "default-hashing-function",
|
||
name: "Default hashing function for model files",
|
||
type: "combo",
|
||
options: Object.values(HashFunction),
|
||
defaultValue: HashFunction.SHA256
|
||
},
|
||
{
|
||
id: "disable-smart-memory",
|
||
name: "Disable smart memory management",
|
||
tooltip: "Force ComfyUI to aggressively offload to regular ram instead of keeping models in vram when it can.",
|
||
category: ["Memory"],
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
{
|
||
id: "deterministic",
|
||
name: "Make pytorch use slower deterministic algorithms when it can.",
|
||
type: "boolean",
|
||
defaultValue: false,
|
||
tooltip: "Note that this might not make images deterministic in all cases."
|
||
},
|
||
{
|
||
id: "fast",
|
||
name: "Enable some untested and potentially quality deteriorating optimizations.",
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
{
|
||
id: "dont-print-server",
|
||
name: "Don't print server output to console.",
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
{
|
||
id: "disable-metadata",
|
||
name: "Disable saving prompt metadata in files.",
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
{
|
||
id: "disable-all-custom-nodes",
|
||
name: "Disable loading all custom nodes.",
|
||
type: "boolean",
|
||
defaultValue: false
|
||
},
|
||
{
|
||
id: "log-level",
|
||
name: "Logging verbosity level",
|
||
type: "combo",
|
||
options: Object.values(LogLevel),
|
||
defaultValue: LogLevel.INFO,
|
||
getValue: /* @__PURE__ */ __name((value) => {
|
||
return {
|
||
verbose: value
|
||
};
|
||
}, "getValue")
|
||
},
|
||
// Directories
|
||
{
|
||
id: "input-directory",
|
||
name: "Input directory",
|
||
category: ["Directories"],
|
||
type: "text",
|
||
defaultValue: ""
|
||
},
|
||
{
|
||
id: "output-directory",
|
||
name: "Output directory",
|
||
category: ["Directories"],
|
||
type: "text",
|
||
defaultValue: ""
|
||
}
|
||
];
|
||
function useCoreCommands() {
|
||
const getTracker = /* @__PURE__ */ __name(() => useWorkflowStore()?.activeWorkflow?.changeTracker, "getTracker");
|
||
const getSelectedNodes = /* @__PURE__ */ __name(() => {
|
||
const selectedNodes = app.canvas.selected_nodes;
|
||
const result = [];
|
||
if (selectedNodes) {
|
||
for (const i in selectedNodes) {
|
||
const node = selectedNodes[i];
|
||
result.push(node);
|
||
}
|
||
}
|
||
return result;
|
||
}, "getSelectedNodes");
|
||
const toggleSelectedNodesMode = /* @__PURE__ */ __name((mode) => {
|
||
getSelectedNodes().forEach((node) => {
|
||
if (node.mode === mode) {
|
||
node.mode = LGraphEventMode.ALWAYS;
|
||
} else {
|
||
node.mode = mode;
|
||
}
|
||
});
|
||
}, "toggleSelectedNodesMode");
|
||
return [
|
||
{
|
||
id: "Comfy.NewBlankWorkflow",
|
||
icon: "pi pi-plus",
|
||
label: "New Blank Workflow",
|
||
menubarLabel: "New",
|
||
function: /* @__PURE__ */ __name(() => workflowService.loadBlankWorkflow(), "function")
|
||
},
|
||
{
|
||
id: "Comfy.OpenWorkflow",
|
||
icon: "pi pi-folder-open",
|
||
label: "Open Workflow",
|
||
menubarLabel: "Open",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
app.ui.loadFile();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.LoadDefaultWorkflow",
|
||
icon: "pi pi-code",
|
||
label: "Load Default Workflow",
|
||
function: /* @__PURE__ */ __name(() => workflowService.loadDefaultWorkflow(), "function")
|
||
},
|
||
{
|
||
id: "Comfy.SaveWorkflow",
|
||
icon: "pi pi-save",
|
||
label: "Save Workflow",
|
||
menubarLabel: "Save",
|
||
function: /* @__PURE__ */ __name(async () => {
|
||
const workflow = useWorkflowStore().activeWorkflow;
|
||
if (!workflow) return;
|
||
await workflowService.saveWorkflow(workflow);
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.SaveWorkflowAs",
|
||
icon: "pi pi-save",
|
||
label: "Save Workflow As",
|
||
menubarLabel: "Save As",
|
||
function: /* @__PURE__ */ __name(async () => {
|
||
const workflow = useWorkflowStore().activeWorkflow;
|
||
if (!workflow) return;
|
||
await workflowService.saveWorkflowAs(workflow);
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.ExportWorkflow",
|
||
icon: "pi pi-download",
|
||
label: "Export Workflow",
|
||
menubarLabel: "Export",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
workflowService.exportWorkflow("workflow", "workflow");
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.ExportWorkflowAPI",
|
||
icon: "pi pi-download",
|
||
label: "Export Workflow (API Format)",
|
||
menubarLabel: "Export (API)",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
workflowService.exportWorkflow("workflow_api", "output");
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Undo",
|
||
icon: "pi pi-undo",
|
||
label: "Undo",
|
||
function: /* @__PURE__ */ __name(async () => {
|
||
await getTracker()?.undo?.();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Redo",
|
||
icon: "pi pi-refresh",
|
||
label: "Redo",
|
||
function: /* @__PURE__ */ __name(async () => {
|
||
await getTracker()?.redo?.();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.ClearWorkflow",
|
||
icon: "pi pi-trash",
|
||
label: "Clear Workflow",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
const settingStore = useSettingStore();
|
||
if (!settingStore.get("Comfy.ComfirmClear") || confirm("Clear workflow?")) {
|
||
app.clean();
|
||
app.graph.clear();
|
||
api.dispatchCustomEvent("graphCleared");
|
||
}
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ResetView",
|
||
icon: "pi pi-expand",
|
||
label: "Reset View",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
app.resetView();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.OpenClipspace",
|
||
icon: "pi pi-clipboard",
|
||
label: "Clipspace",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
app.openClipspace();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.RefreshNodeDefinitions",
|
||
icon: "pi pi-refresh",
|
||
label: "Refresh Node Definitions",
|
||
function: /* @__PURE__ */ __name(async () => {
|
||
await app.refreshComboInNodes();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Interrupt",
|
||
icon: "pi pi-stop",
|
||
label: "Interrupt",
|
||
function: /* @__PURE__ */ __name(async () => {
|
||
await api.interrupt();
|
||
useToastStore().add({
|
||
severity: "info",
|
||
summary: "Interrupted",
|
||
detail: "Execution has been interrupted",
|
||
life: 1e3
|
||
});
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.ClearPendingTasks",
|
||
icon: "pi pi-stop",
|
||
label: "Clear Pending Tasks",
|
||
function: /* @__PURE__ */ __name(async () => {
|
||
await useQueueStore().clear(["queue"]);
|
||
useToastStore().add({
|
||
severity: "info",
|
||
summary: "Confirmed",
|
||
detail: "Pending tasks deleted",
|
||
life: 3e3
|
||
});
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.BrowseTemplates",
|
||
icon: "pi pi-folder-open",
|
||
label: "Browse Templates",
|
||
function: showTemplateWorkflowsDialog
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ZoomIn",
|
||
icon: "pi pi-plus",
|
||
label: "Zoom In",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
const ds = app.canvas.ds;
|
||
ds.changeScale(
|
||
ds.scale * 1.1,
|
||
ds.element ? [ds.element.width / 2, ds.element.height / 2] : void 0
|
||
);
|
||
app.canvas.setDirty(true, true);
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ZoomOut",
|
||
icon: "pi pi-minus",
|
||
label: "Zoom Out",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
const ds = app.canvas.ds;
|
||
ds.changeScale(
|
||
ds.scale / 1.1,
|
||
ds.element ? [ds.element.width / 2, ds.element.height / 2] : void 0
|
||
);
|
||
app.canvas.setDirty(true, true);
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.FitView",
|
||
icon: "pi pi-expand",
|
||
label: "Fit view to selected nodes",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
if (app.canvas.empty) {
|
||
useToastStore().add({
|
||
severity: "error",
|
||
summary: "Empty canvas",
|
||
life: 3e3
|
||
});
|
||
return;
|
||
}
|
||
app.canvas.fitViewToSelectionAnimated();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ToggleLock",
|
||
icon: "pi pi-lock",
|
||
label: "Canvas Toggle Lock",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
app.canvas["read_only"] = !app.canvas["read_only"];
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ToggleLinkVisibility",
|
||
icon: "pi pi-eye",
|
||
label: "Canvas Toggle Link Visibility",
|
||
versionAdded: "1.3.6",
|
||
function: (() => {
|
||
const settingStore = useSettingStore();
|
||
let lastLinksRenderMode = LiteGraph.SPLINE_LINK;
|
||
return () => {
|
||
const currentMode = settingStore.get("Comfy.LinkRenderMode");
|
||
if (currentMode === LiteGraph.HIDDEN_LINK) {
|
||
settingStore.set("Comfy.LinkRenderMode", lastLinksRenderMode);
|
||
} else {
|
||
lastLinksRenderMode = currentMode;
|
||
settingStore.set("Comfy.LinkRenderMode", LiteGraph.HIDDEN_LINK);
|
||
}
|
||
};
|
||
})()
|
||
},
|
||
{
|
||
id: "Comfy.QueuePrompt",
|
||
icon: "pi pi-play",
|
||
label: "Queue Prompt",
|
||
versionAdded: "1.3.7",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
const batchCount = useQueueSettingsStore().batchCount;
|
||
app.queuePrompt(0, batchCount);
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.QueuePromptFront",
|
||
icon: "pi pi-play",
|
||
label: "Queue Prompt (Front)",
|
||
versionAdded: "1.3.7",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
const batchCount = useQueueSettingsStore().batchCount;
|
||
app.queuePrompt(-1, batchCount);
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.ShowSettingsDialog",
|
||
icon: "pi pi-cog",
|
||
label: "Show Settings Dialog",
|
||
versionAdded: "1.3.7",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
showSettingsDialog();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Graph.GroupSelectedNodes",
|
||
icon: "pi pi-sitemap",
|
||
label: "Group Selected Nodes",
|
||
versionAdded: "1.3.7",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
const { canvas } = app;
|
||
if (!canvas.selectedItems?.size) {
|
||
useToastStore().add({
|
||
severity: "error",
|
||
summary: "Nothing to group",
|
||
detail: "Please select the nodes (or other groups) to create a group for",
|
||
life: 3e3
|
||
});
|
||
return;
|
||
}
|
||
const group = new LGraphGroup();
|
||
const padding = useSettingStore().get(
|
||
"Comfy.GroupSelectedNodes.Padding"
|
||
);
|
||
group.resizeTo(canvas.selectedItems, padding);
|
||
canvas.graph.add(group);
|
||
useTitleEditorStore().titleEditorTarget = group;
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Workspace.NextOpenedWorkflow",
|
||
icon: "pi pi-step-forward",
|
||
label: "Next Opened Workflow",
|
||
versionAdded: "1.3.9",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
workflowService.loadNextOpenedWorkflow();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Workspace.PreviousOpenedWorkflow",
|
||
icon: "pi pi-step-backward",
|
||
label: "Previous Opened Workflow",
|
||
versionAdded: "1.3.9",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
workflowService.loadPreviousOpenedWorkflow();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ToggleSelectedNodes.Mute",
|
||
icon: "pi pi-volume-off",
|
||
label: "Mute/Unmute Selected Nodes",
|
||
versionAdded: "1.3.11",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
toggleSelectedNodesMode(LGraphEventMode.NEVER);
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ToggleSelectedNodes.Bypass",
|
||
icon: "pi pi-shield",
|
||
label: "Bypass/Unbypass Selected Nodes",
|
||
versionAdded: "1.3.11",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
toggleSelectedNodesMode(LGraphEventMode.BYPASS);
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ToggleSelectedNodes.Pin",
|
||
icon: "pi pi-pin",
|
||
label: "Pin/Unpin Selected Nodes",
|
||
versionAdded: "1.3.11",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
getSelectedNodes().forEach((node) => {
|
||
node.pin(!node.pinned);
|
||
});
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ToggleSelected.Pin",
|
||
icon: "pi pi-pin",
|
||
label: "Pin/Unpin Selected Items",
|
||
versionAdded: "1.3.33",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
for (const item3 of app.canvas.selectedItems) {
|
||
if (item3 instanceof LGraphNode || item3 instanceof LGraphGroup) {
|
||
item3.pin(!item3.pinned);
|
||
}
|
||
}
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Canvas.ToggleSelectedNodes.Collapse",
|
||
icon: "pi pi-minus",
|
||
label: "Collapse/Expand Selected Nodes",
|
||
versionAdded: "1.3.11",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
getSelectedNodes().forEach((node) => {
|
||
node.collapse();
|
||
});
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.ToggleTheme",
|
||
icon: "pi pi-moon",
|
||
label: "Toggle Theme (Dark/Light)",
|
||
versionAdded: "1.3.12",
|
||
function: /* @__PURE__ */ (() => {
|
||
let previousDarkTheme = "dark";
|
||
const isDarkMode = /* @__PURE__ */ __name((themeId) => themeId !== "light", "isDarkMode");
|
||
return () => {
|
||
const settingStore = useSettingStore();
|
||
const currentTheme = settingStore.get("Comfy.ColorPalette");
|
||
if (isDarkMode(currentTheme)) {
|
||
previousDarkTheme = currentTheme;
|
||
settingStore.set("Comfy.ColorPalette", "light");
|
||
} else {
|
||
settingStore.set("Comfy.ColorPalette", previousDarkTheme);
|
||
}
|
||
};
|
||
})()
|
||
},
|
||
{
|
||
id: "Workspace.ToggleBottomPanel",
|
||
icon: "pi pi-list",
|
||
label: "Toggle Bottom Panel",
|
||
versionAdded: "1.3.22",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
useBottomPanelStore().toggleBottomPanel();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Workspace.ToggleFocusMode",
|
||
icon: "pi pi-eye",
|
||
label: "Toggle Focus Mode",
|
||
versionAdded: "1.3.27",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
useWorkspaceStore().toggleFocusMode();
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Graph.FitGroupToContents",
|
||
icon: "pi pi-expand",
|
||
label: "Fit Group To Contents",
|
||
versionAdded: "1.4.9",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
for (const group of app.canvas.selectedItems) {
|
||
if (group instanceof LGraphGroup) {
|
||
group.recomputeInsideNodes();
|
||
const padding = useSettingStore().get(
|
||
"Comfy.GroupSelectedNodes.Padding"
|
||
);
|
||
group.resizeTo(group.children, padding);
|
||
app.graph.change();
|
||
}
|
||
}
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Help.OpenComfyUIIssues",
|
||
icon: "pi pi-github",
|
||
label: "Open ComfyUI Issues",
|
||
menubarLabel: "ComfyUI Issues",
|
||
versionAdded: "1.5.5",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
window.open(
|
||
"https://github.com/comfyanonymous/ComfyUI/issues",
|
||
"_blank"
|
||
);
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Help.OpenComfyUIDocs",
|
||
icon: "pi pi-info-circle",
|
||
label: "Open ComfyUI Docs",
|
||
menubarLabel: "ComfyUI Docs",
|
||
versionAdded: "1.5.5",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
window.open("https://docs.comfy.org/", "_blank");
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Comfy.Help.OpenComfyOrgDiscord",
|
||
icon: "pi pi-discord",
|
||
label: "Open Comfy-Org Discord",
|
||
menubarLabel: "Comfy-Org Discord",
|
||
versionAdded: "1.5.5",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
window.open("https://www.comfy.org/discord", "_blank");
|
||
}, "function")
|
||
},
|
||
{
|
||
id: "Workspace.SearchBox.Toggle",
|
||
icon: "pi pi-search",
|
||
label: "Toggle Search Box",
|
||
versionAdded: "1.5.7",
|
||
function: /* @__PURE__ */ __name(() => {
|
||
useSearchBoxStore().toggleVisible();
|
||
}, "function")
|
||
}
|
||
];
|
||
}
|
||
__name(useCoreCommands, "useCoreCommands");
|
||
const _sfc_main = /* @__PURE__ */ defineComponent({
|
||
__name: "GraphView",
|
||
setup(__props) {
|
||
setupAutoQueueHandler();
|
||
const { t } = useI18n();
|
||
const toast = useToast();
|
||
const settingStore = useSettingStore();
|
||
const executionStore = useExecutionStore();
|
||
const theme11 = computed(() => settingStore.get("Comfy.ColorPalette"));
|
||
watch(
|
||
theme11,
|
||
(newTheme) => {
|
||
const DARK_THEME_CLASS = "dark-theme";
|
||
const isDarkTheme = newTheme !== "light";
|
||
if (isDarkTheme) {
|
||
document.body.classList.add(DARK_THEME_CLASS);
|
||
} else {
|
||
document.body.classList.remove(DARK_THEME_CLASS);
|
||
}
|
||
},
|
||
{ immediate: true }
|
||
);
|
||
watchEffect(() => {
|
||
const fontSize = settingStore.get("Comfy.TextareaWidget.FontSize");
|
||
document.documentElement.style.setProperty(
|
||
"--comfy-textarea-font-size",
|
||
`${fontSize}px`
|
||
);
|
||
});
|
||
watchEffect(() => {
|
||
const padding = settingStore.get("Comfy.TreeExplorer.ItemPadding");
|
||
document.documentElement.style.setProperty(
|
||
"--comfy-tree-explorer-item-padding",
|
||
`${padding}px`
|
||
);
|
||
});
|
||
watchEffect(() => {
|
||
const locale = settingStore.get("Comfy.Locale");
|
||
if (locale) {
|
||
i18n.global.locale.value = locale;
|
||
}
|
||
});
|
||
watchEffect(() => {
|
||
const useNewMenu = settingStore.get("Comfy.UseNewMenu");
|
||
if (useNewMenu === "Disabled") {
|
||
app.ui.menuContainer.style.removeProperty("display");
|
||
app.ui.restoreMenuPosition();
|
||
} else {
|
||
app.ui.menuContainer.style.setProperty("display", "none");
|
||
}
|
||
});
|
||
watchEffect(() => {
|
||
useQueueStore().maxHistoryItems = settingStore.get(
|
||
"Comfy.Queue.MaxHistoryItems"
|
||
);
|
||
});
|
||
const init = /* @__PURE__ */ __name(() => {
|
||
settingStore.addSettings(app.ui.settings);
|
||
const coreCommands = useCoreCommands();
|
||
useCommandStore().registerCommands(coreCommands);
|
||
useMenuItemStore().registerCoreMenuCommands();
|
||
useKeybindingStore().loadCoreKeybindings();
|
||
useSidebarTabStore().registerCoreSidebarTabs();
|
||
useBottomPanelStore().registerCoreBottomPanelTabs();
|
||
app.extensionManager = useWorkspaceStore();
|
||
}, "init");
|
||
const queuePendingTaskCountStore = useQueuePendingTaskCountStore();
|
||
const onStatus = /* @__PURE__ */ __name((e) => {
|
||
queuePendingTaskCountStore.update(e);
|
||
}, "onStatus");
|
||
const reconnectingMessage = {
|
||
severity: "error",
|
||
summary: t("g.reconnecting")
|
||
};
|
||
const onReconnecting = /* @__PURE__ */ __name(() => {
|
||
toast.remove(reconnectingMessage);
|
||
toast.add(reconnectingMessage);
|
||
}, "onReconnecting");
|
||
const onReconnected = /* @__PURE__ */ __name(() => {
|
||
toast.remove(reconnectingMessage);
|
||
toast.add({
|
||
severity: "success",
|
||
summary: t("g.reconnected"),
|
||
life: 2e3
|
||
});
|
||
}, "onReconnected");
|
||
onMounted(() => {
|
||
api.addEventListener("status", onStatus);
|
||
api.addEventListener("reconnecting", onReconnecting);
|
||
api.addEventListener("reconnected", onReconnected);
|
||
executionStore.bindExecutionEvents();
|
||
try {
|
||
init();
|
||
} catch (e) {
|
||
console.error("Failed to init ComfyUI frontend", e);
|
||
}
|
||
});
|
||
onBeforeUnmount(() => {
|
||
api.removeEventListener("status", onStatus);
|
||
api.removeEventListener("reconnecting", onReconnecting);
|
||
api.removeEventListener("reconnected", onReconnected);
|
||
executionStore.unbindExecutionEvents();
|
||
});
|
||
const onGraphReady = /* @__PURE__ */ __name(() => {
|
||
requestIdleCallback(
|
||
() => {
|
||
useKeybindingStore().loadUserKeybindings();
|
||
useServerConfigStore().loadServerConfig(
|
||
SERVER_CONFIG_ITEMS,
|
||
settingStore.get("Comfy.Server.ServerConfigValues")
|
||
);
|
||
useModelStore().loadModelFolders();
|
||
useNodeDefStore().nodeSearchService.endsWithFilterStartSequence("");
|
||
useNodeFrequencyStore().loadNodeFrequencies();
|
||
},
|
||
{ timeout: 1e3 }
|
||
);
|
||
}, "onGraphReady");
|
||
return (_ctx, _cache) => {
|
||
return openBlock(), createElementBlock(Fragment, null, [
|
||
createVNode(TopMenubar),
|
||
createVNode(_sfc_main$c, { onReady: onGraphReady }),
|
||
createVNode(_sfc_main$a),
|
||
createVNode(_sfc_main$9),
|
||
createVNode(_sfc_main$8),
|
||
createVNode(MenuHamburger)
|
||
], 64);
|
||
};
|
||
}
|
||
});
|
||
export {
|
||
_sfc_main as default
|
||
};
|
||
//# sourceMappingURL=GraphView-BWxgNrh6.js.map
|