Cambio en logica de registro automatico de componentes

This commit is contained in:
Alejandro Tasistro 2024-08-30 01:13:06 -03:00
parent 11d18ad4a5
commit 5453b1158f
2 changed files with 24 additions and 3 deletions

5
resources/js/app.js vendored
View File

@ -4,7 +4,6 @@
* building robust, powerful web applications using Vue and Laravel. * building robust, powerful web applications using Vue and Laravel.
*/ */
import axios from 'axios'; import axios from 'axios';
import animate from 'animate.css';
import Vue from 'vue'; import Vue from 'vue';
window.Vue = require('vue'); window.Vue = require('vue');
window.Event = new Vue(); window.Event = new Vue();
@ -18,8 +17,8 @@ window.bulmaToast = require('bulma-toast');
* *
* Eg. ./components/ExampleComponent.vue -> <example-component></example-component> * Eg. ./components/ExampleComponent.vue -> <example-component></example-component>
*/ */
const files = require.context('./', true, /\.vue$/i) import './components';
files.keys().map(key => Vue.component(key.split('/').pop().split('.')[0], files(key).default))
/** /**
* Constants * Constants
*/ */

22
resources/js/components.js vendored Normal file
View File

@ -0,0 +1,22 @@
import Vue from 'vue';
const requireComponent = require.context('./components', true, /\.vue$/);
requireComponent.keys().forEach(fileName => {
// Get the component config
const componentConfig = requireComponent(fileName);
// Get the PascalCase name of the component
const componentName = fileName
.replace(/^\.\/(.*)\.\w+$/, '$1') // Remove "./" from the beginning and the file extension from the end
.replace(/\//g, '-') // Replace directories with hyphens
.replace(/([a-z])([A-Z])/g, '$1-$2') // Insert hyphen between camelCase words
.toLowerCase() // Convert to lowercase
// Globally register the component
Vue.component(
componentName,
// Look for the component options on `.default`, which will
// exist if the component was exported with `export default`,
// otherwise fall back to module's root.
componentConfig.default || componentConfig
);
});