Files
ComfyUI_frontend/src/composables/node/useNodeFileInput.ts

46 lines
1.1 KiB
TypeScript

import type { LGraphNode } from '@comfyorg/litegraph'
import { useChainCallback } from '@/composables/functional/useChainCallback'
interface FileInputOptions {
accept?: string
allow_batch?: boolean
fileFilter?: (file: File) => boolean
onSelect: (files: File[]) => void
}
/**
* Creates a file input for a node.
*/
export function useNodeFileInput(node: LGraphNode, options: FileInputOptions) {
const {
accept,
allow_batch = false,
fileFilter = () => true,
onSelect
} = options
let fileInput: HTMLInputElement | null = document.createElement('input')
fileInput.type = 'file'
fileInput.accept = accept ?? '*'
fileInput.multiple = allow_batch
fileInput.onchange = () => {
if (fileInput?.files?.length) {
const files = Array.from(fileInput.files).filter(fileFilter)
if (files.length) onSelect(files)
}
}
node.onRemoved = useChainCallback(node.onRemoved, () => {
if (fileInput) {
fileInput.onchange = null
fileInput = null
}
})
return {
openFileSelection: () => fileInput?.click()
}
}