-
-
Notifications
You must be signed in to change notification settings - Fork 26
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support multiple plugins for same root classname #50
Comments
Hmm that's a great idea. Never considered more than one plugin How do you think it could handle potential conflicts though? For example your drag and drop plugin would it also want to update the file name label or would you leave that to the current file plugin to detect the change event, as it currently does? Your example doesn't seem to exist. I would appreciate a pull request, would help see what the changes are you propose. |
Bulma If attach multi plugins to same class name and same event, it are called in order. Example: class FileDragDrop {
/**
* Plugin constructor
* @param {Object} options The options object for this plugin
* @return {this} The newly created plugin instance
*/
constructor(options) {
if(!options.element) {
throw new Error('[BulmaJS] The file component requires an element to function.');
}
/**
* The root file element.
* @type {HTMLElement}
*/
this.root = options.element;
/**
* The element to file input.
* @type {HTMLELement}
*/
this.input = this.root.querySelector('input');
this.registerEvents();
}
/**
* Register all the events this module needs.
* @return {undefined}
*/
registerEvents() {
// add hovered class name
this.root.addEventListener('dragover', (e) => {
e.preventDefault();
this.root.classList.add('is-hovered');
});
// remove hovered class name
this.root.addEventListener('dragleave', (e) => {
e.preventDefault();
this.root.classList.remove('is-hovered');
});
// remove hovered class name and set dragged file
this.root.addEventListener('drop', (e) => {
e.preventDefault();
this.root.classList.remove('is-hovered');
this.input.files = e.dataTransfer.files;
});
}
/**
* Handle parsing the DOMs data attribute API.
* @param {HTMLElement} element The root element for this plugin
* @return {undefined}
*/
static handleDomParsing(element) {
new FileDragDrop({
element: element
});
}
static getRootClass() {
return 'file';
}
}
Bulma.registerPlugin('file-drag-drop', FileDragDrop);
export default FileDragDrop; |
Looking at your code all I see is the hover class being applied to the file element when dragging and the files property being set to the event dragged files. Is this correct or am I missing something? If this is correct then I actually think this could be implemented into the core file plugin, rather than being it's own plugin. I'm assuming this doesn't reply on any third party library. If you would like to create a PR adding this to the core file plugin I'll be more than happy to merge it in. |
You are right. I think so too. |
Is your feature request related to a problem? Please describe.
Current plugin loading calls only first registered plugin by same root class name.
I try to create [file drag and drop plugin] using
.file
class name but it has not called fromcore.js::traverseDOM()
when using file.js together.Describe the solution you'd like
Return target plugins array from
core.js::findCompatiblePlugin()
.Describe alternatives you've considered
How about this?
master...apecell:feature/multi-plugins
Thanks 👍
The text was updated successfully, but these errors were encountered: