Sha256: 6460e1c18f064abe7e81e15d08712b547dbc29691ea60216656767bf11abc064
Contents?: true
Size: 1.59 KB
Versions: 2
Compression:
Stored size: 1.59 KB
Contents
import { Application } from "stimulus" const application = Application.start() const { controllerAttribute } = application.schema const registeredControllers = {} function autoloadControllersWithin(element) { queryControllerNamesWithin(element).forEach(loadController) } function queryControllerNamesWithin(element) { return Array.from(element.querySelectorAll(`[${controllerAttribute}]`)).map(extractControllerNamesFrom).flat() } function extractControllerNamesFrom(element) { return element.getAttribute(controllerAttribute).split(/\s+/).filter(content => content.length) } function loadController(name) { import(controllerFilename(name)) .then(module => registerController(name, module)) .catch(error => console.log(`Failed to autoload controller: ${name}`, error)) } function controllerFilename(name) { return `${name.replace(/--/g, "/").replace(/-/g, "_")}_controller` } function registerController(name, module) { if (name in registeredControllers) return application.register(name, module.default) registeredControllers[name] = true } new MutationObserver((mutationsList) => { for (const { attributeName, target, type } of mutationsList) { switch (type) { case "attributes": { if (attributeName == controllerAttribute && target.getAttribute(controllerAttribute)) { extractControllerNamesFrom(target).forEach(loadController) } } case "childList": { autoloadControllersWithin(target) } } } }).observe(document, { attributeFilter: [controllerAttribute], subtree: true, childList: true }) autoloadControllersWithin(document)
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
stimulus-rails-0.2.4 | app/assets/javascripts/stimulus/loaders/autoloader.js |
stimulus-rails-0.2.3 | app/assets/javascripts/stimulus/loaders/autoloader.js |