Skip to content

Commit

Permalink
Update rollup build for Core
Browse files Browse the repository at this point in the history
  • Loading branch information
mertsincan committed Oct 4, 2021
1 parent 2a5f242 commit 7c3ea39
Showing 1 changed file with 49 additions and 14 deletions.
63 changes: 49 additions & 14 deletions rollup.config.js
Expand Up @@ -7,32 +7,40 @@ const path = require('path');

let entries = [];

let globalDependencies = {
'vue': 'Vue',
let coreDependencies = {
'primevue/config': 'primevue.config',
'primevue/api': 'primevue.api',
'primevue/ripple': 'primevue.ripple',
'primevue/utils': 'primevue.utils',
'primevue/button': 'primevue.button',
'primevue/inputtext': 'primevue.inputtext',
'primevue/virtualscroller': 'primevue.virtualscroller',
'primevue/dialog': 'primevue.dialog',
'primevue/paginator': 'primevue.paginator',
'primevue/ripple': 'primevue.ripple',
'primevue/confirmationeventbus': 'primevue.confirmationeventbus',
'primevue/toasteventbus': 'primevue.toasteventbus',
'primevue/overlayeventbus': 'primevue.overlayeventbus',
'primevue/terminalservice': 'primevue.terminalservice',
'primevue/useconfirm': 'primevue.useconfirm',
'primevue/usetoast': 'primevue.usetoast',
'primevue/button': 'primevue.button',
'primevue/inputtext': 'primevue.inputtext',
'primevue/virtualscroller': 'primevue.virtualscroller',
'primevue/dialog': 'primevue.dialog',
'primevue/paginator': 'primevue.paginator',
'primevue/progressbar': 'primevue.progressbar',
'primevue/message': 'primevue.message',
'primevue/dropdown': 'primevue.dropdown',
'primevue/inputnumber': 'primevue.inputnumber',
'primevue/menu': 'primevue.menu',
'primevue/tieredmenu': 'primevue.tieredmenu',
'primevue/tree': 'primevue.tree',
'@fullcalendar/core': 'FullCalendar'
}

let globalDependencies = {
'vue': 'Vue',
'@fullcalendar/core': 'FullCalendar',
...coreDependencies
}

function addEntry(folder, inFile, outFile) {
let useCorePlugin = Object.keys(coreDependencies).some(d => d.replace('primevue/', '') === outFile);

entries.push({
input: 'src/components/' + folder + '/' + inFile,
output: [
Expand All @@ -53,7 +61,8 @@ function addEntry(folder, inFile, outFile) {
],
plugins: [
vue(),
postcss()
postcss(),
useCorePlugin && corePlugin()
]
});

Expand All @@ -78,11 +87,36 @@ function addEntry(folder, inFile, outFile) {
plugins: [
vue(),
postcss(),
terser()
terser(),
useCorePlugin && corePlugin()
]
});
}

function corePlugin() {
return {
name: 'corePlugin',
generateBundle(outputOptions, bundle) {
if (outputOptions.format === 'iife') {
Object.keys(bundle).forEach(id => {
const chunk = bundle[id];
const filePath = `./dist/core/core${id.indexOf('.min.js') > 0 ? '.min.js': '.js'}`;

fs.outputFile(path.resolve(__dirname, filePath), chunk.code + '\n', { 'flag': 'a' }, function(err) {
if (err) {
return console.error(err);
}
});
});
}
}
};
}

function removeCore() {
fs.removeSync(path.resolve(__dirname, './dist/core'));
}

function addSFC() {
fs.readdirSync(path.resolve(__dirname, './src/components/')).forEach(folder => {
fs.readdirSync(path.resolve(__dirname, './src/components/' + folder)).forEach(file => {
Expand Down Expand Up @@ -124,11 +158,12 @@ function addServices() {
addEntry('terminalservice', 'TerminalService.js', 'terminalservice');
}

addSFC();
addDirectives();
addConfig();
removeCore();
addUtils();
addApi();
addConfig();
addDirectives();
addServices();
addSFC();

export default entries;

0 comments on commit 7c3ea39

Please sign in to comment.