Skip to content

Commit

Permalink
feat(FilePickerBuilder): Allow to configure the dialog container element
Browse files Browse the repository at this point in the history
Signed-off-by: Ferdinand Thiessen <opensource@fthiessen.de>
  • Loading branch information
susnux committed Aug 25, 2023
1 parent b6ad9c0 commit f6ce7c1
Showing 1 changed file with 24 additions and 5 deletions.
29 changes: 24 additions & 5 deletions lib/filepicker.ts
Original file line number Diff line number Diff line change
Expand Up @@ -51,21 +51,24 @@ export class FilePicker<IsMultiSelect extends boolean> {
private buttons: IFilePickerButton[] | IFilePickerButtonFactory
private path?: string
private filter?: IFilePickerFilter
private container?: string

public constructor(title: string,
multiSelect: IsMultiSelect,
mimeTypeFilter: string[],
directoriesAllowed: boolean,
buttons: IFilePickerButton[] | IFilePickerButtonFactory,
path?: string,
filter?: IFilePickerFilter) {
filter?: IFilePickerFilter,
container?: string) {
this.title = title
this.multiSelect = multiSelect
this.mimeTypeFilter = mimeTypeFilter
this.directoriesAllowed = directoriesAllowed
this.path = path
this.filter = filter
this.buttons = buttons
this.container = container
}

/**
Expand All @@ -78,17 +81,21 @@ export class FilePicker<IsMultiSelect extends boolean> {
spawnDialog(FilePickerVue, {
allowPickDirectory: this.directoriesAllowed,
buttons: this.buttons,
container: this.container,
name: this.title,
path: this.path,
mimetypeFilter: this.mimeTypeFilter,
multiselect: this.multiSelect,
filterFn: this.filter,
}, (...nodes: unknown[]) => {
if (!nodes) reject(new Error('Nothing selected'))
if (this.multiSelect) {
resolve((nodes as Node[]).map((node) => node.path) as (IsMultiSelect extends true ? string[] : string))
if (!nodes) {
reject(new Error('Nothing selected'))
} else {
resolve(((nodes as Node[])[0]?.path || '/') as (IsMultiSelect extends true ? string[] : string))
if (this.multiSelect) {
resolve((nodes as Node[]).map((node) => node.path) as (IsMultiSelect extends true ? string[] : string))
} else {
resolve(((nodes as Node[])[0]?.path || '/') as (IsMultiSelect extends true ? string[] : string))
}
}
})
})
Expand All @@ -105,6 +112,7 @@ export class FilePickerBuilder<IsMultiSelect extends boolean> {
private path?: string
private filter?: IFilePickerFilter
private buttons: IFilePickerButton[] | IFilePickerButtonFactory = []
private container?: string

/**
* Construct a new FilePicker
Expand All @@ -115,6 +123,17 @@ export class FilePickerBuilder<IsMultiSelect extends boolean> {
this.title = title
}

/**
* Set the container where the FilePicker will be mounted
* By default 'body' is used
*
* @param container The dialog container
*/
public setContainer(container: string) {
this.container = container
return this
}

/**
* Enable or disable picking multiple files
*
Expand Down

0 comments on commit f6ce7c1

Please sign in to comment.