2024-10-28 18:29:38 +00:00
var _ _defProp = Object . defineProperty ;
var _ _name = ( target , value ) => _ _defProp ( target , "name" , { value , configurable : true } ) ;
2025-01-02 21:18:54 +00:00
import { d as defineComponent , u as useExecutionStore , c as computed , a as useSettingStore , b as useWorkflowStore , e as useTitle , o as openBlock , f as createElementBlock , g as useWorkspaceStore , w as watchEffect , h as app , r as resolveDirective , i as withDirectives , v as vShow , j as unref , k as createBlock , n as normalizeStyle , s as showNativeMenu , l as script$d , _ as _export _sfc , m as onMounted , p as onBeforeUnmount , B as BaseStyle , q as script$e , t as getWidth , x as getHeight , y as getOuterWidth , z as getOuterHeight , A as getVNodeProp , C as isArray , D as mergeProps , F as Fragment , E as renderList , G as resolveDynamicComponent , H as createBaseVNode , I as createCommentVNode , J as renderSlot , K as useSidebarTabStore , L as useBottomPanelStore , M as withCtx , N as createVNode , O as getAttribute , P as findSingle , Q as focus , R as equals , S as Ripple , T as normalizeClass , U as getOffset , V as script$f , W as script$g , X as toDisplayString , Y as script$h , Z as markRaw , $ as defineStore , a0 as shallowRef , a1 as useI18n , a2 as useCommandStore , a3 as LiteGraph , a4 as useColorPaletteStore , a5 as watch , a6 as useNodeDefStore , a7 as BadgePosition , a8 as LGraphBadge , a9 as _ , aa as NodeBadgeMode , ab as ref , ac as useEventListener , ad as nextTick , ae as st , af as normalizeI18nKey , ag as LGraphGroup , ah as LGraphNode , ai as EditableText , aj as isNotEmpty , ak as UniqueComponentId , al as ZIndex , am as resolveFieldData , an as OverlayEventBus , ao as isEmpty , ap as addStyle , aq as relativePosition , ar as absolutePosition , as as ConnectedOverlayScrollHandler , at as isTouchDevice , au as findLastIndex , av as script$i , aw as script$j , ax as script$k , ay as script$l , az as script$m , aA as script$n , aB as resolveComponent , aC as Transition , aD as createSlots , aE as createTextVNode , aF as useNodeFrequencyStore , aG as useNodeBookmarkStore , aH as highlightQuery , aI as script$o , aJ as formatNumberWithSuffix , aK as NodeSourceType , aL as pushScopeId , aM as popScopeId , aN as NodePreview , aO as NodeSearchFilter , aP as script$p , aQ as SearchFilterChip , aR as useLitegraphService , aS as storeToRefs , aT as isRef , aU as toRaw , aV as LinkReleaseTriggerAction , aW as script$q , aX as useUserStore , aY as useDialogStore , aZ as SettingDialogHeader , a _ as SettingDialogContent , a$ as useKeybindingStore , b0 as Teleport , b1 as LinkMarkerShape , b2 as useModelToNodeStore , b3 as CanvasPointer , b4 as IS _CONTROL _WIDGET , b5 as updateControlWidgetLabel , b6 as useColorPaletteService , b7 as setStorageValue , b8 as api , b9 as usePragmaticDroppable , ba as LGraph , bb as LLink , bc as DragAndScale , bd as LGraphCanvas , be as ContextMenu , bf as ChangeTracker , bg as useWorkflowService , bh as ComfyNodeDefImpl , bi as ComfyModelDef , bj as script$r , bk as script$s , bl as script$t , bm as script$u , bn as script$v , bo as normalizeProps , bp as ToastEventBus , bq as setAttribute , br as TransitionGroup , bs as useToast , bt as useToastStore , bu as resolve , bv as nestedPosition , bw as script$w , bx as isPrintableCharacter , by as useQueueSettingsStore , bz as script$x , bA as useQueuePendingTaskCountStore , bB as useLocalStorage , bC as useDraggable , bD as watchDebounced , bE as inject , bF as useElementBounding , bG as lodashExports , bH as useEventBus , bI as script$z , bJ as guardReactiveProps , bK as useMenuItemStore , bL as usePragmaticDraggable , bM as withModifiers , bN as script$B , bO as script$C , bP as provide , bQ as script$D , bR as useDialogService , bS as LGraphEventMode , bT as useQueueStore , bU as i18n , bV as useModelStore } from "./index-CJmKJOqY.js" ;
import { s as script$y } from "./index-COz_BRFJ.js" ;
import { s as script$A } from "./index-xXycuGHJ.js" ;
import { u as useKeybindingService } from "./keybindingService-DyirEpoV.js" ;
import { u as useServerConfigStore } from "./serverConfigStore-CCtRsrpA.js" ;
import "./index-DAh4IuBR.js" ;
const DEFAULT _TITLE = "ComfyUI" ;
const TITLE _SUFFIX = " - ComfyUI" ;
const _sfc _main$t = /* @__PURE__ */ defineComponent ( {
_ _name : "BrowserTabTitle" ,
2024-10-28 18:29:38 +00:00
setup ( _ _props ) {
2025-01-02 21:18:54 +00:00
const executionStore = useExecutionStore ( ) ;
const executionText = computed (
( ) => executionStore . isIdle ? "" : ` [ ${ executionStore . executionProgress } %] `
) ;
2024-10-28 18:29:38 +00:00
const settingStore = useSettingStore ( ) ;
2025-01-02 21:18:54 +00:00
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 ;
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
const nodeExecutionTitle = computed (
( ) => executionStore . executingNode && executionStore . executingNodeProgress ? ` ${ executionText . value } [ ${ executionStore . executingNodeProgress } %] ${ executionStore . executingNode . type } ` : ""
2024-10-28 18:29:38 +00:00
) ;
2025-01-02 21:18:54 +00:00
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 _sfc _main$s = /* @__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" ) {
2024-10-28 18:29:38 +00:00
return ;
}
2025-01-02 21:18:54 +00:00
if ( workspaceState . focusMode ) {
app . ui . menuContainer . style . display = "none" ;
} else {
app . ui . menuContainer . style . display = "block" ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ;
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$d ) , {
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 } ]
] ) ;
2024-10-28 18:29:38 +00:00
} ;
2025-01-02 21:18:54 +00:00
}
} ) ;
const MenuHamburger = /* @__PURE__ */ _export _sfc ( _sfc _main$s , [ [ "__scopeId" , "data-v-5661bed0" ] ] ) ;
const _sfc _main$r = /* @__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" ) ;
2024-10-28 18:29:38 +00:00
onMounted ( ( ) => {
2025-01-02 21:18:54 +00:00
window . addEventListener ( "beforeunload" , handleBeforeUnload ) ;
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
onBeforeUnmount ( ( ) => {
window . removeEventListener ( "beforeunload" , handleBeforeUnload ) ;
2024-10-28 18:29:38 +00:00
} ) ;
return ( _ctx , _cache ) => {
2025-01-02 21:18:54 +00:00
return openBlock ( ) , createElementBlock ( "div" ) ;
2024-10-28 18:29:38 +00:00
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
var theme$7 = /* @__PURE__ */ _ _name ( function theme ( _ref ) {
2024-10-28 18:29:38 +00:00
var dt = _ref . dt ;
2025-01-02 21:18:54 +00:00
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" ) ;
2024-10-28 18:29:38 +00:00
} , "theme" ) ;
2025-01-02 21:18:54 +00:00
var classes$a = {
root : /* @__PURE__ */ _ _name ( function root ( _ref2 ) {
var props = _ref2 . props ;
return [ "p-splitter p-component" , "p-splitter-" + props . layout ] ;
} , "root" ) ,
gutter : "p-splitter-gutter" ,
gutterHandle : "p-splitter-gutter-handle"
2024-10-28 18:29:38 +00:00
} ;
2025-01-02 21:18:54 +00:00
var inlineStyles$4 = {
root : /* @__PURE__ */ _ _name ( function root2 ( _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$a ,
inlineStyles : inlineStyles$4
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
var script$1$a = {
name : "BaseSplitter" ,
2024-10-29 18:14:06 +00:00
"extends" : script$e ,
2025-01-02 21:18:54 +00:00
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 ,
2024-10-28 18:29:38 +00:00
provide : /* @__PURE__ */ _ _name ( function provide2 ( ) {
return {
2025-01-02 21:18:54 +00:00
$pcSplitter : this ,
2024-10-28 18:29:38 +00:00
$parentInstance : this
} ;
} , "provide" )
} ;
2025-01-02 21:18:54 +00:00
function _toConsumableArray$2 ( r ) {
return _arrayWithoutHoles$2 ( r ) || _iterableToArray$2 ( r ) || _unsupportedIterableToArray$2 ( r ) || _nonIterableSpread$2 ( ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
}
_ _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" ) ;
2024-10-29 18:14:06 +00:00
var script$c = {
2025-01-02 21:18:54 +00:00
name : "Splitter" ,
2024-10-29 18:14:06 +00:00
"extends" : script$1$a ,
inheritAttrs : false ,
2025-01-02 21:18:54 +00:00
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 data ( ) {
2024-10-29 18:14:06 +00:00
return {
2025-01-02 21:18:54 +00:00
prevSize : null
2024-10-29 18:14:06 +00:00
} ;
} , "data" ) ,
mounted : /* @__PURE__ */ _ _name ( function mounted ( ) {
var _this = this ;
2025-01-02 21:18:54 +00:00
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 ) ;
}
2024-10-29 18:14:06 +00:00
}
} , "mounted" ) ,
beforeUnmount : /* @__PURE__ */ _ _name ( function beforeUnmount ( ) {
2025-01-02 21:18:54 +00:00
this . clear ( ) ;
this . unbindMouseListeners ( ) ;
2024-10-29 18:14:06 +00:00
} , "beforeUnmount" ) ,
methods : {
2025-01-02 21:18:54 +00:00
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 ) ;
2024-10-29 18:14:06 +00:00
} else {
2025-01-02 21:18:54 +00:00
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 ;
2024-10-29 18:14:06 +00:00
}
2025-01-02 21:18:54 +00:00
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 ;
}
2024-10-29 18:14:06 +00:00
} else {
2025-01-02 21:18:54 +00:00
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 ;
2024-10-29 18:14:06 +00:00
}
2025-01-02 21:18:54 +00:00
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 ) {
2024-10-29 18:14:06 +00:00
switch ( event . code ) {
2025-01-02 21:18:54 +00:00
case "ArrowLeft" : {
if ( this . layout === "horizontal" ) {
this . setTimer ( event , index , this . step * - 1 ) ;
}
event . preventDefault ( ) ;
2024-10-29 18:14:06 +00:00
break ;
2025-01-02 21:18:54 +00:00
}
case "ArrowRight" : {
if ( this . layout === "horizontal" ) {
this . setTimer ( event , index , this . step ) ;
}
event . preventDefault ( ) ;
2024-10-29 18:14:06 +00:00
break ;
2025-01-02 21:18:54 +00:00
}
case "ArrowDown" : {
if ( this . layout === "vertical" ) {
this . setTimer ( event , index , this . step * - 1 ) ;
}
event . preventDefault ( ) ;
2024-10-29 18:14:06 +00:00
break ;
2025-01-02 21:18:54 +00:00
}
case "ArrowUp" : {
if ( this . layout === "vertical" ) {
this . setTimer ( event , index , this . step ) ;
}
event . preventDefault ( ) ;
2024-10-29 18:14:06 +00:00
break ;
2025-01-02 21:18:54 +00:00
}
2024-10-29 18:14:06 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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 ( ) ;
2024-10-29 18:14:06 +00:00
event . preventDefault ( ) ;
2025-01-02 21:18:54 +00:00
} , "onGutterTouchStart" ) ,
onGutterTouchMove : /* @__PURE__ */ _ _name ( function onGutterTouchMove ( event ) {
this . onResize ( event ) ;
2024-10-29 18:14:06 +00:00
event . preventDefault ( ) ;
2025-01-02 21:18:54 +00:00
} , "onGutterTouchMove" ) ,
onGutterTouchEnd : /* @__PURE__ */ _ _name ( function onGutterTouchEnd ( event ) {
this . onResizeEnd ( event ) ;
this . unbindTouchListeners ( ) ;
2024-10-29 18:14:06 +00:00
event . preventDefault ( ) ;
2025-01-02 21:18:54 +00:00
} , "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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
if ( ! this . mouseUpListener ) {
this . mouseUpListener = function ( event ) {
_this3 . onResizeEnd ( event ) ;
_this3 . unbindMouseListeners ( ) ;
} ;
document . addEventListener ( "mouseup" , this . mouseUpListener ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
if ( ! this . touchEndListener ) {
this . touchEndListener = function ( event ) {
_this4 . resizeEnd ( event ) ;
_this4 . unbindTouchListeners ( ) ;
} ;
document . addEventListener ( "touchend" , this . touchEndListener ) ;
2024-10-28 18:29:38 +00:00
}
} , "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" )
}
} ;
2025-01-02 21:18:54 +00:00
var _hoisted _1$m = [ "onMousedown" , "onTouchstart" , "onTouchmove" , "onTouchend" ] ;
var _hoisted _2$j = [ "aria-orientation" , "aria-valuenow" , "onKeydown" ] ;
function render$j ( _ctx , _cache , $props , $setup , $data , $options ) {
2024-10-28 18:29:38 +00:00
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 ) ;
} ) ,
2024-10-29 18:14:06 +00:00
onKeydown : /* @__PURE__ */ _ _name ( function onKeydown2 ( $event ) {
2024-10-28 18:29:38 +00:00
return $options . onGutterKeyDown ( $event , i ) ;
} , "onKeydown" ) ,
ref _for : true
2025-01-02 21:18:54 +00:00
} , _ctx . ptm ( "gutterHandle" ) ) , null , 16 , _hoisted _2$j ) ] , 16 , _hoisted _1$m ) ) : createCommentVNode ( "" , true ) ] , 64 ) ;
2024-10-28 18:29:38 +00:00
} ) , 128 ) ) ] , 16 ) ;
}
2025-01-02 21:18:54 +00:00
_ _name ( render$j , "render$j" ) ;
script$c . render = render$j ;
var classes$9 = {
root : /* @__PURE__ */ _ _name ( function root3 ( _ref ) {
2024-10-28 18:29:38 +00:00
var instance = _ref . instance ;
return [ "p-splitterpanel" , {
"p-splitterpanel-nested" : instance . isNested
} ] ;
} , "root" )
} ;
var SplitterPanelStyle = BaseStyle . extend ( {
name : "splitterpanel" ,
2025-01-02 21:18:54 +00:00
classes : classes$9
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
var script$1$9 = {
2024-10-28 18:29:38 +00:00
name : "BaseSplitterPanel" ,
2025-01-02 21:18:54 +00:00
"extends" : script$e ,
2024-10-28 18:29:38 +00:00
props : {
size : {
type : Number ,
"default" : null
} ,
minSize : {
type : Number ,
"default" : null
}
} ,
style : SplitterPanelStyle ,
2025-01-02 21:18:54 +00:00
provide : /* @__PURE__ */ _ _name ( function provide3 ( ) {
2024-10-28 18:29:38 +00:00
return {
$pcSplitterPanel : this ,
$parentInstance : this
} ;
} , "provide" )
} ;
2025-01-02 21:18:54 +00:00
var script$b = {
2024-10-28 18:29:38 +00:00
name : "SplitterPanel" ,
2025-01-02 21:18:54 +00:00
"extends" : script$1$9 ,
2024-10-28 18:29:38 +00:00
inheritAttrs : false ,
2025-01-02 21:18:54 +00:00
data : /* @__PURE__ */ _ _name ( function data2 ( ) {
2024-10-28 18:29:38 +00:00
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" )
}
} ;
2025-01-02 21:18:54 +00:00
function render$i ( _ctx , _cache , $props , $setup , $data , $options ) {
2024-10-28 18:29:38 +00:00
return openBlock ( ) , createElementBlock ( "div" , mergeProps ( {
ref : "container" ,
"class" : _ctx . cx ( "root" )
} , _ctx . ptmi ( "root" , $options . getPTOptions ) ) , [ renderSlot ( _ctx . $slots , "default" ) ] , 16 ) ;
}
2025-01-02 21:18:54 +00:00
_ _name ( render$i , "render$i" ) ;
script$b . render = render$i ;
const _sfc _main$q = /* @__PURE__ */ defineComponent ( {
2024-10-28 18:29:38 +00:00
_ _name : "LiteGraphCanvasSplitterOverlay" ,
setup ( _ _props ) {
const settingStore = useSettingStore ( ) ;
const sidebarLocation = computed (
( ) => settingStore . get ( "Comfy.Sidebar.Location" )
) ;
const sidebarPanelVisible = computed (
2024-10-29 18:14:06 +00:00
( ) => useSidebarTabStore ( ) . activeSidebarTab !== null
) ;
const bottomPanelVisible = computed (
( ) => useBottomPanelStore ( ) . bottomPanelVisible
2024-10-28 18:29:38 +00:00
) ;
2025-01-02 21:18:54 +00:00
const activeSidebarTabId = computed (
( ) => useSidebarTabStore ( ) . activeSidebarTabId
) ;
2024-10-28 18:29:38 +00:00
return ( _ctx , _cache ) => {
2025-01-02 21:18:54 +00:00
return openBlock ( ) , createBlock ( unref ( script$c ) , {
2024-10-29 18:14:06 +00:00
class : "splitter-overlay-root splitter-overlay" ,
2024-11-16 01:17:15 +00:00
"pt:gutter" : sidebarPanelVisible . value ? "" : "hidden" ,
2025-01-02 21:18:54 +00:00
key : activeSidebarTabId . value ,
stateKey : activeSidebarTabId . value ,
2024-11-16 01:17:15 +00:00
stateStorage : "local"
2024-10-28 18:29:38 +00:00
} , {
default : withCtx ( ( ) => [
2025-01-02 21:18:54 +00:00
sidebarLocation . value === "left" ? withDirectives ( ( openBlock ( ) , createBlock ( unref ( script$b ) , {
2024-10-28 18:29:38 +00:00
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 ) ,
2025-01-02 21:18:54 +00:00
createVNode ( unref ( script$b ) , { size : 100 } , {
2024-10-28 18:29:38 +00:00
default : withCtx ( ( ) => [
2025-01-02 21:18:54 +00:00
createVNode ( unref ( script$c ) , {
2024-11-16 01:17:15 +00:00
class : "splitter-overlay max-w-full" ,
2024-10-29 18:14:06 +00:00
layout : "vertical" ,
2024-11-16 01:17:15 +00:00
"pt:gutter" : bottomPanelVisible . value ? "" : "hidden" ,
stateKey : "bottom-panel-splitter" ,
stateStorage : "local"
2024-10-29 18:14:06 +00:00
} , {
default : withCtx ( ( ) => [
2025-01-02 21:18:54 +00:00
createVNode ( unref ( script$b ) , { class : "graph-canvas-panel relative" } , {
2024-10-29 18:14:06 +00:00
default : withCtx ( ( ) => [
renderSlot ( _ctx . $slots , "graph-canvas-panel" , { } , void 0 , true )
] ) ,
_ : 3
} ) ,
2025-01-02 21:18:54 +00:00
withDirectives ( createVNode ( unref ( script$b ) , { class : "bottom-panel" } , {
2024-10-29 18:14:06 +00:00
default : withCtx ( ( ) => [
renderSlot ( _ctx . $slots , "bottom-panel" , { } , void 0 , true )
] ) ,
_ : 3
} , 512 ) , [
[ vShow , bottomPanelVisible . value ]
] )
] ) ,
_ : 3
} , 8 , [ "pt:gutter" ] )
2024-10-28 18:29:38 +00:00
] ) ,
_ : 3
} ) ,
2025-01-02 21:18:54 +00:00
sidebarLocation . value === "right" ? withDirectives ( ( openBlock ( ) , createBlock ( unref ( script$b ) , {
2024-10-28 18:29:38 +00:00
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
2025-01-02 21:18:54 +00:00
} , 8 , [ "pt:gutter" , "stateKey" ] ) ;
2024-10-28 18:29:38 +00:00
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
const LiteGraphCanvasSplitterOverlay = /* @__PURE__ */ _export _sfc ( _sfc _main$q , [ [ "__scopeId" , "data-v-e50caa15" ] ] ) ;
var classes$8 = {
root : /* @__PURE__ */ _ _name ( function root4 ( _ref ) {
var instance = _ref . instance , props = _ref . props ;
return [ "p-tab" , {
"p-tab-active" : instance . active ,
"p-disabled" : props . disabled
2024-10-28 18:29:38 +00:00
} ] ;
2025-01-02 21:18:54 +00:00
} , "root" )
2024-10-28 18:29:38 +00:00
} ;
2025-01-02 21:18:54 +00:00
var TabStyle = BaseStyle . extend ( {
name : "tab" ,
classes : classes$8
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
var script$1$8 = {
name : "BaseTab" ,
"extends" : script$e ,
2024-10-28 18:29:38 +00:00
props : {
2025-01-02 21:18:54 +00:00
value : {
type : [ String , Number ] ,
"default" : void 0
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
disabled : {
2024-10-28 18:29:38 +00:00
type : Boolean ,
"default" : false
} ,
2025-01-02 21:18:54 +00:00
as : {
type : [ String , Object ] ,
"default" : "BUTTON"
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
asChild : {
2024-10-28 18:29:38 +00:00
type : Boolean ,
"default" : false
}
} ,
2025-01-02 21:18:54 +00:00
style : TabStyle ,
provide : /* @__PURE__ */ _ _name ( function provide4 ( ) {
2024-10-28 18:29:38 +00:00
return {
2025-01-02 21:18:54 +00:00
$pcTab : this ,
2024-10-28 18:29:38 +00:00
$parentInstance : this
} ;
} , "provide" )
} ;
2025-01-02 21:18:54 +00:00
var script$a = {
name : "Tab" ,
"extends" : script$1$8 ,
2024-10-28 18:29:38 +00:00
inheritAttrs : false ,
2025-01-02 21:18:54 +00:00
inject : [ "$pcTabs" , "$pcTabList" ] ,
2024-10-28 18:29:38 +00:00
methods : {
2025-01-02 21:18:54 +00:00
onFocus : /* @__PURE__ */ _ _name ( function onFocus ( ) {
this . $pcTabs . selectOnFocus && this . changeActiveValue ( ) ;
2024-10-28 18:29:38 +00:00
} , "onFocus" ) ,
2025-01-02 21:18:54 +00:00
onClick : /* @__PURE__ */ _ _name ( function onClick ( ) {
this . changeActiveValue ( ) ;
} , "onClick" ) ,
onKeydown : /* @__PURE__ */ _ _name ( function onKeydown ( event ) {
2024-10-28 18:29:38 +00:00
switch ( event . code ) {
2025-01-02 21:18:54 +00:00
case "ArrowRight" :
this . onArrowRightKey ( event ) ;
2024-10-28 18:29:38 +00:00
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" :
2025-01-02 21:18:54 +00:00
case "Space" :
2024-10-28 18:29:38 +00:00
this . onEnterKey ( event ) ;
break ;
}
2025-01-02 21:18:54 +00:00
} , "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
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ;
} , "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$a . render = render$h ;
var classes$7 = {
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$7
} ) ;
var script$1$7 = {
name : "BaseTabList" ,
"extends" : script$e ,
props : { } ,
style : TabListStyle ,
provide : /* @__PURE__ */ _ _name ( function provide5 ( ) {
return {
$pcTabList : this ,
$parentInstance : this
} ;
} , "provide" )
} ;
var script$9 = {
name : "TabList" ,
"extends" : script$1$7 ,
inheritAttrs : false ,
inject : [ "$pcTabs" ] ,
data : /* @__PURE__ */ _ _name ( function data3 ( ) {
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 mounted2 ( ) {
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 beforeUnmount2 ( ) {
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 ( ) ;
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
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" ;
2024-10-28 18:29:38 +00:00
} else {
2025-01-02 21:18:54 +00:00
inkbar . style . width = getOuterWidth ( activeTab ) + "px" ;
inkbar . style . left = getOffset ( activeTab ) . left - getOffset ( tabs ) . left + "px" ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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 ;
2024-10-28 18:29:38 +00:00
} else {
2025-01-02 21:18:54 +00:00
this . isPrevButtonEnabled = scrollLeft !== 0 ;
this . isNextButtonEnabled = list . offsetWidth >= offsetWidth && parseInt ( scrollLeft ) !== scrollWidth - width ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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$f ,
ChevronRightIcon : script$g
} ,
directives : {
ripple : Ripple
}
} ;
var _hoisted _1$l = [ "aria-label" , "tabindex" ] ;
var _hoisted _2$i = [ "aria-orientation" ] ;
var _hoisted _3$g = [ "aria-label" , "tabindex" ] ;
function render$g ( _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$l ) ) , [ [ _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$i ) ] , 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$g , "render$g" ) ;
script$9 . render = render$g ;
const _sfc _main$p = /* @__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 ( ) ;
2024-10-28 18:29:38 +00:00
}
} ) ;
return ( _ctx , _cache ) => {
2025-01-02 21:18:54 +00:00
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 ) ) ;
2024-10-28 18:29:38 +00:00
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
const _hoisted _1$k = { class : "flex flex-col h-full" } ;
const _hoisted _2$h = { class : "w-full flex justify-between" } ;
const _hoisted _3$f = { class : "tabs-container" } ;
const _hoisted _4$5 = { class : "font-bold" } ;
const _hoisted _5$4 = { class : "flex-grow h-0" } ;
const _sfc _main$o = /* @__PURE__ */ defineComponent ( {
_ _name : "BottomPanel" ,
2024-10-29 18:14:06 +00:00
setup ( _ _props ) {
2025-01-02 21:18:54 +00:00
const bottomPanelStore = useBottomPanelStore ( ) ;
2024-10-29 18:14:06 +00:00
return ( _ctx , _cache ) => {
2025-01-02 21:18:54 +00:00
return openBlock ( ) , createElementBlock ( "div" , _hoisted _1$k , [
createVNode ( unref ( script$h ) , {
value : unref ( bottomPanelStore ) . activeBottomPanelTabId ,
"onUpdate:value" : _cache [ 1 ] || ( _cache [ 1 ] = ( $event ) => unref ( bottomPanelStore ) . activeBottomPanelTabId = $event )
} , {
default : withCtx ( ( ) => [
createVNode ( unref ( script$9 ) , { "pt:tabList" : "border-none" } , {
default : withCtx ( ( ) => [
createBaseVNode ( "div" , _hoisted _2$h , [
createBaseVNode ( "div" , _hoisted _3$f , [
( openBlock ( true ) , createElementBlock ( Fragment , null , renderList ( unref ( bottomPanelStore ) . bottomPanelTabs , ( tab ) => {
return openBlock ( ) , createBlock ( unref ( script$a ) , {
key : tab . id ,
value : tab . id ,
class : "p-3 border-none"
} , {
default : withCtx ( ( ) => [
createBaseVNode ( "span" , _hoisted _4$5 , toDisplayString ( tab . title . toUpperCase ( ) ) , 1 )
] ) ,
_ : 2
} , 1032 , [ "value" ] ) ;
} ) , 128 ) )
] ) ,
createVNode ( unref ( script$d ) , {
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$p , {
key : 0 ,
extension : unref ( bottomPanelStore ) . activeBottomPanelTab
} , null , 8 , [ "extension" ] ) ) : createCommentVNode ( "" , true )
] )
] ) ;
2024-10-29 18:14:06 +00:00
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
const _hoisted _1$j = {
2024-10-28 18:29:38 +00:00
viewBox : "0 0 1024 1024" ,
width : "1.2em" ,
height : "1.2em"
} ;
2025-01-02 21:18:54 +00:00
const _hoisted _2$g = /* @__PURE__ */ createBaseVNode ( "path" , {
2024-10-28 18:29:38 +00:00
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 ) ;
2025-01-02 21:18:54 +00:00
const _hoisted _3$e = [
_hoisted _2$g
2024-10-28 18:29:38 +00:00
] ;
2025-01-02 21:18:54 +00:00
function render$f ( _ctx , _cache ) {
return openBlock ( ) , createElementBlock ( "svg" , _hoisted _1$j , [ ... _hoisted _3$e ] ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( render$f , "render$f" ) ;
const _ _unplugin _components _1$2 = markRaw ( { name : "simple-line-icons-cursor" , render : render$f } ) ;
const _hoisted _1$i = {
2024-10-28 18:29:38 +00:00
viewBox : "0 0 24 24" ,
width : "1.2em" ,
height : "1.2em"
} ;
2025-01-02 21:18:54 +00:00
const _hoisted _2$f = /* @__PURE__ */ createBaseVNode ( "path" , {
2024-10-28 18:29:38 +00:00
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 ) ;
2025-01-02 21:18:54 +00:00
const _hoisted _3$d = [
_hoisted _2$f
2024-10-28 18:29:38 +00:00
] ;
2025-01-02 21:18:54 +00:00
function render$e ( _ctx , _cache ) {
return openBlock ( ) , createElementBlock ( "svg" , _hoisted _1$i , [ ... _hoisted _3$d ] ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( render$e , "render$e" ) ;
const _ _unplugin _components _0$2 = markRaw ( { name : "material-symbols-pan-tool-outline" , render : render$e } ) ;
var theme$6 = /* @__PURE__ */ _ _name ( function theme2 ( _ref ) {
2024-10-28 18:29:38 +00:00
_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" ) ;
2025-01-02 21:18:54 +00:00
var classes$6 = {
2024-10-28 18:29:38 +00:00
root : "p-buttongroup p-component"
} ;
var ButtonGroupStyle = BaseStyle . extend ( {
name : "buttongroup" ,
2025-01-02 21:18:54 +00:00
theme : theme$6 ,
classes : classes$6
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
var script$1$6 = {
2024-10-28 18:29:38 +00:00
name : "BaseButtonGroup" ,
2025-01-02 21:18:54 +00:00
"extends" : script$e ,
2024-10-28 18:29:38 +00:00
style : ButtonGroupStyle ,
2025-01-02 21:18:54 +00:00
provide : /* @__PURE__ */ _ _name ( function provide6 ( ) {
2024-10-28 18:29:38 +00:00
return {
$pcButtonGroup : this ,
$parentInstance : this
} ;
} , "provide" )
} ;
2025-01-02 21:18:54 +00:00
var script$8 = {
2024-10-28 18:29:38 +00:00
name : "ButtonGroup" ,
2025-01-02 21:18:54 +00:00
"extends" : script$1$6 ,
2024-10-28 18:29:38 +00:00
inheritAttrs : false
} ;
2025-01-02 21:18:54 +00:00
function render$d ( _ctx , _cache , $props , $setup , $data , $options ) {
2024-10-28 18:29:38 +00:00
return openBlock ( ) , createElementBlock ( "span" , mergeProps ( {
"class" : _ctx . cx ( "root" ) ,
role : "group"
} , _ctx . ptmi ( "root" ) ) , [ renderSlot ( _ctx . $slots , "default" ) ] , 16 ) ;
}
2025-01-02 21:18:54 +00:00
_ _name ( render$d , "render$d" ) ;
script$8 . render = render$d ;
const useTitleEditorStore = defineStore ( "titleEditor" , ( ) => {
const titleEditorTarget = shallowRef ( null ) ;
return {
titleEditorTarget
} ;
} ) ;
const useCanvasStore = defineStore ( "canvas" , ( ) => {
const canvas = shallowRef ( null ) ;
return {
canvas
} ;
} ) ;
const _sfc _main$n = /* @__PURE__ */ defineComponent ( {
2024-10-28 18:29:38 +00:00
_ _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 ) => {
2024-10-29 18:14:06 +00:00
const _component _i _material _symbols58pan _tool _outline = _ _unplugin _components _0$2 ;
2024-11-16 01:17:15 +00:00
const _component _i _simple _line _icons58cursor = _ _unplugin _components _1$2 ;
2024-10-28 18:29:38 +00:00
const _directive _tooltip = resolveDirective ( "tooltip" ) ;
2025-01-02 21:18:54 +00:00
return openBlock ( ) , createBlock ( unref ( script$8 ) , { class : "p-buttongroup-vertical absolute bottom-[10px] right-[10px] z-[1000] pointer-events-auto" } , {
2024-10-28 18:29:38 +00:00
default : withCtx ( ( ) => [
2025-01-02 21:18:54 +00:00
withDirectives ( createVNode ( unref ( script$d ) , {
2024-10-28 18:29:38 +00:00
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 }
]
] ) ,
2025-01-02 21:18:54 +00:00
withDirectives ( createVNode ( unref ( script$d ) , {
2024-10-28 18:29:38 +00:00
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 }
]
] ) ,
2025-01-02 21:18:54 +00:00
withDirectives ( createVNode ( unref ( script$d ) , {
2024-10-28 18:29:38 +00:00
severity : "secondary" ,
icon : "pi pi-expand" ,
2024-11-16 01:17:15 +00:00
onClick : _cache [ 2 ] || ( _cache [ 2 ] = ( ) => unref ( commandStore ) . execute ( "Comfy.Canvas.FitView" ) )
2024-10-28 18:29:38 +00:00
} , null , 512 ) , [
[
_directive _tooltip ,
2024-11-16 01:17:15 +00:00
unref ( t ) ( "graphCanvasMenu.fitView" ) ,
2024-10-28 18:29:38 +00:00
void 0 ,
{ left : true }
]
] ) ,
2025-01-02 21:18:54 +00:00
withDirectives ( ( openBlock ( ) , createBlock ( unref ( script$d ) , {
2024-10-28 18:29:38 +00:00
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 }
]
] ) ,
2025-01-02 21:18:54 +00:00
withDirectives ( createVNode ( unref ( script$d ) , {
2024-10-28 18:29:38 +00:00
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
} ) ;
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
const GraphCanvasMenu = /* @__PURE__ */ _export _sfc ( _sfc _main$n , [ [ "__scopeId" , "data-v-cf40dd39" ] ] ) ;
const _sfc _main$m = /* @__PURE__ */ defineComponent ( {
_ _name : "NodeBadge" ,
setup ( _ _props ) {
2024-10-28 18:29:38 +00:00
const settingStore = useSettingStore ( ) ;
2025-01-02 21:18:54 +00:00
const colorPaletteStore = useColorPaletteStore ( ) ;
const nodeSourceBadgeMode = computed (
( ) => settingStore . get ( "Comfy.NodeBadge.NodeSourceBadgeMode" )
2024-10-28 18:29:38 +00:00
) ;
2025-01-02 21:18:54 +00:00
const nodeIdBadgeMode = computed (
( ) => settingStore . get ( "Comfy.NodeBadge.NodeIdBadgeMode" )
2024-10-28 18:29:38 +00:00
) ;
2025-01-02 21:18:54 +00:00
const nodeLifeCycleBadgeMode = computed (
( ) => settingStore . get ( "Comfy.NodeBadge.NodeLifeCycleBadgeMode" )
) ;
watch ( [ nodeSourceBadgeMode , nodeIdBadgeMode , nodeLifeCycleBadgeMode ] , ( ) => {
app . graph ? . setDirtyCanvas ( true , true ) ;
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
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 : colorPaletteStore . completedActivePalette . colors . litegraph _base . BADGE _FG _COLOR ,
bgColor : colorPaletteStore . completedActivePalette . colors . litegraph _base . BADGE _BG _COLOR
} ) ;
} ) ;
node . badges . push ( ( ) => badge . value ) ;
2024-12-16 19:38:24 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ;
2024-10-28 18:29:38 +00:00
} ) ;
return ( _ctx , _cache ) => {
2025-01-02 21:18:54 +00:00
return openBlock ( ) , createElementBlock ( "div" ) ;
2024-10-28 18:29:38 +00:00
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
const _sfc _main$l = /* @__PURE__ */ defineComponent ( {
_ _name : "NodeTooltip" ,
2024-11-16 01:17:15 +00:00
setup ( _ _props ) {
2025-01-02 21:18:54 +00:00
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" ;
2024-11-16 01:17:15 +00:00
}
2025-01-02 21:18:54 +00:00
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 ) ;
2024-11-16 01:17:15 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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$l , [ [ "__scopeId" , "data-v-46859edf" ] ] ) ;
const _sfc _main$k = /* @__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"
2024-11-16 01:17:15 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
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 ` ;
}
}
2024-11-16 01:17:15 +00:00
) ;
2025-01-02 21:18:54 +00:00
const canvasEventHandler = /* @__PURE__ */ _ _name ( ( event ) => {
if ( event . detail . subType === "group-double-click" ) {
if ( ! settingStore . get ( "Comfy.Group.DoubleClickTitleToEdit" ) ) {
return ;
}
const group = event . detail . group ;
const [ x , y ] = group . pos ;
const e = event . detail . originalEvent ;
const relativeY = e . canvasY - y ;
if ( relativeY <= group . titleHeight ) {
titleEditorStore . titleEditorTarget = group ;
}
} else if ( event . detail . subType === "node-double-click" ) {
if ( ! settingStore . get ( "Comfy.Node.DoubleClickTitleToEdit" ) ) {
return ;
}
const node = event . detail . node ;
const [ x , y ] = node . pos ;
const e = event . detail . originalEvent ;
const relativeY = e . canvasY - y ;
if ( relativeY <= 0 ) {
titleEditorStore . titleEditorTarget = node ;
}
}
} , "canvasEventHandler" ) ;
useEventListener ( document , "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 ) ;
2024-11-16 01:17:15 +00:00
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
const TitleEditor = /* @__PURE__ */ _export _sfc ( _sfc _main$k , [ [ "__scopeId" , "data-v-12d3fd12" ] ] ) ;
const useSearchBoxStore = defineStore ( "searchBox" , ( ) => {
const visible = ref ( false ) ;
function toggleVisible ( ) {
visible . value = ! visible . value ;
}
_ _name ( toggleVisible , "toggleVisible" ) ;
return {
visible ,
toggleVisible
} ;
} ) ;
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 ) ;
}
2024-10-28 18:29:38 +00:00
}
}
2025-01-02 21:18:54 +00:00
var theme$5 = /* @__PURE__ */ _ _name ( function theme3 ( _ref ) {
2024-10-28 18:29:38 +00:00
var dt = _ref . dt ;
2025-01-02 21:18:54 +00:00
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: "
2024-10-28 18:29:38 +00:00
} , "theme" ) ;
2025-01-02 21:18:54 +00:00
var inlineStyles$3 = {
root : {
position : "relative"
}
2024-10-28 18:29:38 +00:00
} ;
2025-01-02 21:18:54 +00:00
var classes$5 = {
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
} ] ;
2024-10-28 18:29:38 +00:00
} , "root" ) ,
2025-01-02 21:18:54 +00:00
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"
2024-10-28 18:29:38 +00:00
} ] ;
2025-01-02 21:18:54 +00:00
} , "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"
2024-10-28 18:29:38 +00:00
} ;
2025-01-02 21:18:54 +00:00
var AutoCompleteStyle = BaseStyle . extend ( {
name : "autocomplete" ,
theme : theme$5 ,
classes : classes$5 ,
inlineStyles : inlineStyles$3
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
var script$1$5 = {
name : "BaseAutoComplete" ,
"extends" : script$e ,
2024-10-28 18:29:38 +00:00
props : {
2025-01-02 21:18:54 +00:00
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 : {
2024-10-28 18:29:38 +00:00
type : String ,
"default" : null
} ,
2025-01-02 21:18:54 +00:00
inputStyle : {
type : Object ,
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
inputClass : {
type : [ String , Object ] ,
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
panelStyle : {
type : Object ,
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
panelClass : {
type : [ String , Object ] ,
"default" : null
} ,
overlayStyle : {
2024-10-28 18:29:38 +00:00
type : Object ,
"default" : null
} ,
2025-01-02 21:18:54 +00:00
overlayClass : {
type : [ String , Object ] ,
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
dropdownIcon : {
2024-10-28 18:29:38 +00:00
type : String ,
2025-01-02 21:18:54 +00:00
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
dropdownClass : {
type : [ String , Object ] ,
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
loader : {
2024-10-28 18:29:38 +00:00
type : String ,
2025-01-02 21:18:54 +00:00
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
loadingIcon : {
2024-10-28 18:29:38 +00:00
type : String ,
2025-01-02 21:18:54 +00:00
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
removeTokenIcon : {
type : String ,
2024-10-28 18:29:38 +00:00
"default" : null
2025-01-02 21:18:54 +00:00
} ,
chipIcon : {
type : String ,
2024-10-28 18:29:38 +00:00
"default" : null
} ,
2025-01-02 21:18:54 +00:00
virtualScrollerOptions : {
2024-10-28 18:29:38 +00:00
type : Object ,
"default" : null
} ,
2025-01-02 21:18:54 +00:00
autoOptionFocus : {
type : Boolean ,
"default" : false
} ,
selectOnFocus : {
type : Boolean ,
"default" : false
} ,
focusOnHover : {
type : Boolean ,
"default" : true
} ,
searchLocale : {
2024-10-28 18:29:38 +00:00
type : String ,
2025-01-02 21:18:54 +00:00
"default" : void 0
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
searchMessage : {
2024-10-28 18:29:38 +00:00
type : String ,
"default" : null
} ,
2025-01-02 21:18:54 +00:00
selectionMessage : {
2024-10-28 18:29:38 +00:00
type : String ,
"default" : null
} ,
2025-01-02 21:18:54 +00:00
emptySelectionMessage : {
2024-10-28 18:29:38 +00:00
type : String ,
"default" : null
} ,
2025-01-02 21:18:54 +00:00
emptySearchMessage : {
2024-10-28 18:29:38 +00:00
type : String ,
"default" : null
} ,
2025-01-02 21:18:54 +00:00
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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( _typeof$1$1 , "_typeof$1$1" ) ;
function _toConsumableArray$1 ( r ) {
return _arrayWithoutHoles$1 ( r ) || _iterableToArray$1 ( r ) || _unsupportedIterableToArray$1 ( r ) || _nonIterableSpread$1 ( ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( _toConsumableArray$1 , "_toConsumableArray$1" ) ;
function _nonIterableSpread$1 ( ) {
2024-10-28 18:29:38 +00:00
throw new TypeError ( "Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method." ) ;
}
2025-01-02 21:18:54 +00:00
_ _name ( _nonIterableSpread$1 , "_nonIterableSpread$1" ) ;
function _unsupportedIterableToArray$1 ( r , a ) {
2024-10-28 18:29:38 +00:00
if ( r ) {
2025-01-02 21:18:54 +00:00
if ( "string" == typeof r ) return _arrayLikeToArray$1 ( r , a ) ;
2024-10-28 18:29:38 +00:00
var t = { } . toString . call ( r ) . slice ( 8 , - 1 ) ;
2025-01-02 21:18:54 +00:00
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 ;
2024-10-28 18:29:38 +00:00
}
}
2025-01-02 21:18:54 +00:00
_ _name ( _unsupportedIterableToArray$1 , "_unsupportedIterableToArray$1" ) ;
function _iterableToArray$1 ( r ) {
2024-10-28 18:29:38 +00:00
if ( "undefined" != typeof Symbol && null != r [ Symbol . iterator ] || null != r [ "@@iterator" ] ) return Array . from ( r ) ;
}
2025-01-02 21:18:54 +00:00
_ _name ( _iterableToArray$1 , "_iterableToArray$1" ) ;
function _arrayWithoutHoles$1 ( r ) {
if ( Array . isArray ( r ) ) return _arrayLikeToArray$1 ( r ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( _arrayWithoutHoles$1 , "_arrayWithoutHoles$1" ) ;
function _arrayLikeToArray$1 ( r , a ) {
2024-10-28 18:29:38 +00:00
( null == a || a > r . length ) && ( a = r . length ) ;
for ( var e = 0 , n = Array ( a ) ; e < a ; e ++ ) n [ e ] = r [ e ] ;
return n ;
}
2025-01-02 21:18:54 +00:00
_ _name ( _arrayLikeToArray$1 , "_arrayLikeToArray$1" ) ;
var script$7 = {
name : "AutoComplete" ,
"extends" : script$1$5 ,
2024-10-28 18:29:38 +00:00
inheritAttrs : false ,
2025-01-02 21:18:54 +00:00
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 ( ) {
2024-10-28 18:29:38 +00:00
return {
2025-01-02 21:18:54 +00:00
id : this . $attrs . id ,
clicked : false ,
focused : false ,
focusedOptionIndex : - 1 ,
focusedMultipleOptionIndex : - 1 ,
overlayVisible : false ,
searching : false
2024-10-28 18:29:38 +00:00
} ;
} , "data" ) ,
2025-01-02 21:18:54 +00:00
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 ( ) ;
2024-10-28 18:29:38 +00:00
} , "mounted" ) ,
2025-01-02 21:18:54 +00:00
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 ;
2024-10-28 18:29:38 +00:00
}
} , "beforeUnmount" ) ,
methods : {
2025-01-02 21:18:54 +00:00
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 )
}
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} , "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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
if ( ! this . dirty && this . completeOnFocus ) {
this . search ( event , event . target . value , "focus" ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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 ( ) ;
2024-10-28 18:29:38 +00:00
}
}
}
2025-01-02 21:18:54 +00:00
} , "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 ) ;
}
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
if ( ! valid ) {
if ( this . multiple ) this . $refs . focusInput . value = "" ;
else this . $refs . focusInput . $el . value = "" ;
this . $emit ( "clear" ) ;
! this . multiple && this . updateModel ( event , null ) ;
2024-10-28 18:29:38 +00:00
}
}
2025-01-02 21:18:54 +00:00
} , "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 ) {
2024-10-28 18:29:38 +00:00
event . preventDefault ( ) ;
return ;
}
2025-01-02 21:18:54 +00:00
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 ) ) {
2024-10-28 18:29:38 +00:00
return ;
}
2025-01-02 21:18:54 +00:00
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 ) ;
2024-12-16 19:38:24 +00:00
break ;
2025-01-02 21:18:54 +00:00
}
} , "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 = "" ;
2024-12-16 19:38:24 +00:00
}
2025-01-02 21:18:54 +00:00
} else {
if ( ! this . overlayVisible ) {
this . focusedOptionIndex = - 1 ;
this . onArrowDownKey ( event ) ;
} else {
if ( this . focusedOptionIndex !== - 1 ) {
this . onOptionSelect ( event , this . visibleOptions [ this . focusedOptionIndex ] ) ;
}
this . hide ( ) ;
2024-12-16 19:38:24 +00:00
}
2025-01-02 21:18:54 +00:00
}
} , "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
} ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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"
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
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 ) ;
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} , "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" , {
2024-10-28 18:29:38 +00:00
originalEvent : event ,
2025-01-02 21:18:54 +00:00
query
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} , "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" , {
2024-10-28 18:29:38 +00:00
originalEvent : event ,
2025-01-02 21:18:54 +00:00
value : removedOption
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
this . $emit ( "option-unselect" , {
2024-10-28 18:29:38 +00:00
originalEvent : event ,
2025-01-02 21:18:54 +00:00
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 ) ;
}
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} , "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" , {
2024-10-28 18:29:38 +00:00
originalEvent : event ,
2025-01-02 21:18:54 +00:00
value
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} , "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" )
2024-10-28 18:29:38 +00:00
} ,
computed : {
2025-01-02 21:18:54 +00:00
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 ) ;
2024-10-28 18:29:38 +00:00
} ) . length ;
2025-01-02 21:18:54 +00:00
} , "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" )
2024-10-28 18:29:38 +00:00
} ,
components : {
2025-01-02 21:18:54 +00:00
InputText : script$i ,
VirtualScroller : script$j ,
Portal : script$k ,
ChevronDownIcon : script$l ,
SpinnerIcon : script$m ,
Chip : script$n
2024-10-28 18:29:38 +00:00
} ,
directives : {
ripple : Ripple
}
} ;
2025-01-02 21:18:54 +00:00
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$h = [ "aria-activedescendant" ] ;
var _hoisted _2$e = [ "id" , "aria-label" , "aria-setsize" , "aria-posinset" ] ;
var _hoisted _3$c = [ "id" , "placeholder" , "tabindex" , "disabled" , "aria-label" , "aria-labelledby" , "aria-expanded" , "aria-controls" , "aria-activedescendant" , "aria-invalid" ] ;
var _hoisted _4$4 = [ "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$c ( _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 ,
2024-10-28 18:29:38 +00:00
ref _for : true
2025-01-02 21:18:54 +00:00
} , _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" ) ,
2024-10-28 18:29:38 +00:00
ref _for : true
2025-01-02 21:18:54 +00:00
} , _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$e ) ;
} ) , 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$c ) ] , 16 ) ] , 16 , _hoisted _1$h ) ) : 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 ( {
2024-10-28 18:29:38 +00:00
key : 0 ,
2025-01-02 21:18:54 +00:00
"class" : [ "pi-spin" , _ctx . cx ( "loader" ) , _ctx . loader , _ctx . loadingIcon ] ,
"aria-hidden" : "true"
} , _ctx . ptm ( "loader" ) ) , null , 16 ) ) : ( openBlock ( ) , createBlock ( _component _SpinnerIcon , mergeProps ( {
2024-10-28 18:29:38 +00:00
key : 1 ,
2025-01-02 21:18:54 +00:00
"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 ( {
2024-10-28 18:29:38 +00:00
key : 0 ,
2025-01-02 21:18:54 +00:00
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 ) ;
2024-10-28 18:29:38 +00:00
} )
2025-01-02 21:18:54 +00:00
} , _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$4 ) ) : 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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( render$c , "render$c" ) ;
script$7 . render = render$c ;
const _sfc _main$j = {
name : "AutoCompletePlus" ,
extends : script$7 ,
emits : [ "focused-option-changed" ] ,
mounted ( ) {
if ( typeof script$7 . mounted === "function" ) {
script$7 . mounted . call ( this ) ;
}
this . $watch (
( ) => this . focusedOptionIndex ,
( newVal , oldVal ) => {
this . $emit ( "focused-option-changed" , newVal ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
) ;
}
} ;
const _withScopeId$5 = /* @__PURE__ */ _ _name ( ( n ) => ( pushScopeId ( "data-v-5741c9ae" ) , n = n ( ) , popScopeId ( ) , n ) , "_withScopeId$5" ) ;
const _hoisted _1$g = { class : "option-container flex justify-between items-center px-2 py-0 cursor-pointer overflow-hidden w-full" } ;
const _hoisted _2$d = { class : "option-display-name font-semibold flex flex-col" } ;
const _hoisted _3$b = { key : 0 } ;
const _hoisted _4$3 = /* @__PURE__ */ _withScopeId$5 ( ( ) => /* @__PURE__ */ createBaseVNode ( "i" , { class : "pi pi-bookmark-fill text-sm mr-1" } , null , - 1 ) ) ;
const _hoisted _5$2 = [
_hoisted _4$3
] ;
const _hoisted _6$1 = [ "innerHTML" ] ;
const _hoisted _7 = /* @__PURE__ */ _withScopeId$5 ( ( ) => /* @__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 : { }
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
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$g , [
createBaseVNode ( "div" , _hoisted _2$d , [
createBaseVNode ( "div" , null , [
isBookmarked . value ? ( openBlock ( ) , createElementBlock ( "span" , _hoisted _3$b , _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$o ) , {
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$o ) , {
key : 0 ,
value : _ctx . $t ( "g.experimental" ) ,
severity : "primary"
} , null , 8 , [ "value" ] ) ) : createCommentVNode ( "" , true ) ,
_ctx . nodeDef . deprecated ? ( openBlock ( ) , createBlock ( unref ( script$o ) , {
key : 1 ,
value : _ctx . $t ( "g.deprecated" ) ,
severity : "danger"
} , null , 8 , [ "value" ] ) ) : createCommentVNode ( "" , true ) ,
showNodeFrequency . value && nodeFrequency . value > 0 ? ( openBlock ( ) , createBlock ( unref ( script$o ) , {
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$n ) , {
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-5741c9ae" ] ] ) ;
const _hoisted _1$f = { class : "comfy-vue-node-search-container flex justify-center items-center w-full min-w-96 pointer-events-auto" } ;
const _hoisted _2$c = {
key : 0 ,
class : "comfy-vue-node-preview-container absolute left-[-350px] top-[50px]"
} ;
const _hoisted _3$a = /* @__PURE__ */ createBaseVNode ( "h3" , null , "Add node filter condition" , - 1 ) ;
const _hoisted _4$2 = { 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 ;
let inputElement = null ;
const reFocusInput = /* @__PURE__ */ _ _name ( ( ) => {
inputElement ? ? = document . getElementById ( inputId ) ;
if ( inputElement ) {
inputElement . blur ( ) ;
nextTick ( ( ) => inputElement ? . focus ( ) ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "reFocusInput" ) ;
onMounted ( reFocusInput ) ;
const onAddFilter = /* @__PURE__ */ _ _name ( ( filterAndValue ) => {
nodeSearchFilterVisible . value = false ;
emit ( "addFilter" , filterAndValue ) ;
reFocusInput ( ) ;
} , "onAddFilter" ) ;
const onRemoveFilter = /* @__PURE__ */ _ _name ( ( event , filterAndValue ) => {
event . stopPropagation ( ) ;
2024-10-28 18:29:38 +00:00
event . preventDefault ( ) ;
2025-01-02 21:18:54 +00:00
emit ( "removeFilter" , filterAndValue ) ;
reFocusInput ( ) ;
} , "onRemoveFilter" ) ;
const setHoverSuggestion = /* @__PURE__ */ _ _name ( ( index ) => {
if ( index === - 1 ) {
hoveredSuggestion . value = null ;
return ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
const value = suggestions2 . value [ index ] ;
hoveredSuggestion . value = value ;
} , "setHoverSuggestion" ) ;
return ( _ctx , _cache ) => {
return openBlock ( ) , createElementBlock ( "div" , _hoisted _1$f , [
enableNodePreview . value ? ( openBlock ( ) , createElementBlock ( "div" , _hoisted _2$c , [
hoveredSuggestion . value ? ( openBlock ( ) , createBlock ( NodePreview , {
nodeDef : hoveredSuggestion . value ,
key : hoveredSuggestion . value ? . name || ""
} , null , 8 , [ "nodeDef" ] ) ) : createCommentVNode ( "" , true )
] ) ) : createCommentVNode ( "" , true ) ,
createVNode ( unref ( script$d ) , {
icon : "pi pi-filter" ,
severity : "secondary" ,
class : "filter-button z-10" ,
onClick : _cache [ 0 ] || ( _cache [ 0 ] = ( $event ) => nodeSearchFilterVisible . value = true )
} ) ,
createVNode ( unref ( script$p ) , {
visible : nodeSearchFilterVisible . value ,
"onUpdate:visible" : _cache [ 1 ] || ( _cache [ 1 ] = ( $event ) => nodeSearchFilterVisible . value = $event ) ,
class : "min-w-96"
} , {
header : withCtx ( ( ) => [
_hoisted _3$a
] ) ,
default : withCtx ( ( ) => [
createBaseVNode ( "div" , _hoisted _4$2 , [
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 } ) => [
( openBlock ( ) , createBlock ( SearchFilterChip , {
key : ` ${ value [ 0 ] . id } - ${ value [ 1 ] } ` ,
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" ] )
] ) ;
} ;
}
} ) ;
const _sfc _main$g = /* @__PURE__ */ defineComponent ( {
_ _name : "NodeSearchBoxPopover" ,
setup ( _ _props ) {
const settingStore = useSettingStore ( ) ;
const litegraphService = useLitegraphService ( ) ;
const { visible } = storeToRefs ( useSearchBoxStore ( ) ) ;
const dismissable = ref ( true ) ;
const triggerEvent = ref ( null ) ;
const getNewNodeLocation = /* @__PURE__ */ _ _name ( ( ) => {
if ( ! triggerEvent . value ) {
return litegraphService . getCanvasCenter ( ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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 = litegraphService . addNodeOnGraph ( nodeDef , {
pos : getNewNodeLocation ( )
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
const eventDetail = triggerEvent . value ? . detail ;
if ( eventDetail && eventDetail . subType === "empty-release" ) {
eventDetail . linkReleaseContext . links . forEach ( ( link ) => {
ConnectingLinkImpl . createFromPlainObject ( link ) . connectTo ( node ) ;
2024-10-28 18:29:38 +00:00
} ) ;
}
2025-01-02 21:18:54 +00:00
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 ) ;
2024-10-28 18:29:38 +00:00
}
} else {
2025-01-02 21:18:54 +00:00
canvasStore . canvas . showSearchBox ( detail . originalEvent ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
const firstLink = ConnectingLinkImpl . createFromPlainObject ( links [ 0 ] ) ;
const filter = nodeDefStore . nodeSearchService . getFilterById (
firstLink . releaseSlotType
) ;
const dataType = firstLink . type . toString ( ) ;
addFilter ( [ filter , dataType ] ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
const links = e . detail . linkReleaseContext . links ;
if ( links . length === 0 ) {
console . warn ( "Empty release with no links! This should never happen" ) ;
return ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ;
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 ) ;
}
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "handleCanvasEmptyRelease" ) ;
useEventListener ( document , "litegraph:canvas" , canvasEventHandler ) ;
return ( _ctx , _cache ) => {
return openBlock ( ) , createElementBlock ( "div" , null , [
createVNode ( unref ( script$p ) , {
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"
}
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , {
container : withCtx ( ( ) => [
createVNode ( _sfc _main$h , {
filters : nodeFilters . value ,
onAddFilter : addFilter ,
onRemoveFilter : removeFilter ,
onAddNode : addNode
} , null , 8 , [ "filters" ] )
] ) ,
_ : 1
} , 8 , [ "visible" , "dismissable-mask" ] )
] ) ;
} ;
}
} ) ;
var theme$4 = /* @__PURE__ */ _ _name ( function theme4 ( _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$4 = {
root : "p-overlaybadge"
} ;
var OverlayBadgeStyle = BaseStyle . extend ( {
name : "overlaybadge" ,
theme : theme$4 ,
classes : classes$4
} ) ;
var script$1$4 = {
name : "OverlayBadge" ,
"extends" : script$q ,
style : OverlayBadgeStyle ,
provide : /* @__PURE__ */ _ _name ( function provide8 ( ) {
return {
$pcOverlayBadge : this ,
$parentInstance : this
} ;
} , "provide" )
} ;
var script$6 = {
name : "OverlayBadge" ,
"extends" : script$1$4 ,
inheritAttrs : false ,
components : {
Badge : script$q
}
} ;
function render$b ( _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$b , "render$b" ) ;
script$6 . render = render$b ;
const _sfc _main$f = /* @__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$d ) , {
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
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ,
onClick : _cache [ 0 ] || ( _cache [ 0 ] = ( $event ) => emit ( "click" , $event ) )
} , {
icon : withCtx ( ( ) => [
shouldShowBadge . value ? ( openBlock ( ) , createBlock ( unref ( script$6 ) , {
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$f , [ [ "__scopeId" , "data-v-6ab4daa6" ] ] ) ;
const _sfc _main$e = /* @__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$d = /* @__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$c = /* @__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 _withScopeId$4 = /* @__PURE__ */ _ _name ( ( n ) => ( pushScopeId ( "data-v-37d8d7b4" ) , n = n ( ) , popScopeId ( ) , n ) , "_withScopeId$4" ) ;
const _hoisted _1$e = { class : "side-tool-bar-end" } ;
const _hoisted _2$b = {
key : 0 ,
class : "sidebar-content-container h-full overflow-y-auto overflow-x-hidden"
} ;
const _sfc _main$b = /* @__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$e , [
unref ( userStore ) . isMultiUserServer ? ( openBlock ( ) , createBlock ( _sfc _main$e , { key : 0 } ) ) : createCommentVNode ( "" , true ) ,
createVNode ( _sfc _main$c ) ,
createVNode ( _sfc _main$d )
] )
] , 2 )
] , 8 , [ "to" ] ) ) ,
selectedTab . value ? ( openBlock ( ) , createElementBlock ( "div" , _hoisted _2$b , [
createVNode ( _sfc _main$p , { extension : selectedTab . value } , null , 8 , [ "extension" ] )
] ) ) : createCommentVNode ( "" , true )
] , 64 ) ;
} ;
}
} ) ;
const SideToolbar = /* @__PURE__ */ _export _sfc ( _sfc _main$b , [ [ "__scopeId" , "data-v-37d8d7b4" ] ] ) ;
const CORE _SETTINGS = [
{
id : "Comfy.Validation.Workflows" ,
name : "Validate workflows" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.NodeSearchBoxImpl" ,
category : [ "Comfy" , "Node Search Box" , "Implementation" ] ,
experimental : true ,
name : "Node search box implementation" ,
type : "combo" ,
options : [ "default" , "litegraph (legacy)" ] ,
defaultValue : "default"
} ,
{
id : "Comfy.LinkRelease.Action" ,
category : [ "LiteGraph" , "LinkRelease" , "Action" ] ,
name : "Action on link release (No modifier)" ,
type : "combo" ,
options : Object . values ( LinkReleaseTriggerAction ) ,
defaultValue : LinkReleaseTriggerAction . CONTEXT _MENU
} ,
{
id : "Comfy.LinkRelease.ActionShift" ,
category : [ "LiteGraph" , "LinkRelease" , "ActionShift" ] ,
name : "Action on link release (Shift)" ,
type : "combo" ,
options : Object . values ( LinkReleaseTriggerAction ) ,
defaultValue : LinkReleaseTriggerAction . SEARCH _BOX
} ,
{
id : "Comfy.NodeSearchBoxImpl.NodePreview" ,
category : [ "Comfy" , "Node Search Box" , "NodePreview" ] ,
name : "Node preview" ,
tooltip : "Only applies to the default implementation" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.NodeSearchBoxImpl.ShowCategory" ,
category : [ "Comfy" , "Node Search Box" , "ShowCategory" ] ,
name : "Show node category in search results" ,
tooltip : "Only applies to the default implementation" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.NodeSearchBoxImpl.ShowIdName" ,
category : [ "Comfy" , "Node Search Box" , "ShowIdName" ] ,
name : "Show node id name in search results" ,
tooltip : "Only applies to the default implementation" ,
type : "boolean" ,
defaultValue : false
} ,
{
id : "Comfy.NodeSearchBoxImpl.ShowNodeFrequency" ,
category : [ "Comfy" , "Node Search Box" , "ShowNodeFrequency" ] ,
name : "Show node frequency in search results" ,
tooltip : "Only applies to the default implementation" ,
type : "boolean" ,
defaultValue : false
} ,
{
id : "Comfy.Sidebar.Location" ,
category : [ "Appearance" , "Sidebar" , "Location" ] ,
name : "Sidebar location" ,
type : "combo" ,
options : [ "left" , "right" ] ,
defaultValue : "left"
} ,
{
id : "Comfy.Sidebar.Size" ,
category : [ "Appearance" , "Sidebar" , "Size" ] ,
name : "Sidebar size" ,
type : "combo" ,
options : [ "normal" , "small" ] ,
defaultValue : /* @__PURE__ */ _ _name ( ( ) => window . innerWidth < 1600 ? "small" : "normal" , "defaultValue" )
} ,
{
id : "Comfy.TextareaWidget.FontSize" ,
category : [ "Appearance" , "Node Widget" , "TextareaWidget" , "FontSize" ] ,
name : "Textarea widget font size" ,
type : "slider" ,
defaultValue : 10 ,
attrs : {
min : 8 ,
max : 24
}
} ,
{
id : "Comfy.TextareaWidget.Spellcheck" ,
category : [ "Comfy" , "Node Widget" , "TextareaWidget" , "Spellcheck" ] ,
name : "Textarea widget spellcheck" ,
type : "boolean" ,
defaultValue : false
} ,
{
id : "Comfy.Workflow.SortNodeIdOnSave" ,
name : "Sort node IDs when saving workflow" ,
type : "boolean" ,
defaultValue : false
} ,
{
id : "Comfy.Graph.CanvasInfo" ,
category : [ "LiteGraph" , "Canvas" , "CanvasInfo" ] ,
name : "Show canvas info on bottom left corner (fps, etc.)" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.Node.ShowDeprecated" ,
name : "Show deprecated nodes in search" ,
tooltip : "Deprecated nodes are hidden by default in the UI, but remain functional in existing workflows that use them." ,
type : "boolean" ,
defaultValue : false
} ,
{
id : "Comfy.Node.ShowExperimental" ,
name : "Show experimental nodes in search" ,
tooltip : "Experimental nodes are marked as such in the UI and may be subject to significant changes or removal in future versions. Use with caution in production workflows" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.Node.Opacity" ,
category : [ "Appearance" , "Node" , "Opacity" ] ,
name : "Node opacity" ,
type : "slider" ,
defaultValue : 1 ,
attrs : {
min : 0.01 ,
max : 1 ,
step : 0.01
}
} ,
{
id : "Comfy.Workflow.ShowMissingNodesWarning" ,
name : "Show missing nodes warning" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.Workflow.ShowMissingModelsWarning" ,
name : "Show missing models warning" ,
type : "boolean" ,
defaultValue : false ,
experimental : true
} ,
{
id : "Comfy.Graph.ZoomSpeed" ,
category : [ "LiteGraph" , "Canvas" , "ZoomSpeed" ] ,
name : "Canvas zoom speed" ,
type : "slider" ,
defaultValue : 1.1 ,
attrs : {
min : 1.01 ,
max : 2.5 ,
step : 0.01
}
} ,
// Bookmarks are stored in the settings store.
// Bookmarks are in format of category/display_name. e.g. "conditioning/CLIPTextEncode"
{
id : "Comfy.NodeLibrary.Bookmarks" ,
name : "Node library bookmarks with display name (deprecated)" ,
type : "hidden" ,
defaultValue : [ ] ,
deprecated : true
} ,
{
id : "Comfy.NodeLibrary.Bookmarks.V2" ,
name : "Node library bookmarks v2 with unique name" ,
type : "hidden" ,
defaultValue : [ ]
} ,
// Stores mapping from bookmark folder name to its customization.
{
id : "Comfy.NodeLibrary.BookmarksCustomization" ,
name : "Node library bookmarks customization" ,
type : "hidden" ,
defaultValue : { }
} ,
// Hidden setting used by the queue for how to fit images
{
id : "Comfy.Queue.ImageFit" ,
name : "Queue image fit" ,
type : "hidden" ,
defaultValue : "cover"
} ,
{
id : "Comfy.GroupSelectedNodes.Padding" ,
category : [ "LiteGraph" , "Group" , "Padding" ] ,
name : "Group selected nodes padding" ,
type : "slider" ,
defaultValue : 10 ,
attrs : {
min : 0 ,
max : 100
}
} ,
{
id : "Comfy.Node.DoubleClickTitleToEdit" ,
category : [ "LiteGraph" , "Node" , "DoubleClickTitleToEdit" ] ,
name : "Double click node title to edit" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.Group.DoubleClickTitleToEdit" ,
category : [ "LiteGraph" , "Group" , "DoubleClickTitleToEdit" ] ,
name : "Double click group title to edit" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.Window.UnloadConfirmation" ,
name : "Show confirmation when closing window" ,
type : "boolean" ,
defaultValue : false
} ,
{
id : "Comfy.TreeExplorer.ItemPadding" ,
category : [ "Appearance" , "Tree Explorer" , "ItemPadding" ] ,
name : "Tree explorer item padding" ,
type : "slider" ,
defaultValue : 2 ,
attrs : {
min : 0 ,
max : 8 ,
step : 1
}
} ,
{
id : "Comfy.ModelLibrary.AutoLoadAll" ,
name : "Automatically load all model folders" ,
tooltip : "If true, all folders will load as soon as you open the model library (this may cause delays while it loads). If false, root level model folders will only load once you click on them." ,
type : "boolean" ,
defaultValue : false
} ,
{
id : "Comfy.ModelLibrary.NameFormat" ,
name : "What name to display in the model library tree view" ,
tooltip : 'Select "filename" to render a simplified view of the raw filename (without directory or ".safetensors" extension) in the model list. Select "title" to display the configurable model metadata title.' ,
type : "combo" ,
options : [ "filename" , "title" ] ,
defaultValue : "title"
} ,
{
id : "Comfy.Locale" ,
name : "Language" ,
type : "combo" ,
options : [
{ value : "en" , text : "English" } ,
{ value : "zh" , text : "中文" } ,
{ value : "ru" , text : "Русский" } ,
{ value : "ja" , text : "日本語" } ,
{ value : "ko" , text : "한국어" } ,
{ value : "fr" , text : "Français" }
] ,
defaultValue : /* @__PURE__ */ _ _name ( ( ) => navigator . language . split ( "-" ) [ 0 ] || "en" , "defaultValue" )
} ,
{
id : "Comfy.NodeBadge.NodeSourceBadgeMode" ,
category : [ "LiteGraph" , "Node" , "NodeSourceBadgeMode" ] ,
name : "Node source badge mode" ,
type : "combo" ,
options : Object . values ( NodeBadgeMode ) ,
defaultValue : NodeBadgeMode . HideBuiltIn
} ,
{
id : "Comfy.NodeBadge.NodeIdBadgeMode" ,
category : [ "LiteGraph" , "Node" , "NodeIdBadgeMode" ] ,
name : "Node ID badge mode" ,
type : "combo" ,
options : [ NodeBadgeMode . None , NodeBadgeMode . ShowAll ] ,
defaultValue : NodeBadgeMode . ShowAll
} ,
{
id : "Comfy.NodeBadge.NodeLifeCycleBadgeMode" ,
category : [ "LiteGraph" , "Node" , "NodeLifeCycleBadgeMode" ] ,
name : "Node life cycle badge mode" ,
type : "combo" ,
options : [ NodeBadgeMode . None , NodeBadgeMode . ShowAll ] ,
defaultValue : NodeBadgeMode . ShowAll
} ,
{
id : "Comfy.ConfirmClear" ,
category : [ "Comfy" , "Workflow" , "ConfirmClear" ] ,
name : "Require confirmation when clearing workflow" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.PromptFilename" ,
category : [ "Comfy" , "Workflow" , "PromptFilename" ] ,
name : "Prompt for filename when saving workflow" ,
type : "boolean" ,
defaultValue : true
} ,
/ * *
* file format for preview
*
* format ; quality
*
* ex )
* webp ; 50 - > webp , quality 50
* jpeg ; 80 - > rgb , jpeg , quality 80
*
* @ type { string }
* /
{
id : "Comfy.PreviewFormat" ,
category : [ "LiteGraph" , "Node Widget" , "PreviewFormat" ] ,
name : "Preview image format" ,
tooltip : "When displaying a preview in the image widget, convert it to a lightweight image, e.g. webp, jpeg, webp;50, etc." ,
type : "text" ,
defaultValue : ""
} ,
{
id : "Comfy.DisableSliders" ,
category : [ "LiteGraph" , "Node Widget" , "DisableSliders" ] ,
name : "Disable node widget sliders" ,
type : "boolean" ,
defaultValue : false
} ,
{
id : "Comfy.DisableFloatRounding" ,
category : [ "LiteGraph" , "Node Widget" , "DisableFloatRounding" ] ,
name : "Disable default float widget rounding." ,
tooltip : "(requires page reload) Cannot disable round when round is set by the node in the backend." ,
type : "boolean" ,
defaultValue : false
} ,
{
id : "Comfy.FloatRoundingPrecision" ,
category : [ "LiteGraph" , "Node Widget" , "FloatRoundingPrecision" ] ,
name : "Float widget rounding decimal places [0 = auto]." ,
tooltip : "(requires page reload)" ,
type : "slider" ,
attrs : {
min : 0 ,
max : 6 ,
step : 1
} ,
defaultValue : 0
} ,
{
id : "Comfy.EnableTooltips" ,
category : [ "LiteGraph" , "Node" , "EnableTooltips" ] ,
name : "Enable Tooltips" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.DevMode" ,
name : "Enable dev mode options (API save, etc.)" ,
type : "boolean" ,
defaultValue : false ,
onChange : /* @__PURE__ */ _ _name ( ( value ) => {
const element = document . getElementById ( "comfy-dev-save-api-button" ) ;
if ( element ) {
element . style . display = value ? "flex" : "none" ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "onChange" )
} ,
{
id : "Comfy.UseNewMenu" ,
category : [ "Comfy" , "Menu" , "UseNewMenu" ] ,
defaultValue : "Top" ,
name : "Use new menu" ,
type : "combo" ,
options : [ "Disabled" , "Top" , "Bottom" ] ,
migrateDeprecatedValue : /* @__PURE__ */ _ _name ( ( value ) => {
if ( value === "Floating" ) {
return "Top" ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
return value ;
} , "migrateDeprecatedValue" )
} ,
{
id : "Comfy.Workflow.WorkflowTabsPosition" ,
name : "Opened workflows position" ,
type : "combo" ,
options : [ "Sidebar" , "Topbar" ] ,
defaultValue : "Topbar"
} ,
{
id : "Comfy.Graph.CanvasMenu" ,
category : [ "LiteGraph" , "Canvas" , "CanvasMenu" ] ,
name : "Show graph canvas menu" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.QueueButton.BatchCountLimit" ,
name : "Batch count limit" ,
tooltip : "The maximum number of tasks added to the queue at one button click" ,
type : "number" ,
defaultValue : 100 ,
versionAdded : "1.3.5"
} ,
{
id : "Comfy.Keybinding.UnsetBindings" ,
name : "Keybindings unset by the user" ,
type : "hidden" ,
defaultValue : [ ] ,
versionAdded : "1.3.7"
} ,
{
id : "Comfy.Keybinding.NewBindings" ,
name : "Keybindings set by the user" ,
type : "hidden" ,
defaultValue : [ ] ,
versionAdded : "1.3.7"
} ,
{
id : "Comfy.Extension.Disabled" ,
name : "Disabled extension names" ,
type : "hidden" ,
defaultValue : [ ] ,
versionAdded : "1.3.11"
} ,
{
id : "Comfy.Validation.NodeDefs" ,
name : "Validate node definitions (slow)" ,
type : "boolean" ,
tooltip : "Recommended for node developers. This will validate all node definitions on startup." ,
defaultValue : false ,
versionAdded : "1.3.14"
} ,
{
id : "Comfy.LinkRenderMode" ,
category : [ "LiteGraph" , "Graph" , "LinkRenderMode" ] ,
name : "Link Render Mode" ,
defaultValue : 2 ,
type : "combo" ,
options : [
{ value : LiteGraph . STRAIGHT _LINK , text : "Straight" } ,
{ value : LiteGraph . LINEAR _LINK , text : "Linear" } ,
{ value : LiteGraph . SPLINE _LINK , text : "Spline" } ,
{ value : LiteGraph . HIDDEN _LINK , text : "Hidden" }
]
} ,
{
id : "Comfy.Node.AutoSnapLinkToSlot" ,
category : [ "LiteGraph" , "Node" , "AutoSnapLinkToSlot" ] ,
name : "Auto snap link to node slot" ,
tooltip : "When dragging a link over a node, the link automatically snap to a viable input slot on the node" ,
type : "boolean" ,
defaultValue : true ,
versionAdded : "1.3.29"
} ,
{
id : "Comfy.Node.SnapHighlightsNode" ,
category : [ "LiteGraph" , "Node" , "SnapHighlightsNode" ] ,
name : "Snap highlights node" ,
tooltip : "When dragging a link over a node with viable input slot, highlight the node" ,
type : "boolean" ,
defaultValue : true ,
versionAdded : "1.3.29"
} ,
{
id : "Comfy.Node.BypassAllLinksOnDelete" ,
category : [ "LiteGraph" , "Node" , "BypassAllLinksOnDelete" ] ,
name : "Keep all links when deleting nodes" ,
tooltip : "When deleting a node, attempt to reconnect all of its input and output links (bypassing the deleted node)" ,
type : "boolean" ,
defaultValue : true ,
versionAdded : "1.3.40"
} ,
{
id : "Comfy.Node.MiddleClickRerouteNode" ,
category : [ "LiteGraph" , "Node" , "MiddleClickRerouteNode" ] ,
name : "Middle-click creates a new Reroute node" ,
type : "boolean" ,
defaultValue : true ,
versionAdded : "1.3.42"
} ,
{
id : "Comfy.RerouteBeta" ,
category : [ "LiteGraph" , "RerouteBeta" ] ,
name : "Opt-in to the reroute beta test" ,
tooltip : "Enables the new native reroutes.\n\nReroutes can be added by holding alt and dragging from a link line, or on the link menu.\n\nDisabling this option is non-destructive - reroutes are hidden." ,
experimental : true ,
type : "boolean" ,
defaultValue : false ,
versionAdded : "1.3.42"
} ,
{
id : "Comfy.Graph.LinkMarkers" ,
category : [ "LiteGraph" , "Link" , "LinkMarkers" ] ,
name : "Link midpoint markers" ,
defaultValue : LinkMarkerShape . Circle ,
type : "combo" ,
options : [
{ value : LinkMarkerShape . None , text : "None" } ,
{ value : LinkMarkerShape . Circle , text : "Circle" } ,
{ value : LinkMarkerShape . Arrow , text : "Arrow" }
] ,
versionAdded : "1.3.42"
} ,
{
id : "Comfy.DOMClippingEnabled" ,
category : [ "LiteGraph" , "Node" , "DOMClippingEnabled" ] ,
name : "Enable DOM element clipping (enabling may reduce performance)" ,
type : "boolean" ,
defaultValue : true
} ,
{
id : "Comfy.Graph.CtrlShiftZoom" ,
category : [ "LiteGraph" , "Canvas" , "CtrlShiftZoom" ] ,
name : "Enable fast-zoom shortcut (Ctrl + Shift + Drag)" ,
type : "boolean" ,
defaultValue : true ,
versionAdded : "1.4.0"
} ,
{
id : "Comfy.Pointer.ClickDrift" ,
category : [ "LiteGraph" , "Pointer" , "ClickDrift" ] ,
name : "Pointer click drift (maximum distance)" ,
tooltip : "If the pointer moves more than this distance while holding a button down, it is considered dragging (rather than clicking).\n\nHelps prevent objects from being unintentionally nudged if the pointer is moved whilst clicking." ,
experimental : true ,
type : "slider" ,
attrs : {
min : 0 ,
max : 20 ,
step : 1
} ,
defaultValue : 6 ,
versionAdded : "1.4.3"
} ,
{
id : "Comfy.Pointer.ClickBufferTime" ,
category : [ "LiteGraph" , "Pointer" , "ClickBufferTime" ] ,
name : "Pointer click drift delay" ,
tooltip : "After pressing a pointer button down, this is the maximum time (in milliseconds) that pointer movement can be ignored for.\n\nHelps prevent objects from being unintentionally nudged if the pointer is moved whilst clicking." ,
experimental : true ,
type : "slider" ,
attrs : {
min : 0 ,
max : 1e3 ,
step : 25
} ,
defaultValue : 150 ,
versionAdded : "1.4.3"
} ,
{
id : "Comfy.Pointer.DoubleClickTime" ,
category : [ "LiteGraph" , "Pointer" , "DoubleClickTime" ] ,
name : "Double click interval (maximum)" ,
tooltip : "The maximum time in milliseconds between the two clicks of a double-click. Increasing this value may assist if double-clicks are sometimes not registered." ,
type : "slider" ,
attrs : {
min : 100 ,
max : 1e3 ,
step : 50
} ,
defaultValue : 300 ,
versionAdded : "1.4.3"
} ,
{
id : "Comfy.SnapToGrid.GridSize" ,
category : [ "LiteGraph" , "Canvas" , "GridSize" ] ,
name : "Snap to grid size" ,
type : "slider" ,
attrs : {
min : 1 ,
max : 500
} ,
tooltip : "When dragging and resizing nodes while holding shift they will be aligned to the grid, this controls the size of that grid." ,
defaultValue : LiteGraph . CANVAS _GRID _SIZE
} ,
// Keep the 'pysssss.SnapToGrid' setting id so we don't need to migrate setting values.
// Using a new setting id can cause existing users to lose their existing settings.
{
id : "pysssss.SnapToGrid" ,
category : [ "LiteGraph" , "Canvas" , "AlwaysSnapToGrid" ] ,
name : "Always snap to grid" ,
type : "boolean" ,
defaultValue : false ,
versionAdded : "1.3.13"
} ,
{
id : "Comfy.Server.ServerConfigValues" ,
name : "Server config values for frontend display" ,
tooltip : "Server config values used for frontend display only" ,
type : "hidden" ,
// Mapping from server config id to value.
defaultValue : { } ,
versionAdded : "1.4.8"
} ,
{
id : "Comfy.Server.LaunchArgs" ,
name : "Server launch arguments" ,
tooltip : "These are the actual arguments that are passed to the server when it is launched." ,
type : "hidden" ,
defaultValue : { } ,
versionAdded : "1.4.8"
} ,
{
id : "Comfy.Queue.MaxHistoryItems" ,
name : "Queue history size" ,
tooltip : "The maximum number of tasks that show in the queue history." ,
type : "slider" ,
attrs : {
min : 16 ,
max : 256 ,
step : 16
} ,
defaultValue : 64 ,
versionAdded : "1.4.12"
} ,
{
id : "LiteGraph.Canvas.MaximumFps" ,
name : "Maxium FPS" ,
tooltip : "The maximum frames per second that the canvas is allowed to render. Caps GPU usage at the cost of smoothness. If 0, the screen refresh rate is used. Default: 0" ,
type : "slider" ,
attrs : {
min : 0 ,
max : 120
} ,
defaultValue : 0 ,
versionAdded : "1.5.1"
} ,
{
id : "Comfy.EnableWorkflowViewRestore" ,
category : [ "Comfy" , "Workflow" , "EnableWorkflowViewRestore" ] ,
name : "Save and restore canvas position and zoom level in workflows" ,
type : "boolean" ,
defaultValue : true ,
versionModified : "1.5.4"
} ,
{
id : "Comfy.Workflow.ConfirmDelete" ,
name : "Show confirmation when deleting workflows" ,
type : "boolean" ,
defaultValue : true ,
versionAdded : "1.5.6"
} ,
{
id : "Comfy.ColorPalette" ,
name : "The active color palette id" ,
type : "hidden" ,
defaultValue : "dark" ,
versionModified : "1.6.7" ,
migrateDeprecatedValue ( value ) {
return value . startsWith ( "custom_" ) ? value . replace ( "custom_" , "" ) : value ;
}
} ,
{
id : "Comfy.CustomColorPalettes" ,
name : "Custom color palettes" ,
type : "hidden" ,
defaultValue : { } ,
versionModified : "1.6.7"
} ,
{
id : "Comfy.WidgetControlMode" ,
category : [ "Comfy" , "Node Widget" , "WidgetControlMode" ] ,
name : "Widget control mode" ,
tooltip : "Controls when widget values are updated (randomize/increment/decrement), either before the prompt is queued or after." ,
type : "combo" ,
defaultValue : "after" ,
options : [ "before" , "after" ] ,
versionModified : "1.6.10"
}
] ;
const _sfc _main$a = /* @__PURE__ */ defineComponent ( {
_ _name : "GraphCanvas" ,
emits : [ "ready" ] ,
setup ( _ _props , { emit : _ _emit } ) {
const emit = _ _emit ;
const canvasRef = ref ( null ) ;
const litegraphService = useLitegraphService ( ) ;
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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ;
watchEffect ( ( ) => {
const zoomSpeed = settingStore . get ( "Comfy.Graph.ZoomSpeed" ) ;
if ( canvasStore . canvas ) {
canvasStore . canvas . zoom _speed = zoomSpeed ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ;
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 ( ) ;
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} ) ;
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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ;
watchEffect ( ( ) => {
const reroutesEnabled = settingStore . get ( "Comfy.RerouteBeta" ) ;
const { canvas } = canvasStore ;
if ( canvas ) {
canvas . reroutesEnabled = reroutesEnabled ;
canvas . setDirty ( false , true ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ;
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" ) ;
} ) ;
watch (
( ) => settingStore . get ( "Comfy.WidgetControlMode" ) ,
( ) => {
if ( ! canvasStore . canvas ) return ;
for ( const n of app . graph . nodes ) {
if ( ! n . widgets ) continue ;
for ( const w of n . widgets ) {
if ( w [ IS _CONTROL _WIDGET ] ) {
updateControlWidgetLabel ( w ) ;
if ( w . linkedWidgets ) {
for ( const l of w . linkedWidgets ) {
updateControlWidgetLabel ( l ) ;
}
}
}
}
}
app . graph . setDirtyCanvas ( true ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
) ;
const colorPaletteService = useColorPaletteService ( ) ;
const colorPaletteStore = useColorPaletteStore ( ) ;
watch (
[ ( ) => canvasStore . canvas , ( ) => settingStore . get ( "Comfy.ColorPalette" ) ] ,
( [ canvas , currentPaletteId ] ) => {
if ( ! canvas ) return ;
colorPaletteService . loadColorPalette ( currentPaletteId ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
) ;
watch (
( ) => colorPaletteStore . activePaletteId ,
( newValue ) => {
settingStore . set ( "Comfy.ColorPalette" , newValue ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
) ;
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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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
] ) ;
litegraphService . 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 = litegraphService . 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 settingStore . loadSettingValues ( ) ;
CORE _SETTINGS . forEach ( ( setting ) => {
settingStore . addSetting ( setting ) ;
} ) ;
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 ;
colorPaletteStore . customPalettes = settingStore . get (
"Comfy.CustomColorPalettes"
) ;
watch (
( ) => settingStore . get ( "Comfy.Locale" ) ,
async ( ) => {
await useCommandStore ( ) . execute ( "Comfy.RefreshNodeDefinitions" ) ;
useWorkflowService ( ) . 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$o )
] ) ,
"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$m )
] , 64 ) ;
} ;
}
} ) ;
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$3 = /* @__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 :
} , "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$3 = {
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$3 ,
classes : classes$3 ,
inlineStyles : inlineStyles$2
} ) ;
var script$2$2 = {
name : "BaseToast" ,
"extends" : script$e ,
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$3 = {
name : "ToastMessage" ,
hostName : "Toast" ,
"extends" : script$e ,
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"
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} , 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"
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} , "onCloseClick" ) ,
clearCloseTimeout : /* @__PURE__ */ _ _name ( function clearCloseTimeout ( ) {
if ( this . closeTimeout ) {
clearTimeout ( this . closeTimeout ) ;
this . closeTimeout = null ;
}
} , "clearCloseTimeout" )
2024-10-28 18:29:38 +00:00
} ,
computed : {
2025-01-02 21:18:54 +00:00
iconComponent : /* @__PURE__ */ _ _name ( function iconComponent ( ) {
return {
info : ! this . infoIcon && script$r ,
success : ! this . successIcon && script$s ,
warn : ! this . warnIcon && script$t ,
error : ! this . errorIcon && script$u
} [ this . message . severity ] ;
} , "iconComponent" ) ,
closeAriaLabel : /* @__PURE__ */ _ _name ( function closeAriaLabel ( ) {
return this . $primevue . config . locale . aria ? this . $primevue . config . locale . aria . close : void 0 ;
} , "closeAriaLabel" )
2024-10-28 18:29:38 +00:00
} ,
components : {
2025-01-02 21:18:54 +00:00
TimesIcon : script$v ,
InfoCircleIcon : script$r ,
CheckIcon : script$s ,
ExclamationTriangleIcon : script$t ,
TimesCircleIcon : script$u
} ,
directives : {
ripple : Ripple
2024-10-28 18:29:38 +00:00
}
} ;
2025-01-02 21:18:54 +00:00
function _typeof$1 ( o ) {
2024-10-28 18:29:38 +00:00
"@babel/helpers - typeof" ;
2025-01-02 21:18:54 +00:00
return _typeof$1 = "function" == typeof Symbol && "symbol" == typeof Symbol . iterator ? function ( o2 ) {
2024-10-28 18:29:38 +00:00
return typeof o2 ;
} : function ( o2 ) {
return o2 && "function" == typeof Symbol && o2 . constructor === Symbol && o2 !== Symbol . prototype ? "symbol" : typeof o2 ;
2025-01-02 21:18:54 +00:00
} , _typeof$1 ( o ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( _typeof$1 , "_typeof$1" ) ;
function ownKeys$1 ( e , r ) {
2024-10-28 18:29:38 +00:00
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 ;
}
2025-01-02 21:18:54 +00:00
_ _name ( ownKeys$1 , "ownKeys$1" ) ;
function _objectSpread$1 ( e ) {
2024-10-28 18:29:38 +00:00
for ( var r = 1 ; r < arguments . length ; r ++ ) {
var t = null != arguments [ r ] ? arguments [ r ] : { } ;
2025-01-02 21:18:54 +00:00
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 ) {
2024-10-28 18:29:38 +00:00
Object . defineProperty ( e , r2 , Object . getOwnPropertyDescriptor ( t , r2 ) ) ;
} ) ;
}
return e ;
}
2025-01-02 21:18:54 +00:00
_ _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$d = [ "aria-label" ] ;
function render$1$2 ( _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$d ) ) , [ [ _directive _ripple ] ] ) ] , 16 ) ) : createCommentVNode ( "" , true ) ] , 16 ) ) ] , 16 ) ;
}
_ _name ( render$1$2 , "render$1$2" ) ;
script$1$3 . render = render$1$2 ;
function _toConsumableArray ( r ) {
return _arrayWithoutHoles ( r ) || _iterableToArray ( r ) || _unsupportedIterableToArray ( r ) || _nonIterableSpread ( ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _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." ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _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 ;
2024-10-28 18:29:38 +00:00
}
}
2025-01-02 21:18:54 +00:00
_ _name ( _unsupportedIterableToArray , "_unsupportedIterableToArray" ) ;
function _iterableToArray ( r ) {
if ( "undefined" != typeof Symbol && null != r [ Symbol . iterator ] || null != r [ "@@iterator" ] ) return Array . from ( r ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _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$5 = {
name : "Toast" ,
"extends" : script$2$2 ,
2024-10-28 18:29:38 +00:00
inheritAttrs : false ,
2025-01-02 21:18:54 +00:00
emits : [ "close" , "life-end" ] ,
data : /* @__PURE__ */ _ _name ( function data5 ( ) {
2024-10-28 18:29:38 +00:00
return {
2025-01-02 21:18:54 +00:00
messages : [ ]
2024-10-28 18:29:38 +00:00
} ;
} , "data" ) ,
2025-01-02 21:18:54 +00:00
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 ( ) ;
}
2024-10-28 18:29:38 +00:00
} , "mounted" ) ,
2025-01-02 21:18:54 +00:00
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" ) ,
2024-10-28 18:29:38 +00:00
methods : {
2025-01-02 21:18:54 +00:00
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"
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} , "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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "destroyStyle" )
2024-10-28 18:29:38 +00:00
} ,
computed : {
2025-01-02 21:18:54 +00:00
attributeSelector : /* @__PURE__ */ _ _name ( function attributeSelector ( ) {
return UniqueComponentId ( ) ;
} , "attributeSelector" )
2024-10-28 18:29:38 +00:00
} ,
components : {
2025-01-02 21:18:54 +00:00
ToastMessage : script$1$3 ,
Portal : script$k
2024-10-28 18:29:38 +00:00
}
} ;
2025-01-02 21:18:54 +00:00
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 , {
2024-10-28 18:29:38 +00:00
"default" : withCtx ( function ( ) {
2025-01-02 21:18:54 +00:00
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 ) ] ;
2024-10-28 18:29:38 +00:00
} ) ,
2025-01-02 21:18:54 +00:00
_ : 1
} ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( render$a , "render$a" ) ;
script$5 . render = render$a ;
const _sfc _main$9 = /* @__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$5 ) ) ;
} ;
}
} ) ;
const _hoisted _1$c = {
2024-11-16 01:17:15 +00:00
viewBox : "0 0 24 24" ,
width : "1.2em" ,
height : "1.2em"
} ;
2025-01-02 21:18:54 +00:00
const _hoisted _2$a = /* @__PURE__ */ createBaseVNode ( "path" , {
2024-11-16 01:17:15 +00:00
fill : "none" ,
stroke : "currentColor" ,
"stroke-linecap" : "round" ,
"stroke-linejoin" : "round" ,
"stroke-width" : "2" ,
d : "M6 4v16m4-16l10 8l-10 8z"
} , null , - 1 ) ;
2025-01-02 21:18:54 +00:00
const _hoisted _3$9 = [
_hoisted _2$a
2024-11-16 01:17:15 +00:00
] ;
2025-01-02 21:18:54 +00:00
function render$9 ( _ctx , _cache ) {
return openBlock ( ) , createElementBlock ( "svg" , _hoisted _1$c , [ ... _hoisted _3$9 ] ) ;
2024-11-16 01:17:15 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( render$9 , "render$9" ) ;
const _ _unplugin _components _3 = markRaw ( { name : "lucide-step-forward" , render : render$9 } ) ;
const _hoisted _1$b = {
2024-11-16 01:17:15 +00:00
viewBox : "0 0 24 24" ,
width : "1.2em" ,
height : "1.2em"
} ;
2025-01-02 21:18:54 +00:00
const _hoisted _2$9 = /* @__PURE__ */ createBaseVNode ( "path" , {
2024-11-16 01:17:15 +00:00
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 ) ;
2025-01-02 21:18:54 +00:00
const _hoisted _3$8 = [
_hoisted _2$9
2024-11-16 01:17:15 +00:00
] ;
2025-01-02 21:18:54 +00:00
function render$8 ( _ctx , _cache ) {
return openBlock ( ) , createElementBlock ( "svg" , _hoisted _1$b , [ ... _hoisted _3$8 ] ) ;
2024-11-16 01:17:15 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( render$8 , "render$8" ) ;
const _ _unplugin _components _2 = markRaw ( { name : "lucide-fast-forward" , render : render$8 } ) ;
const _hoisted _1$a = {
2024-11-16 01:17:15 +00:00
viewBox : "0 0 24 24" ,
width : "1.2em" ,
height : "1.2em"
} ;
2025-01-02 21:18:54 +00:00
const _hoisted _2$8 = /* @__PURE__ */ createBaseVNode ( "path" , {
2024-11-16 01:17:15 +00:00
fill : "none" ,
stroke : "currentColor" ,
"stroke-linecap" : "round" ,
"stroke-linejoin" : "round" ,
"stroke-width" : "2" ,
d : "m6 3l14 9l-14 9z"
} , null , - 1 ) ;
2025-01-02 21:18:54 +00:00
const _hoisted _3$7 = [
_hoisted _2$8
2024-11-16 01:17:15 +00:00
] ;
2025-01-02 21:18:54 +00:00
function render$7 ( _ctx , _cache ) {
return openBlock ( ) , createElementBlock ( "svg" , _hoisted _1$a , [ ... _hoisted _3$7 ] ) ;
2024-11-16 01:17:15 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( render$7 , "render$7" ) ;
const _ _unplugin _components _1$1 = markRaw ( { name : "lucide-play" , render : render$7 } ) ;
const _hoisted _1$9 = {
2024-10-28 18:29:38 +00:00
viewBox : "0 0 24 24" ,
width : "1.2em" ,
height : "1.2em"
} ;
2025-01-02 21:18:54 +00:00
const _hoisted _2$7 = /* @__PURE__ */ createBaseVNode ( "g" , {
2024-10-28 18:29:38 +00:00
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 ) ;
2025-01-02 21:18:54 +00:00
const _hoisted _3$6 = [
_hoisted _2$7
2024-10-28 18:29:38 +00:00
] ;
2025-01-02 21:18:54 +00:00
function render$6 ( _ctx , _cache ) {
return openBlock ( ) , createElementBlock ( "svg" , _hoisted _1$9 , [ ... _hoisted _3$6 ] ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
_ _name ( render$6 , "render$6" ) ;
const _ _unplugin _components _0$1 = markRaw ( { name : "lucide-list-start" , render : render$6 } ) ;
var theme$2 = /* @__PURE__ */ _ _name ( function theme6 ( _ref ) {
2024-10-28 18:29:38 +00:00
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" ) ;
2025-01-02 21:18:54 +00:00
var inlineStyles$1 = {
submenu : /* @__PURE__ */ _ _name ( function submenu ( _ref2 ) {
2024-10-28 18:29:38 +00:00
var instance = _ref2 . instance , processedItem = _ref2 . processedItem ;
return {
display : instance . isItemActive ( processedItem ) ? "flex" : "none"
} ;
} , "submenu" )
} ;
2025-01-02 21:18:54 +00:00
var classes$2 = {
root : /* @__PURE__ */ _ _name ( function root8 ( _ref3 ) {
2024-10-28 18:29:38 +00:00
_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" ,
2025-01-02 21:18:54 +00:00
item : /* @__PURE__ */ _ _name ( function item ( _ref4 ) {
2024-10-28 18:29:38 +00:00
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" ,
2025-01-02 21:18:54 +00:00
theme : theme$2 ,
classes : classes$2 ,
inlineStyles : inlineStyles$1
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
var script$2$1 = {
2024-10-28 18:29:38 +00:00
name : "BaseTieredMenu" ,
2025-01-02 21:18:54 +00:00
"extends" : script$e ,
2024-10-28 18:29:38 +00:00
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 ,
2025-01-02 21:18:54 +00:00
provide : /* @__PURE__ */ _ _name ( function provide10 ( ) {
2024-10-28 18:29:38 +00:00
return {
$pcTieredMenu : this ,
$parentInstance : this
} ;
} , "provide" )
} ;
2025-01-02 21:18:54 +00:00
var script$1$2 = {
2024-10-28 18:29:38 +00:00
name : "TieredMenuSub" ,
hostName : "TieredMenu" ,
2025-01-02 21:18:54 +00:00
"extends" : script$e ,
2024-10-28 18:29:38 +00:00
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 : {
2025-01-02 21:18:54 +00:00
getItemId : /* @__PURE__ */ _ _name ( function getItemId ( processedItem ) {
2024-10-28 18:29:38 +00:00
return "" . concat ( this . menuId , "_" ) . concat ( processedItem . key ) ;
} , "getItemId" ) ,
2025-01-02 21:18:54 +00:00
getItemKey : /* @__PURE__ */ _ _name ( function getItemKey ( processedItem ) {
2024-10-28 18:29:38 +00:00
return this . getItemId ( processedItem ) ;
} , "getItemKey" ) ,
2025-01-02 21:18:54 +00:00
getItemProp : /* @__PURE__ */ _ _name ( function getItemProp ( processedItem , name , params ) {
2024-10-28 18:29:38 +00:00
return processedItem && processedItem . item ? resolve ( processedItem . item [ name ] , params ) : void 0 ;
} , "getItemProp" ) ,
2025-01-02 21:18:54 +00:00
getItemLabel : /* @__PURE__ */ _ _name ( function getItemLabel ( processedItem ) {
2024-10-28 18:29:38 +00:00
return this . getItemProp ( processedItem , "label" ) ;
} , "getItemLabel" ) ,
2025-01-02 21:18:54 +00:00
getItemLabelId : /* @__PURE__ */ _ _name ( function getItemLabelId ( processedItem ) {
2024-10-28 18:29:38 +00:00
return "" . concat ( this . menuId , "_" ) . concat ( processedItem . key , "_label" ) ;
} , "getItemLabelId" ) ,
2025-01-02 21:18:54 +00:00
getPTOptions : /* @__PURE__ */ _ _name ( function getPTOptions4 ( processedItem , index , key ) {
2024-10-28 18:29:38 +00:00
return this . ptm ( key , {
context : {
item : processedItem . item ,
index ,
active : this . isItemActive ( processedItem ) ,
focused : this . isItemFocused ( processedItem ) ,
disabled : this . isItemDisabled ( processedItem )
}
} ) ;
} , "getPTOptions" ) ,
2025-01-02 21:18:54 +00:00
isItemActive : /* @__PURE__ */ _ _name ( function isItemActive ( processedItem ) {
2024-10-28 18:29:38 +00:00
return this . activeItemPath . some ( function ( path ) {
return path . key === processedItem . key ;
} ) ;
} , "isItemActive" ) ,
2025-01-02 21:18:54 +00:00
isItemVisible : /* @__PURE__ */ _ _name ( function isItemVisible ( processedItem ) {
2024-10-28 18:29:38 +00:00
return this . getItemProp ( processedItem , "visible" ) !== false ;
} , "isItemVisible" ) ,
2025-01-02 21:18:54 +00:00
isItemDisabled : /* @__PURE__ */ _ _name ( function isItemDisabled ( processedItem ) {
2024-10-28 18:29:38 +00:00
return this . getItemProp ( processedItem , "disabled" ) ;
} , "isItemDisabled" ) ,
2025-01-02 21:18:54 +00:00
isItemFocused : /* @__PURE__ */ _ _name ( function isItemFocused ( processedItem ) {
2024-10-28 18:29:38 +00:00
return this . focusedItemId === this . getItemId ( processedItem ) ;
} , "isItemFocused" ) ,
2025-01-02 21:18:54 +00:00
isItemGroup : /* @__PURE__ */ _ _name ( function isItemGroup ( processedItem ) {
2024-10-28 18:29:38 +00:00
return isNotEmpty ( processedItem . items ) ;
} , "isItemGroup" ) ,
onEnter : /* @__PURE__ */ _ _name ( function onEnter2 ( ) {
nestedPosition ( this . container , this . level ) ;
} , "onEnter" ) ,
2025-01-02 21:18:54 +00:00
onItemClick : /* @__PURE__ */ _ _name ( function onItemClick ( event , processedItem ) {
2024-10-28 18:29:38 +00:00
this . getItemProp ( processedItem , "command" , {
originalEvent : event ,
item : processedItem . item
} ) ;
this . $emit ( "item-click" , {
originalEvent : event ,
processedItem ,
isFocus : true
} ) ;
} , "onItemClick" ) ,
2025-01-02 21:18:54 +00:00
onItemMouseEnter : /* @__PURE__ */ _ _name ( function onItemMouseEnter ( event , processedItem ) {
2024-10-28 18:29:38 +00:00
this . $emit ( "item-mouseenter" , {
originalEvent : event ,
processedItem
} ) ;
} , "onItemMouseEnter" ) ,
2025-01-02 21:18:54 +00:00
onItemMouseMove : /* @__PURE__ */ _ _name ( function onItemMouseMove ( event , processedItem ) {
2024-10-28 18:29:38 +00:00
this . $emit ( "item-mousemove" , {
originalEvent : event ,
processedItem
} ) ;
} , "onItemMouseMove" ) ,
2025-01-02 21:18:54 +00:00
getAriaSetSize : /* @__PURE__ */ _ _name ( function getAriaSetSize ( ) {
2024-10-28 18:29:38 +00:00
var _this = this ;
return this . items . filter ( function ( processedItem ) {
return _this . isItemVisible ( processedItem ) && ! _this . getItemProp ( processedItem , "separator" ) ;
} ) . length ;
} , "getAriaSetSize" ) ,
2025-01-02 21:18:54 +00:00
getAriaPosInset : /* @__PURE__ */ _ _name ( function getAriaPosInset2 ( index ) {
2024-10-28 18:29:38 +00:00
var _this2 = this ;
return index - this . items . slice ( 0 , index ) . filter ( function ( processedItem ) {
return _this2 . isItemVisible ( processedItem ) && _this2 . getItemProp ( processedItem , "separator" ) ;
} ) . length + 1 ;
} , "getAriaPosInset" ) ,
2025-01-02 21:18:54 +00:00
getMenuItemProps : /* @__PURE__ */ _ _name ( function getMenuItemProps ( processedItem , index ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
containerRef : /* @__PURE__ */ _ _name ( function containerRef ( el ) {
2024-10-28 18:29:38 +00:00
this . container = el ;
} , "containerRef" )
} ,
components : {
2025-01-02 21:18:54 +00:00
AngleRightIcon : script$w
2024-10-28 18:29:38 +00:00
} ,
directives : {
ripple : Ripple
}
} ;
2025-01-02 21:18:54 +00:00
var _hoisted _1$1$2 = [ "tabindex" ] ;
var _hoisted _2$6 = [ "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$5 = [ "onClick" , "onMouseenter" , "onMousemove" ] ;
var _hoisted _4$1 = [ "href" , "target" ] ;
var _hoisted _5$1 = [ "id" ] ;
2024-10-28 18:29:38 +00:00
var _hoisted _6 = [ "id" ] ;
2024-10-29 18:14:06 +00:00
function render$1$1 ( _ctx , _cache , $props , $setup , $data , $options ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2024-10-29 18:14:06 +00:00
onClick : /* @__PURE__ */ _ _name ( function onClick2 ( $event ) {
2024-10-28 18:29:38 +00:00
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
2025-01-02 21:18:54 +00:00
} , $options . getPTOptions ( processedItem , index , "itemLabel" ) ) , toDisplayString ( $options . getItemLabel ( processedItem ) ) , 17 , _hoisted _5$1 ) , $options . getItemProp ( processedItem , "items" ) ? ( openBlock ( ) , createElementBlock ( Fragment , {
2024-10-28 18:29:38 +00:00
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
2025-01-02 21:18:54 +00:00
} , $options . getPTOptions ( processedItem , index , "submenuIcon" ) ) , null , 16 , [ "class" ] ) ) ] , 64 ) ) : createCommentVNode ( "" , true ) ] , 16 , _hoisted _4$1 ) ) , [ [ _directive _ripple ] ] ) : ( openBlock ( ) , createBlock ( resolveDynamicComponent ( $props . templates . item ) , {
2024-10-28 18:29:38 +00:00
key : 1 ,
item : processedItem . item ,
hasSubmenu : $options . getItemProp ( processedItem , "items" ) ,
label : $options . getItemLabel ( processedItem ) ,
props : $options . getMenuItemProps ( processedItem , index )
2025-01-02 21:18:54 +00:00
} , null , 8 , [ "item" , "hasSubmenu" , "label" , "props" ] ) ) ] , 16 , _hoisted _3$5 ) , $options . isItemVisible ( processedItem ) && $options . isItemGroup ( processedItem ) ? ( openBlock ( ) , createBlock ( _component _TieredMenuSub , {
2024-10-28 18:29:38 +00:00
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 ) ;
} )
2025-01-02 21:18:54 +00:00
} , null , 8 , [ "id" , "style" , "aria-labelledby" , "menuId" , "focusedItemId" , "items" , "templates" , "activeItemPath" , "level" , "visible" , "pt" , "unstyled" ] ) ) : createCommentVNode ( "" , true ) ] , 16 , _hoisted _2$6 ) ) : createCommentVNode ( "" , true ) , $options . isItemVisible ( processedItem ) && $options . getItemProp ( processedItem , "separator" ) ? ( openBlock ( ) , createElementBlock ( "li" , mergeProps ( {
2024-10-28 18:29:38 +00:00
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 ) ;
2025-01-02 21:18:54 +00:00
} ) , 128 ) ) ] , 16 , _hoisted _1$1$2 ) ) : createCommentVNode ( "" , true ) ] ;
2024-10-28 18:29:38 +00:00
} ) ,
_ : 1
} , 16 , [ "onEnter" ] ) ;
}
2024-10-29 18:14:06 +00:00
_ _name ( render$1$1 , "render$1$1" ) ;
2025-01-02 21:18:54 +00:00
script$1$2 . render = render$1$1 ;
var script$4 = {
2024-10-28 18:29:38 +00:00
name : "TieredMenu" ,
2025-01-02 21:18:54 +00:00
"extends" : script$2$1 ,
2024-10-28 18:29:38 +00:00
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 ,
2025-01-02 21:18:54 +00:00
data : /* @__PURE__ */ _ _name ( function data6 ( ) {
2024-10-28 18:29:38 +00:00
return {
id : this . $attrs . id ,
focused : false ,
focusedItemInfo : {
index : - 1 ,
level : 0 ,
parentKey : ""
} ,
activeItemPath : [ ] ,
visible : ! this . popup ,
submenuVisible : false ,
dirty : false
} ;
} , "data" ) ,
watch : {
2025-01-02 21:18:54 +00:00
"$attrs.id" : /* @__PURE__ */ _ _name ( function $attrsId2 ( newValue ) {
2024-10-28 18:29:38 +00:00
this . id = newValue || UniqueComponentId ( ) ;
} , "$attrsId" ) ,
2025-01-02 21:18:54 +00:00
activeItemPath : /* @__PURE__ */ _ _name ( function activeItemPath ( newPath ) {
2024-10-28 18:29:38 +00:00
if ( ! this . popup ) {
if ( isNotEmpty ( newPath ) ) {
this . bindOutsideClickListener ( ) ;
this . bindResizeListener ( ) ;
} else {
this . unbindOutsideClickListener ( ) ;
this . unbindResizeListener ( ) ;
}
}
} , "activeItemPath" )
} ,
2025-01-02 21:18:54 +00:00
mounted : /* @__PURE__ */ _ _name ( function mounted6 ( ) {
2024-10-28 18:29:38 +00:00
this . id = this . id || UniqueComponentId ( ) ;
} , "mounted" ) ,
2025-01-02 21:18:54 +00:00
beforeUnmount : /* @__PURE__ */ _ _name ( function beforeUnmount6 ( ) {
2024-10-28 18:29:38 +00:00
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 : {
2025-01-02 21:18:54 +00:00
getItemProp : /* @__PURE__ */ _ _name ( function getItemProp2 ( item3 , name ) {
2024-10-28 18:29:38 +00:00
return item3 ? resolve ( item3 [ name ] ) : void 0 ;
} , "getItemProp" ) ,
2025-01-02 21:18:54 +00:00
getItemLabel : /* @__PURE__ */ _ _name ( function getItemLabel2 ( item3 ) {
2024-10-28 18:29:38 +00:00
return this . getItemProp ( item3 , "label" ) ;
} , "getItemLabel" ) ,
2025-01-02 21:18:54 +00:00
isItemDisabled : /* @__PURE__ */ _ _name ( function isItemDisabled2 ( item3 ) {
2024-10-28 18:29:38 +00:00
return this . getItemProp ( item3 , "disabled" ) ;
} , "isItemDisabled" ) ,
2025-01-02 21:18:54 +00:00
isItemVisible : /* @__PURE__ */ _ _name ( function isItemVisible2 ( item3 ) {
2024-10-28 18:29:38 +00:00
return this . getItemProp ( item3 , "visible" ) !== false ;
} , "isItemVisible" ) ,
2025-01-02 21:18:54 +00:00
isItemGroup : /* @__PURE__ */ _ _name ( function isItemGroup2 ( item3 ) {
2024-10-28 18:29:38 +00:00
return isNotEmpty ( this . getItemProp ( item3 , "items" ) ) ;
} , "isItemGroup" ) ,
2025-01-02 21:18:54 +00:00
isItemSeparator : /* @__PURE__ */ _ _name ( function isItemSeparator ( item3 ) {
2024-10-28 18:29:38 +00:00
return this . getItemProp ( item3 , "separator" ) ;
} , "isItemSeparator" ) ,
2025-01-02 21:18:54 +00:00
getProccessedItemLabel : /* @__PURE__ */ _ _name ( function getProccessedItemLabel ( processedItem ) {
2024-10-28 18:29:38 +00:00
return processedItem ? this . getItemLabel ( processedItem . item ) : void 0 ;
} , "getProccessedItemLabel" ) ,
2025-01-02 21:18:54 +00:00
isProccessedItemGroup : /* @__PURE__ */ _ _name ( function isProccessedItemGroup ( processedItem ) {
2024-10-28 18:29:38 +00:00
return processedItem && isNotEmpty ( processedItem . items ) ;
} , "isProccessedItemGroup" ) ,
2025-01-02 21:18:54 +00:00
toggle : /* @__PURE__ */ _ _name ( function toggle ( event ) {
2024-10-28 18:29:38 +00:00
this . visible ? this . hide ( event , true ) : this . show ( event ) ;
} , "toggle" ) ,
2025-01-02 21:18:54 +00:00
show : /* @__PURE__ */ _ _name ( function show2 ( event , isFocus ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
hide : /* @__PURE__ */ _ _name ( function hide2 ( event , isFocus ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
onFocus : /* @__PURE__ */ _ _name ( function onFocus3 ( event ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
onBlur : /* @__PURE__ */ _ _name ( function onBlur2 ( event ) {
2024-10-28 18:29:38 +00:00
this . focused = false ;
this . focusedItemInfo = {
index : - 1 ,
level : 0 ,
parentKey : ""
} ;
this . searchValue = "" ;
this . dirty = false ;
this . $emit ( "blur" , event ) ;
} , "onBlur" ) ,
2025-01-02 21:18:54 +00:00
onKeyDown : /* @__PURE__ */ _ _name ( function onKeyDown2 ( event ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
onItemChange : /* @__PURE__ */ _ _name ( function onItemChange ( event ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
onItemClick : /* @__PURE__ */ _ _name ( function onItemClick2 ( event ) {
2024-10-28 18:29:38 +00:00
var originalEvent = event . originalEvent , processedItem = event . processedItem ;
var grouped = this . isProccessedItemGroup ( processedItem ) ;
2025-01-02 21:18:54 +00:00
var root11 = isEmpty ( processedItem . parent ) ;
2024-10-28 18:29:38 +00:00
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
} ;
2025-01-02 21:18:54 +00:00
this . dirty = ! root11 ;
2024-10-28 18:29:38 +00:00
focus ( this . menubar ) ;
} else {
if ( grouped ) {
this . onItemChange ( event ) ;
} else {
2025-01-02 21:18:54 +00:00
var rootProcessedItem = root11 ? processedItem : this . activeItemPath . find ( function ( p ) {
2024-10-28 18:29:38 +00:00
return p . parentKey === "" ;
} ) ;
this . hide ( originalEvent ) ;
this . changeFocusedItemIndex ( originalEvent , rootProcessedItem ? rootProcessedItem . index : - 1 ) ;
focus ( this . menubar ) ;
}
}
} , "onItemClick" ) ,
2025-01-02 21:18:54 +00:00
onItemMouseEnter : /* @__PURE__ */ _ _name ( function onItemMouseEnter2 ( event ) {
2024-10-28 18:29:38 +00:00
if ( this . dirty ) {
this . onItemChange ( event ) ;
}
} , "onItemMouseEnter" ) ,
2025-01-02 21:18:54 +00:00
onItemMouseMove : /* @__PURE__ */ _ _name ( function onItemMouseMove2 ( event ) {
2024-10-28 18:29:38 +00:00
if ( this . focused ) {
this . changeFocusedItemIndex ( event , event . processedItem . index ) ;
}
} , "onItemMouseMove" ) ,
2025-01-02 21:18:54 +00:00
onArrowDownKey : /* @__PURE__ */ _ _name ( function onArrowDownKey2 ( event ) {
2024-10-28 18:29:38 +00:00
var itemIndex = this . focusedItemInfo . index !== - 1 ? this . findNextItemIndex ( this . focusedItemInfo . index ) : this . findFirstFocusedItemIndex ( ) ;
this . changeFocusedItemIndex ( event , itemIndex ) ;
event . preventDefault ( ) ;
} , "onArrowDownKey" ) ,
2025-01-02 21:18:54 +00:00
onArrowUpKey : /* @__PURE__ */ _ _name ( function onArrowUpKey2 ( event ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
onArrowLeftKey : /* @__PURE__ */ _ _name ( function onArrowLeftKey3 ( event ) {
2024-10-28 18:29:38 +00:00
var _this = this ;
var processedItem = this . visibleItems [ this . focusedItemInfo . index ] ;
var parentItem = this . activeItemPath . find ( function ( p ) {
return p . key === processedItem . parentKey ;
} ) ;
2025-01-02 21:18:54 +00:00
var root11 = isEmpty ( processedItem . parent ) ;
if ( ! root11 ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
onArrowRightKey : /* @__PURE__ */ _ _name ( function onArrowRightKey3 ( event ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
onHomeKey : /* @__PURE__ */ _ _name ( function onHomeKey3 ( event ) {
2024-10-28 18:29:38 +00:00
this . changeFocusedItemIndex ( event , this . findFirstItemIndex ( ) ) ;
event . preventDefault ( ) ;
} , "onHomeKey" ) ,
2025-01-02 21:18:54 +00:00
onEndKey : /* @__PURE__ */ _ _name ( function onEndKey3 ( event ) {
2024-10-28 18:29:38 +00:00
this . changeFocusedItemIndex ( event , this . findLastItemIndex ( ) ) ;
event . preventDefault ( ) ;
} , "onEndKey" ) ,
2025-01-02 21:18:54 +00:00
onEnterKey : /* @__PURE__ */ _ _name ( function onEnterKey3 ( event ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
onSpaceKey : /* @__PURE__ */ _ _name ( function onSpaceKey ( event ) {
2024-10-28 18:29:38 +00:00
this . onEnterKey ( event ) ;
} , "onSpaceKey" ) ,
2025-01-02 21:18:54 +00:00
onEscapeKey : /* @__PURE__ */ _ _name ( function onEscapeKey2 ( event ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
onTabKey : /* @__PURE__ */ _ _name ( function onTabKey2 ( event ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
bindOutsideClickListener : /* @__PURE__ */ _ _name ( function bindOutsideClickListener2 ( ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
unbindOutsideClickListener : /* @__PURE__ */ _ _name ( function unbindOutsideClickListener2 ( ) {
2024-10-28 18:29:38 +00:00
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" ) ,
2025-01-02 21:18:54 +00:00
bindResizeListener : /* @__PURE__ */ _ _name ( function bindResizeListener2 ( ) {
2024-10-28 18:29:38 +00:00
var _this4 = this ;
if ( ! this . resizeListener ) {
this . resizeListener = function ( event ) {
if ( ! isTouchDevice ( ) ) {
_this4 . hide ( event , true ) ;
}
} ;
2025-01-02 21:18:54 +00:00
window . addEventListener ( "resize" , this . resizeListener ) ;
}
} , "bindResizeListener" ) ,
unbindResizeListener : /* @__PURE__ */ _ _name ( function unbindResizeListener2 ( ) {
if ( this . resizeListener ) {
window . removeEventListener ( "resize" , this . resizeListener ) ;
this . resizeListener = null ;
}
} , "unbindResizeListener" ) ,
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 _this5 = this ;
return this . visibleItems . findIndex ( function ( processedItem ) {
return _this5 . isValidItem ( processedItem ) ;
} ) ;
} , "findFirstItemIndex" ) ,
findLastItemIndex : /* @__PURE__ */ _ _name ( function findLastItemIndex ( ) {
var _this6 = this ;
return findLastIndex ( this . visibleItems , function ( processedItem ) {
return _this6 . isValidItem ( processedItem ) ;
} ) ;
} , "findLastItemIndex" ) ,
findNextItemIndex : /* @__PURE__ */ _ _name ( function findNextItemIndex ( 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 findPrevItemIndex ( 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 findSelectedItemIndex ( ) {
var _this9 = this ;
return this . visibleItems . findIndex ( function ( processedItem ) {
return _this9 . 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 _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 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 _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 containerRef2 ( 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 _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 focusedItemId ( ) {
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$2 ,
Portal : script$k
}
} ;
var _hoisted _1$8 = [ "id" ] ;
function render$5 ( _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$8 ) ) : createCommentVNode ( "" , true ) ] ;
} ) ,
_ : 3
} , 16 , [ "onEnter" , "onAfterEnter" , "onLeave" , "onAfterLeave" ] ) ] ;
} ) ,
_ : 3
} , 8 , [ "appendTo" , "disabled" ] ) ;
}
_ _name ( render$5 , "render$5" ) ;
script$4 . render = render$5 ;
var theme$1 = /* @__PURE__ */ _ _name ( function theme7 ( _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$1 = {
root : /* @__PURE__ */ _ _name ( function root9 ( _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 : theme$1 ,
classes : classes$1
} ) ;
var script$1$1 = {
name : "BaseSplitButton" ,
"extends" : script$e ,
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 provide11 ( ) {
return {
$pcSplitButton : this ,
$parentInstance : this
} ;
} , "provide" )
} ;
var script$3 = {
name : "SplitButton" ,
"extends" : script$1$1 ,
inheritAttrs : false ,
emits : [ "click" ] ,
inject : {
$pcFluid : {
"default" : null
}
} ,
data : /* @__PURE__ */ _ _name ( function data7 ( ) {
return {
id : this . $attrs . id ,
isExpanded : false
} ;
} , "data" ) ,
watch : {
"$attrs.id" : /* @__PURE__ */ _ _name ( function $attrsId3 ( newValue ) {
this . id = newValue || UniqueComponentId ( ) ;
} , "$attrsId" )
} ,
mounted : /* @__PURE__ */ _ _name ( function mounted7 ( ) {
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 ( ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
this . $refs . menu . toggle ( {
currentTarget : this . $el ,
relatedTarget : this . $refs . button . $el
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
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$d ,
PVSMenu : script$4 ,
ChevronDownIcon : script$l
}
} ;
var _hoisted _1$7 = [ "data-p-severity" ] ;
function render$4 ( _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$7 ) ;
}
_ _name ( render$4 , "render$4" ) ;
script$3 . render = render$4 ;
const minQueueCount = 1 ;
const _sfc _main$8 = /* @__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 = Math . min ( originalCount * 2 , maxQueueCount . value ) ;
2024-10-28 18:29:38 +00:00
} else {
2025-01-02 21:18:54 +00:00
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$x ) , {
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$8 , [ [ "__scopeId" , "data-v-b9328350" ] ] ) ;
const _withScopeId$3 = /* @__PURE__ */ _ _name ( ( n ) => ( pushScopeId ( "data-v-7f4f551b" ) , n = n ( ) , popScopeId ( ) , n ) , "_withScopeId$3" ) ;
const _hoisted _1$6 = { class : "queue-button-group flex" } ;
const _sfc _main$7 = /* @__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" )
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ) ;
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$6 , [
withDirectives ( ( openBlock ( ) , createBlock ( unref ( script$3 ) , {
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$d ) , {
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$8 ) , { class : "execution-actions flex flex-nowrap" } , {
default : withCtx ( ( ) => [
withDirectives ( createVNode ( unref ( script$d ) , {
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$d ) , {
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$7 , [ [ "__scopeId" , "data-v-7f4f551b" ] ] ) ;
const overlapThreshold = 20 ;
const _sfc _main$6 = /* @__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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
if ( storedPosition . value . x !== 0 || storedPosition . value . y !== 0 ) {
x . value = storedPosition . value . x ;
y . value = storedPosition . value . y ;
captureLastDragState ( ) ;
return ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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 ( ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "setInitialPosition" ) ;
onMounted ( setInitialPosition ) ;
watch ( visible , ( newVisible ) => {
if ( newVisible ) {
nextTick ( setInitialPosition ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ;
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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "adjustMenuPosition" ) ;
useEventListener ( window , "resize" , adjustMenuPosition ) ;
const topMenuRef = inject ( "topMenuRef" ) ;
const topMenuBounds = useElementBounding ( topMenuRef ) ;
const isOverlappingWithTopMenu = computed ( ( ) => {
if ( ! panelRef . value ) {
return false ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
} ) ;
return ( _ctx , _cache ) => {
return openBlock ( ) , createBlock ( unref ( script$y ) , {
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" ] ) ;
} ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} ) ;
const Actionbar = /* @__PURE__ */ _export _sfc ( _sfc _main$6 , [ [ "__scopeId" , "data-v-915e5456" ] ] ) ;
const _hoisted _1$5 = {
viewBox : "0 0 24 24" ,
width : "1.2em" ,
height : "1.2em"
2024-10-28 18:29:38 +00:00
} ;
2025-01-02 21:18:54 +00:00
const _hoisted _2$5 = /* @__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$4 = [
_hoisted _2$5
] ;
function render$3 ( _ctx , _cache ) {
return openBlock ( ) , createElementBlock ( "svg" , _hoisted _1$5 , [ ... _hoisted _3$4 ] ) ;
2024-10-28 18:29:38 +00:00
}
2024-10-29 18:14:06 +00:00
_ _name ( render$3 , "render$3" ) ;
2025-01-02 21:18:54 +00:00
const _ _unplugin _components _1 = markRaw ( { name : "material-symbols-dock-to-bottom-outline" , render : render$3 } ) ;
const _hoisted _1$4 = {
viewBox : "0 0 24 24" ,
width : "1.2em" ,
height : "1.2em"
} ;
const _hoisted _2$4 = /* @__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$3 = [
_hoisted _2$4
] ;
function render$2 ( _ctx , _cache ) {
return openBlock ( ) , createElementBlock ( "svg" , _hoisted _1$4 , [ ... _hoisted _3$3 ] ) ;
}
_ _name ( render$2 , "render$2" ) ;
const _ _unplugin _components _0 = markRaw ( { name : "material-symbols-dock-to-bottom" , render : render$2 } ) ;
const _sfc _main$5 = /* @__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$d ) , {
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 } ]
] ) ;
} ;
}
} ) ;
var theme8 = /* @__PURE__ */ _ _name ( function theme9 ( _ref ) {
2024-10-28 18:29:38 +00:00
var dt = _ref . dt ;
2025-01-02 21:18:54 +00:00
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 ( " men
2024-10-28 18:29:38 +00:00
} , "theme" ) ;
2025-01-02 21:18:54 +00:00
var inlineStyles = {
submenu : /* @__PURE__ */ _ _name ( function submenu2 ( _ref2 ) {
var instance = _ref2 . instance , processedItem = _ref2 . processedItem ;
return {
display : instance . isItemActive ( processedItem ) ? "flex" : "none"
} ;
} , "submenu" )
} ;
2024-10-28 18:29:38 +00:00
var classes = {
2025-01-02 21:18:54 +00:00
root : /* @__PURE__ */ _ _name ( function root10 ( _ref3 ) {
var instance = _ref3 . instance ;
return [ "p-menubar p-component" , {
"p-menubar-mobile" : instance . queryMatches ,
"p-menubar-mobile-active" : instance . mobileActive
2024-10-28 18:29:38 +00:00
} ] ;
} , "root" ) ,
2025-01-02 21:18:54 +00:00
start : "p-menubar-start" ,
button : "p-menubar-button" ,
rootList : "p-menubar-root-list" ,
item : /* @__PURE__ */ _ _name ( function item2 ( _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"
2024-10-28 18:29:38 +00:00
} ;
2025-01-02 21:18:54 +00:00
var MenubarStyle = BaseStyle . extend ( {
name : "menubar" ,
theme : theme8 ,
classes ,
inlineStyles
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
var script$2 = {
name : "BaseMenubar" ,
"extends" : script$e ,
2024-10-28 18:29:38 +00:00
props : {
model : {
type : Array ,
"default" : null
} ,
buttonProps : {
type : null ,
"default" : null
} ,
2025-01-02 21:18:54 +00:00
breakpoint : {
2024-10-28 18:29:38 +00:00
type : String ,
2025-01-02 21:18:54 +00:00
"default" : "960px"
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
ariaLabelledby : {
2024-10-28 18:29:38 +00:00
type : String ,
2025-01-02 21:18:54 +00:00
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
ariaLabel : {
2024-10-28 18:29:38 +00:00
type : String ,
"default" : null
2025-01-02 21:18:54 +00:00
}
} ,
style : MenubarStyle ,
provide : /* @__PURE__ */ _ _name ( function provide12 ( ) {
return {
$pcMenubar : this ,
$parentInstance : this
} ;
} , "provide" )
} ;
var script$1 = {
name : "MenubarSub" ,
hostName : "Menubar" ,
"extends" : script$e ,
emits : [ "item-mouseenter" , "item-click" , "item-mousemove" ] ,
props : {
items : {
type : Array ,
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
root : {
2024-10-28 18:29:38 +00:00
type : Boolean ,
"default" : false
} ,
2025-01-02 21:18:54 +00:00
popup : {
2024-10-28 18:29:38 +00:00
type : Boolean ,
"default" : false
} ,
2025-01-02 21:18:54 +00:00
mobileActive : {
2024-10-28 18:29:38 +00:00
type : Boolean ,
"default" : false
} ,
2025-01-02 21:18:54 +00:00
templates : {
type : Object ,
"default" : null
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
level : {
type : Number ,
"default" : 0
} ,
menuId : {
2024-10-28 18:29:38 +00:00
type : String ,
"default" : null
} ,
2025-01-02 21:18:54 +00:00
focusedItemId : {
type : String ,
"default" : null
} ,
activeItemPath : {
type : Object ,
"default" : null
2024-10-28 18:29:38 +00:00
}
} ,
2025-01-02 21:18:54 +00:00
list : null ,
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 ) ,
level : this . level
}
} ) ;
} , "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" ) ,
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" ) ,
getAriaPosInset : /* @__PURE__ */ _ _name ( function getAriaPosInset3 ( index ) {
return index - this . calculateAriaSetSize . slice ( 0 , index ) . 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" )
} ,
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 getAriaSetSize2 ( ) {
var _this2 = this ;
return this . items . filter ( function ( processedItem ) {
return _this2 . isItemVisible ( processedItem ) && ! _this2 . getItemProp ( processedItem , "separator" ) ;
} ) . length ;
} , "getAriaSetSize" )
} ,
components : {
AngleRightIcon : script$w ,
AngleDownIcon : script$z
} ,
directives : {
ripple : Ripple
}
2024-10-28 18:29:38 +00:00
} ;
2025-01-02 21:18:54 +00:00
var _hoisted _1$1$1 = [ "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$3 = [ "onClick" , "onMouseenter" , "onMousemove" ] ;
var _hoisted _3$2 = [ "href" , "target" ] ;
var _hoisted _4 = [ "id" ] ;
var _hoisted _5 = [ "id" ] ;
function render$1 ( _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 ) , $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$2 ) ) , [ [ _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$3 ) , $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$1 ) ) : 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 ) ) : createCommentVNode ( "" , true ) ] , 64 ) ;
} ) , 128 ) ) ] , 16 ) ;
}
_ _name ( render$1 , "render$1" ) ;
script$1 . render = render$1 ;
2024-10-28 18:29:38 +00:00
var script = {
2025-01-02 21:18:54 +00:00
name : "Menubar" ,
"extends" : script$2 ,
2024-10-28 18:29:38 +00:00
inheritAttrs : false ,
2025-01-02 21:18:54 +00:00
emits : [ "focus" , "blur" ] ,
matchMediaListener : null ,
data : /* @__PURE__ */ _ _name ( function data8 ( ) {
2024-10-28 18:29:38 +00:00
return {
id : this . $attrs . id ,
2025-01-02 21:18:54 +00:00
mobileActive : false ,
focused : false ,
focusedItemInfo : {
index : - 1 ,
level : 0 ,
parentKey : ""
} ,
activeItemPath : [ ] ,
dirty : false ,
query : null ,
queryMatches : false
2024-10-28 18:29:38 +00:00
} ;
} , "data" ) ,
watch : {
2025-01-02 21:18:54 +00:00
"$attrs.id" : /* @__PURE__ */ _ _name ( function $attrsId4 ( newValue ) {
2024-10-28 18:29:38 +00:00
this . id = newValue || UniqueComponentId ( ) ;
2025-01-02 21:18:54 +00:00
} , "$attrsId" ) ,
activeItemPath : /* @__PURE__ */ _ _name ( function activeItemPath2 ( newPath ) {
if ( isNotEmpty ( newPath ) ) {
this . bindOutsideClickListener ( ) ;
this . bindResizeListener ( ) ;
} else {
this . unbindOutsideClickListener ( ) ;
this . unbindResizeListener ( ) ;
}
} , "activeItemPath" )
2024-10-28 18:29:38 +00:00
} ,
2025-01-02 21:18:54 +00:00
outsideClickListener : null ,
container : null ,
menubar : null ,
mounted : /* @__PURE__ */ _ _name ( function mounted8 ( ) {
2024-10-28 18:29:38 +00:00
this . id = this . id || UniqueComponentId ( ) ;
2025-01-02 21:18:54 +00:00
this . bindMatchMediaListener ( ) ;
2024-10-28 18:29:38 +00:00
} , "mounted" ) ,
2025-01-02 21:18:54 +00:00
beforeUnmount : /* @__PURE__ */ _ _name ( function beforeUnmount7 ( ) {
this . mobileActive = false ;
this . unbindOutsideClickListener ( ) ;
this . unbindResizeListener ( ) ;
this . unbindMatchMediaListener ( ) ;
if ( this . container ) {
ZIndex . clear ( this . container ) ;
}
this . container = null ;
} , "beforeUnmount" ) ,
2024-10-28 18:29:38 +00:00
methods : {
2025-01-02 21:18:54 +00:00
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 toggle2 ( 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 show3 ( ) {
focus ( this . menubar ) ;
} , "show" ) ,
hide : /* @__PURE__ */ _ _name ( function hide3 ( 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 onFocus4 ( 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 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 onKeyDown3 ( 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 ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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 ;
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
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 onItemClick4 ( event ) {
var originalEvent = event . originalEvent , processedItem = event . processedItem ;
var grouped = this . isProccessedItemGroup ( processedItem ) ;
var root11 = 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 = ! root11 ;
focus ( this . menubar ) ;
} else {
if ( grouped ) {
this . onItemChange ( event ) ;
} else {
var rootProcessedItem = root11 ? 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 ) ;
}
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "onItemClick" ) ,
onItemMouseEnter : /* @__PURE__ */ _ _name ( function onItemMouseEnter4 ( event ) {
if ( this . dirty ) {
this . onItemChange ( event ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "onItemMouseEnter" ) ,
onItemMouseMove : /* @__PURE__ */ _ _name ( function onItemMouseMove4 ( 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 onArrowDownKey3 ( event ) {
var processedItem = this . visibleItems [ this . focusedItemInfo . index ] ;
var root11 = processedItem ? isEmpty ( processedItem . parent ) : null ;
if ( root11 ) {
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 onArrowUpKey3 ( event ) {
var _this3 = this ;
var processedItem = this . visibleItems [ this . focusedItemInfo . index ] ;
var root11 = isEmpty ( processedItem . parent ) ;
if ( root11 ) {
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 onArrowLeftKey4 ( 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 ( ) ;
2024-10-28 18:29:38 +00:00
} else {
2025-01-02 21:18:54 +00:00
var itemIndex = this . focusedItemInfo . index !== - 1 ? this . findPrevItemIndex ( this . focusedItemInfo . index ) : this . findLastFocusedItemIndex ( ) ;
this . changeFocusedItemIndex ( event , itemIndex ) ;
event . preventDefault ( ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "onArrowLeftKey" ) ,
onArrowRightKey : /* @__PURE__ */ _ _name ( function onArrowRightKey4 ( 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 ( ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "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 , '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 ( ) ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
event . preventDefault ( ) ;
} , "onEnterKey" ) ,
onSpaceKey : /* @__PURE__ */ _ _name ( function onSpaceKey2 ( event ) {
this . onEnterKey ( event ) ;
} , "onSpaceKey" ) ,
onEscapeKey : /* @__PURE__ */ _ _name ( function onEscapeKey3 ( 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 : ""
} ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
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
} ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
this . hide ( ) ;
} , "onTabKey" ) ,
bindOutsideClickListener : /* @__PURE__ */ _ _name ( function bindOutsideClickListener3 ( ) {
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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "bindOutsideClickListener" ) ,
unbindOutsideClickListener : /* @__PURE__ */ _ _name ( function unbindOutsideClickListener3 ( ) {
if ( this . outsideClickListener ) {
document . removeEventListener ( "click" , this . outsideClickListener ) ;
this . outsideClickListener = null ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
} , "unbindOutsideClickListener" ) ,
bindResizeListener : /* @__PURE__ */ _ _name ( function bindResizeListener3 ( ) {
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 unbindResizeListener3 ( ) {
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 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 _this8 = this ;
return this . visibleItems . findIndex ( function ( processedItem ) {
return _this8 . isValidItem ( processedItem ) ;
} ) ;
} , "findFirstItemIndex" ) ,
findLastItemIndex : /* @__PURE__ */ _ _name ( function findLastItemIndex2 ( ) {
var _this9 = this ;
return findLastIndex ( this . visibleItems , function ( processedItem ) {
return _this9 . isValidItem ( processedItem ) ;
} ) ;
} , "findLastItemIndex" ) ,
findNextItemIndex : /* @__PURE__ */ _ _name ( function findNextItemIndex2 ( 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 findPrevItemIndex2 ( 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 findSelectedItemIndex2 ( ) {
var _this12 = this ;
return this . visibleItems . findIndex ( function ( processedItem ) {
return _this12 . 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 _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 ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
if ( this . searchTimeout ) {
clearTimeout ( this . searchTimeout ) ;
2024-10-28 18:29:38 +00:00
}
2025-01-02 21:18:54 +00:00
this . searchTimeout = setTimeout ( function ( ) {
_this13 . searchValue = "" ;
_this13 . 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 _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 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 _this15 = this ;
var processedItem = this . activeItemPath . find ( function ( p ) {
return p . key === _this15 . focusedItemInfo . parentKey ;
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
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 : {
MenubarSub : script$1 ,
BarsIcon : script$A
}
} ;
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 ) ) ;
2024-10-28 18:29:38 +00:00
} ) ;
2025-01-02 21:18:54 +00:00
}
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$3 = [ "aria-haspopup" , "aria-expanded" , "aria-controls" , "aria-label" ] ;
function render ( _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$3 ) ) : 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 , "render" ) ;
script . render = render ;
const _withScopeId$2 = /* @__PURE__ */ _ _name ( ( n ) => ( pushScopeId ( "data-v-6fecd137" ) , n = n ( ) , popScopeId ( ) , n ) , "_withScopeId$2" ) ;
const _hoisted _1$2 = [ "href" ] ;
const _hoisted _2$2 = { class : "p-menubar-item-label" } ;
const _hoisted _3$1 = {
key : 1 ,
class : "ml-auto border border-surface rounded text-muted text-xs p-1 keybinding-tag"
} ;
const _sfc _main$4 = /* @__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 )
) ;
2024-10-28 18:29:38 +00:00
return ( _ctx , _cache ) => {
2025-01-02 21:18:54 +00:00
return openBlock ( ) , createBlock ( unref ( script ) , {
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"
}
2024-10-28 18:29:38 +00:00
} , {
2025-01-02 21:18:54 +00:00
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$2 , toDisplayString ( item3 . label ) , 1 ) ,
item3 ? . comfyCommand ? . keybinding ? ( openBlock ( ) , createElementBlock ( "span" , _hoisted _3$1 , toDisplayString ( item3 . comfyCommand . keybinding . combo . toString ( ) ) , 1 ) ) : createCommentVNode ( "" , true )
] , 16 , _hoisted _1$2 )
2024-10-28 18:29:38 +00:00
] ) ,
_ : 1
2025-01-02 21:18:54 +00:00
} , 8 , [ "model" , "pt" ] ) ;
2024-10-28 18:29:38 +00:00
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
const CommandMenubar = /* @__PURE__ */ _export _sfc ( _sfc _main$4 , [ [ "__scopeId" , "data-v-6fecd137" ] ] ) ;
const _withScopeId$1 = /* @__PURE__ */ _ _name ( ( n ) => ( pushScopeId ( "data-v-8d011a31" ) , n = n ( ) , popScopeId ( ) , n ) , "_withScopeId$1" ) ;
const _hoisted _1$1 = { class : "workflow-label text-sm max-w-[150px] truncate inline-block" } ;
const _hoisted _2$1 = { class : "relative" } ;
const _hoisted _3 = {
key : 0 ,
class : "status-indicator"
2024-10-29 18:14:06 +00:00
} ;
2025-01-02 21:18:54 +00:00
const _sfc _main$3 = /* @__PURE__ */ defineComponent ( {
_ _name : "WorkflowTab" ,
props : {
class : { } ,
workflowOption : { }
} ,
2024-10-29 18:14:06 +00:00
setup ( _ _props ) {
2025-01-02 21:18:54 +00:00
const props = _ _props ;
const workspaceStore = useWorkspaceStore ( ) ;
const workflowStore = useWorkflowStore ( ) ;
const workflowTabRef = ref ( null ) ;
const closeWorkflows = /* @__PURE__ */ _ _name ( async ( options ) => {
for ( const opt of options ) {
if ( ! await useWorkflowService ( ) . closeWorkflow ( opt . workflow , {
warnIfUnsaved : ! workspaceStore . shiftDown
} ) ) {
break ;
}
}
} , "closeWorkflows" ) ;
const onCloseWorkflow = /* @__PURE__ */ _ _name ( ( option2 ) => {
closeWorkflows ( [ option2 ] ) ;
} , "onCloseWorkflow" ) ;
const tabGetter = /* @__PURE__ */ _ _name ( ( ) => workflowTabRef . value , "tabGetter" ) ;
usePragmaticDraggable ( tabGetter , {
getInitialData : /* @__PURE__ */ _ _name ( ( ) => {
return {
workflowKey : props . workflowOption . workflow . key
} ;
} , "getInitialData" )
} ) ;
usePragmaticDroppable ( tabGetter , {
getData : /* @__PURE__ */ _ _name ( ( ) => {
return {
workflowKey : props . workflowOption . workflow . key
} ;
} , "getData" ) ,
onDrop : /* @__PURE__ */ _ _name ( ( e ) => {
const fromIndex = workflowStore . openWorkflows . findIndex (
( wf ) => wf . key === e . source . data . workflowKey
) ;
const toIndex = workflowStore . openWorkflows . findIndex (
( wf ) => wf . key === e . location . current . dropTargets [ 0 ] ? . data . workflowKey
) ;
if ( fromIndex !== toIndex ) {
workflowStore . reorderWorkflows ( fromIndex , toIndex ) ;
}
} , "onDrop" )
} ) ;
2024-10-29 18:14:06 +00:00
return ( _ctx , _cache ) => {
const _directive _tooltip = resolveDirective ( "tooltip" ) ;
2025-01-02 21:18:54 +00:00
return openBlock ( ) , createElementBlock ( "div" , mergeProps ( {
class : "flex p-2 gap-2 workflow-tab" ,
ref _key : "workflowTabRef" ,
ref : workflowTabRef
} , _ctx . $attrs ) , [
withDirectives ( ( openBlock ( ) , createElementBlock ( "span" , _hoisted _1$1 , [
createTextVNode ( toDisplayString ( _ctx . workflowOption . workflow . filename ) , 1 )
] ) ) , [
[
_directive _tooltip ,
_ctx . workflowOption . workflow . key ,
void 0 ,
{ bottom : true }
]
2024-10-29 18:14:06 +00:00
] ) ,
2025-01-02 21:18:54 +00:00
createBaseVNode ( "div" , _hoisted _2$1 , [
! unref ( workspaceStore ) . shiftDown && ( _ctx . workflowOption . workflow . isModified || ! _ctx . workflowOption . workflow . isPersisted ) ? ( openBlock ( ) , createElementBlock ( "span" , _hoisted _3 , "•" ) ) : createCommentVNode ( "" , true ) ,
createVNode ( unref ( script$d ) , {
class : "close-button p-0 w-auto" ,
icon : "pi pi-times" ,
text : "" ,
severity : "secondary" ,
size : "small" ,
onClick : _cache [ 0 ] || ( _cache [ 0 ] = withModifiers ( ( $event ) => onCloseWorkflow ( _ctx . workflowOption ) , [ "stop" ] ) )
} )
] )
] , 16 ) ;
} ;
}
} ) ;
const WorkflowTab = /* @__PURE__ */ _export _sfc ( _sfc _main$3 , [ [ "__scopeId" , "data-v-8d011a31" ] ] ) ;
const _sfc _main$2 = /* @__PURE__ */ defineComponent ( {
_ _name : "WorkflowTabs" ,
props : {
class : { }
} ,
setup ( _ _props ) {
const props = _ _props ;
const { t } = useI18n ( ) ;
const workspaceStore = useWorkspaceStore ( ) ;
const workflowStore = useWorkflowStore ( ) ;
const workflowService = useWorkflowService ( ) ;
const rightClickedTab = ref ( null ) ;
const menu = ref ( ) ;
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 showContextMenu = /* @__PURE__ */ _ _name ( ( event , option2 ) => {
rightClickedTab . value = option2 ;
menu . value . show ( event ) ;
} , "showContextMenu" ) ;
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 ) => {
return openBlock ( ) , createElementBlock ( Fragment , null , [
createVNode ( unref ( script$B ) , {
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 } ) => [
createVNode ( WorkflowTab , {
onContextmenu : /* @__PURE__ */ _ _name ( ( $event ) => showContextMenu ( $event , option2 ) , "onContextmenu" ) ,
onMouseup : withModifiers ( ( $event ) => onCloseWorkflow ( option2 ) , [ "middle" ] ) ,
"workflow-option" : option2
} , null , 8 , [ "onContextmenu" , "onMouseup" , "workflow-option" ] )
] ) ,
_ : 1
} , 8 , [ "class" , "modelValue" , "options" ] ) ,
createVNode ( unref ( script$d ) , {
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$C ) , {
ref _key : "menu" ,
ref : menu ,
model : contextMenuItems . value
} , null , 8 , [ "model" ] )
] , 64 ) ;
2024-10-29 18:14:06 +00:00
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
const WorkflowTabs = /* @__PURE__ */ _export _sfc ( _sfc _main$2 , [ [ "__scopeId" , "data-v-d485c044" ] ] ) ;
const _withScopeId = /* @__PURE__ */ _ _name ( ( n ) => ( pushScopeId ( "data-v-878b63b8" ) , n = n ( ) , popScopeId ( ) , n ) , "_withScopeId" ) ;
2024-10-28 18:29:38 +00:00
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 ) {
2024-11-16 01:17:15 +00:00
const workspaceState = useWorkspaceStore ( ) ;
2024-10-28 18:29:38 +00:00
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 ) => {
2024-11-16 01:17:15 +00:00
const _directive _tooltip = resolveDirective ( "tooltip" ) ;
2024-10-28 18:29:38 +00:00
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 ) ,
2025-01-02 21:18:54 +00:00
createVNode ( unref ( script$D ) , {
2024-10-28 18:29:38 +00:00
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 ) ,
2024-10-29 18:14:06 +00:00
createVNode ( Actionbar ) ,
2025-01-02 21:18:54 +00:00
createVNode ( _sfc _main$5 ) ,
withDirectives ( createVNode ( unref ( script$d ) , {
2024-11-16 01:17:15 +00:00
icon : "pi pi-bars" ,
severity : "secondary" ,
text : "" ,
2024-12-16 19:38:24 +00:00
onClick : _cache [ 0 ] || ( _cache [ 0 ] = ( $event ) => unref ( workspaceState ) . focusMode = true ) ,
onContextmenu : unref ( showNativeMenu )
} , null , 8 , [ "onContextmenu" ] ) , [
2024-11-16 01:17:15 +00:00
[ _directive _tooltip , { value : _ctx . $t ( "menu.hideMenu" ) , showDelay : 300 } ]
] )
2024-10-28 18:29:38 +00:00
] , 2 ) , [
2024-11-16 01:17:15 +00:00
[ vShow , betaMenuEnabled . value && ! unref ( workspaceState ) . focusMode ]
2024-10-28 18:29:38 +00:00
] )
] , 8 , [ "to" ] ) ;
} ;
}
} ) ;
2025-01-02 21:18:54 +00:00
const TopMenubar = /* @__PURE__ */ _export _sfc ( _sfc _main$1 , [ [ "__scopeId" , "data-v-878b63b8" ] ] ) ;
2024-11-28 09:59:06 +00:00
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 = [
2024-12-16 19:38:24 +00:00
// 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
2024-11-28 09:59:06 +00:00
{
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" ,
2024-12-16 19:38:24 +00:00
// The default launch port for desktop app is 8000 instead of 8188.
defaultValue : 8e3
} ,
2024-11-28 09:59:06 +00:00
{
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" ,
2024-12-16 19:38:24 +00:00
name : "Disable smart memory management" ,
tooltip : "Force ComfyUI to aggressively offload to regular ram instead of keeping models in vram when it can." ,
2024-11-28 09:59:06 +00:00
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" )
2024-12-16 19:38:24 +00:00
} ,
// Directories
{
id : "input-directory" ,
name : "Input directory" ,
category : [ "Directories" ] ,
type : "text" ,
defaultValue : ""
} ,
{
id : "output-directory" ,
name : "Output directory" ,
category : [ "Directories" ] ,
type : "text" ,
defaultValue : ""
2024-11-28 09:59:06 +00:00
}
] ;
2024-12-16 19:38:24 +00:00
function useCoreCommands ( ) {
2025-01-02 21:18:54 +00:00
const workflowService = useWorkflowService ( ) ;
const dialogService = useDialogService ( ) ;
2024-12-16 19:38:24 +00:00
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" ,
2025-01-02 21:18:54 +00:00
function : /* @__PURE__ */ _ _name ( ( ) => {
dialogService . showTemplateWorkflowsDialog ( ) ;
} , "function" )
2024-12-16 19:38:24 +00:00
} ,
{
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 ( ( ) => {
2025-01-02 21:18:54 +00:00
dialogService . showSettingsDialog ( ) ;
2024-12-16 19:38:24 +00:00
} , "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" )
2025-01-02 21:18:54 +00:00
} ,
{
id : "Comfy.Help.AboutComfyUI" ,
icon : "pi pi-info-circle" ,
label : "Open About ComfyUI" ,
menubarLabel : "About ComfyUI" ,
versionAdded : "1.6.4" ,
function : /* @__PURE__ */ _ _name ( ( ) => {
dialogService . showSettingsDialog ( "about" ) ;
} , "function" )
2024-12-16 19:38:24 +00:00
}
] ;
}
_ _name ( useCoreCommands , "useCoreCommands" ) ;
2025-01-02 21:18:54 +00:00
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" ) ;
2024-10-28 18:29:38 +00:00
const _sfc _main = /* @__PURE__ */ defineComponent ( {
_ _name : "GraphView" ,
setup ( _ _props ) {
setupAutoQueueHandler ( ) ;
const { t } = useI18n ( ) ;
const toast = useToast ( ) ;
const settingStore = useSettingStore ( ) ;
const executionStore = useExecutionStore ( ) ;
2025-01-02 21:18:54 +00:00
const theme10 = computed ( ( ) => settingStore . get ( "Comfy.ColorPalette" ) ) ;
2024-10-28 18:29:38 +00:00
watch (
2025-01-02 21:18:54 +00:00
theme10 ,
2024-10-28 18:29:38 +00:00
( 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" ) {
2025-01-02 21:18:54 +00:00
app . ui . menuContainer . style . setProperty ( "display" , "block" ) ;
2024-10-28 18:29:38 +00:00
app . ui . restoreMenuPosition ( ) ;
} else {
app . ui . menuContainer . style . setProperty ( "display" , "none" ) ;
}
} ) ;
2024-11-28 09:59:06 +00:00
watchEffect ( ( ) => {
useQueueStore ( ) . maxHistoryItems = settingStore . get (
"Comfy.Queue.MaxHistoryItems"
) ;
} ) ;
2024-10-28 18:29:38 +00:00
const init = /* @__PURE__ */ _ _name ( ( ) => {
2024-12-16 19:38:24 +00:00
const coreCommands = useCoreCommands ( ) ;
useCommandStore ( ) . registerCommands ( coreCommands ) ;
useMenuItemStore ( ) . registerCoreMenuCommands ( ) ;
2025-01-02 21:18:54 +00:00
useKeybindingService ( ) . registerCoreKeybindings ( ) ;
2024-10-28 18:29:38 +00:00
useSidebarTabStore ( ) . registerCoreSidebarTabs ( ) ;
2024-10-29 18:14:06 +00:00
useBottomPanelStore ( ) . registerCoreBottomPanelTabs ( ) ;
2024-10-28 18:29:38 +00:00
app . extensionManager = useWorkspaceStore ( ) ;
} , "init" ) ;
const queuePendingTaskCountStore = useQueuePendingTaskCountStore ( ) ;
const onStatus = /* @__PURE__ */ _ _name ( ( e ) => {
queuePendingTaskCountStore . update ( e ) ;
} , "onStatus" ) ;
const reconnectingMessage = {
severity : "error" ,
2024-12-16 19:38:24 +00:00
summary : t ( "g.reconnecting" )
2024-10-28 18:29:38 +00:00
} ;
const onReconnecting = /* @__PURE__ */ _ _name ( ( ) => {
toast . remove ( reconnectingMessage ) ;
toast . add ( reconnectingMessage ) ;
} , "onReconnecting" ) ;
const onReconnected = /* @__PURE__ */ _ _name ( ( ) => {
toast . remove ( reconnectingMessage ) ;
toast . add ( {
severity : "success" ,
2024-12-16 19:38:24 +00:00
summary : t ( "g.reconnected" ) ,
2024-10-28 18:29:38 +00:00
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 ( ) ;
} ) ;
2025-01-02 21:18:54 +00:00
useEventListener ( window , "keydown" , useKeybindingService ( ) . keybindHandler ) ;
2024-10-28 18:29:38 +00:00
const onGraphReady = /* @__PURE__ */ _ _name ( ( ) => {
requestIdleCallback (
( ) => {
2025-01-02 21:18:54 +00:00
useKeybindingService ( ) . registerUserKeybindings ( ) ;
2024-11-28 09:59:06 +00:00
useServerConfigStore ( ) . loadServerConfig (
SERVER _CONFIG _ITEMS ,
settingStore . get ( "Comfy.Server.ServerConfigValues" )
) ;
2024-11-16 01:17:15 +00:00
useModelStore ( ) . loadModelFolders ( ) ;
2024-10-28 18:29:38 +00:00
useNodeDefStore ( ) . nodeSearchService . endsWithFilterStartSequence ( "" ) ;
useNodeFrequencyStore ( ) . loadNodeFrequencies ( ) ;
} ,
{ timeout : 1e3 }
) ;
} , "onGraphReady" ) ;
return ( _ctx , _cache ) => {
return openBlock ( ) , createElementBlock ( Fragment , null , [
createVNode ( TopMenubar ) ,
2025-01-02 21:18:54 +00:00
createVNode ( _sfc _main$a , { onReady : onGraphReady } ) ,
2024-10-28 18:29:38 +00:00
createVNode ( _sfc _main$9 ) ,
2025-01-02 21:18:54 +00:00
createVNode ( _sfc _main$r ) ,
createVNode ( _sfc _main$t ) ,
2024-11-16 01:17:15 +00:00
createVNode ( MenuHamburger )
2024-10-28 18:29:38 +00:00
] , 64 ) ;
} ;
}
} ) ;
export {
_sfc _main as default
} ;
2025-01-02 21:18:54 +00:00
//# sourceMappingURL=GraphView-BxwJvm2y.js.map