mirror of
https://github.com/fluxscape/fluxscape.git
synced 2026-01-13 07:42:54 +01:00
Initial commit
Co-Authored-By: Eric Tuvesson <eric.tuvesson@gmail.com> Co-Authored-By: mikaeltellhed <2311083+mikaeltellhed@users.noreply.github.com> Co-Authored-By: kotte <14197736+mrtamagotchi@users.noreply.github.com> Co-Authored-By: Anders Larsson <64838990+anders-topp@users.noreply.github.com> Co-Authored-By: Johan <4934465+joolsus@users.noreply.github.com> Co-Authored-By: Tore Knudsen <18231882+torekndsn@users.noreply.github.com> Co-Authored-By: victoratndl <99176179+victoratndl@users.noreply.github.com>
This commit is contained in:
@@ -0,0 +1,110 @@
|
||||
'use strict';
|
||||
|
||||
const OpenFilePicker = {
|
||||
name: 'Open File Picker',
|
||||
docs: 'https://docs.noodl.net/nodes/utilities/open-file-picker',
|
||||
category: 'Utilities',
|
||||
getInspectInfo() {
|
||||
if (this._internal.file) {
|
||||
return this._internal.file.path;
|
||||
}
|
||||
},
|
||||
initialize() {
|
||||
//for some reason the input element has to be created here, it doesn't
|
||||
//work predictably in Safari when created in the open signal function.
|
||||
//Creating it here and reusing it seems to work correctly in all browsers.
|
||||
const input = document.createElement('input');
|
||||
input.type = 'file';
|
||||
|
||||
this._internal.inputElement = input;
|
||||
},
|
||||
inputs: {
|
||||
open: {
|
||||
type: 'signal',
|
||||
displayName: 'Open',
|
||||
group: 'Actions',
|
||||
valueChangedToTrue() {
|
||||
const input = this._internal.inputElement;
|
||||
|
||||
const onChange = (e) => {
|
||||
this._internal.file = e.target.files[0];
|
||||
|
||||
this.flagOutputDirty('file');
|
||||
this.flagOutputDirty('path');
|
||||
this.flagOutputDirty('name');
|
||||
this.flagOutputDirty('sizeInBytes');
|
||||
this.flagOutputDirty('type');
|
||||
|
||||
this.sendSignalOnOutput('success');
|
||||
|
||||
input.onchange = null;
|
||||
input.value = ''; //reset value so the same file can be picked again
|
||||
};
|
||||
|
||||
input.accept = this._internal.acceptedFileTypes;
|
||||
|
||||
input.onchange = onChange;
|
||||
input.click();
|
||||
}
|
||||
},
|
||||
acceptedFileTypes: {
|
||||
group: 'General',
|
||||
type: 'string',
|
||||
displayName: 'Accepted file types',
|
||||
set(value) {
|
||||
this._internal.acceptedFileTypes = value;
|
||||
}
|
||||
}
|
||||
},
|
||||
outputs: {
|
||||
file: {
|
||||
type: '*',
|
||||
displayName: 'File',
|
||||
group: 'General',
|
||||
get() {
|
||||
return this._internal.file;
|
||||
}
|
||||
},
|
||||
path: {
|
||||
displayName: 'Path',
|
||||
group: 'Metadata',
|
||||
type: 'string',
|
||||
get() {
|
||||
return this._internal.file && this._internal.file.path;
|
||||
}
|
||||
},
|
||||
name: {
|
||||
displayName: 'Name',
|
||||
group: 'Metadata',
|
||||
type: 'string',
|
||||
get() {
|
||||
return this._internal.file && this._internal.file.name;
|
||||
}
|
||||
},
|
||||
sizeInBytes: {
|
||||
displayName: 'Size in bytes',
|
||||
group: 'Metadata',
|
||||
type: 'number',
|
||||
get() {
|
||||
return this._internal.file && this._internal.file.size;
|
||||
}
|
||||
},
|
||||
type: {
|
||||
displayName: 'Type',
|
||||
group: 'Metadata',
|
||||
type: 'string',
|
||||
get() {
|
||||
return this._internal.file && this._internal.file.type;
|
||||
}
|
||||
},
|
||||
success: {
|
||||
type: 'signal',
|
||||
group: 'Events',
|
||||
displayName: 'Success'
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
module.exports = {
|
||||
node: OpenFilePicker
|
||||
};
|
||||
Reference in New Issue
Block a user