2024-06-11 12:21:12 +00:00
|
|
|
import fs from 'fs-extra';
|
|
|
|
import path from 'path';
|
|
|
|
import { removeBuild, resolvePath, updatePackageJson } from '../../../scripts/build-helper.mjs';
|
|
|
|
|
|
|
|
removeBuild(import.meta.url);
|
|
|
|
|
|
|
|
const { __dirname, INPUT_DIR } = resolvePath(import.meta.url);
|
|
|
|
const __root = path.resolve(__dirname, '../');
|
|
|
|
const pkg = path.resolve(__root, './package.json');
|
|
|
|
|
|
|
|
updatePackageJson(pkg);
|
|
|
|
|
|
|
|
// update package.json > "exports" for local
|
|
|
|
let exports = {};
|
2024-06-12 13:37:30 +00:00
|
|
|
let umd = {
|
|
|
|
ignoredFolders: ['useconfirm', 'usedialog', 'usetoast', 'usestyle'],
|
|
|
|
exports: [
|
|
|
|
`// API
|
|
|
|
export * from '@primevue/core';
|
|
|
|
|
|
|
|
// BaseIcon
|
|
|
|
export { default as BaseIcon } from '@primevue/icons/baseicon';
|
|
|
|
export { default as BaseIconStyle } from '@primevue/icons/baseicon/style';
|
|
|
|
|
|
|
|
// Themes
|
|
|
|
export * from '@primevue/themes';
|
|
|
|
|
|
|
|
// UseConfirm
|
|
|
|
export * from './useconfirm/UseConfirm.js';
|
|
|
|
|
|
|
|
// UseDialog
|
|
|
|
export * from './usedialog/UseDialog.js';
|
|
|
|
|
|
|
|
// UseToast
|
|
|
|
export * from './usetoast/UseToast.js';
|
|
|
|
|
|
|
|
// UseStyle
|
|
|
|
export * from './usestyle/UseStyle.js';
|
|
|
|
`
|
|
|
|
]
|
|
|
|
};
|
2024-06-11 12:21:12 +00:00
|
|
|
|
|
|
|
fs.readdirSync(path.resolve(__root, INPUT_DIR), { withFileTypes: true })
|
|
|
|
.filter((dir) => dir.isDirectory())
|
|
|
|
.forEach(({ name: folderName }) => {
|
2024-06-12 13:37:30 +00:00
|
|
|
const folderPath = path.resolve(__root, INPUT_DIR + folderName);
|
|
|
|
|
|
|
|
fs.readdirSync(folderPath).forEach((file) => {
|
2024-06-11 12:21:12 +00:00
|
|
|
let fileName = file.split(/(.vue)$|(.js)$/)[0];
|
|
|
|
let name = fileName.toLowerCase();
|
|
|
|
|
|
|
|
if (name === folderName) {
|
2024-06-12 13:37:30 +00:00
|
|
|
const validUMDFolder = !umd.ignoredFolders.includes(folderName);
|
|
|
|
|
2024-06-11 12:21:12 +00:00
|
|
|
exports[`./${folderName}`] = `./${INPUT_DIR}${folderName}/${file}`;
|
2024-06-12 13:37:30 +00:00
|
|
|
validUMDFolder &&
|
|
|
|
umd.exports.push(
|
|
|
|
`
|
|
|
|
// ${fileName}
|
|
|
|
export * from './${folderName}/${file}';
|
|
|
|
export { default as ${fileName} } from './${folderName}/${file}';
|
|
|
|
`
|
|
|
|
);
|
|
|
|
|
|
|
|
try {
|
|
|
|
fs.readdirSync(folderPath + '/style').forEach((file) => {
|
|
|
|
let subFileName = file.split(/(.js)$/)[0];
|
|
|
|
let subName = subFileName.toLowerCase();
|
|
|
|
|
|
|
|
if (subName === `${folderName}style`) {
|
|
|
|
exports[`./${folderName}/style`] = `./${INPUT_DIR}${folderName}/style/${file}`;
|
|
|
|
validUMDFolder &&
|
|
|
|
umd.exports.push(
|
|
|
|
`export * from './${folderName}/style/${file}';
|
|
|
|
export { default as ${subFileName} } from './${folderName}/style/${file}';
|
|
|
|
`
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
} catch {}
|
2024-06-11 12:21:12 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
exports['./*'] = './*';
|
|
|
|
|
2024-06-12 13:37:30 +00:00
|
|
|
// package.json
|
2024-06-11 12:21:12 +00:00
|
|
|
const pkgJson = JSON.parse(fs.readFileSync(pkg, { encoding: 'utf8', flag: 'r' }));
|
|
|
|
|
|
|
|
pkgJson.exports = exports;
|
|
|
|
|
|
|
|
fs.writeFileSync(pkg, JSON.stringify(pkgJson, null, 4));
|
2024-06-12 13:37:30 +00:00
|
|
|
|
|
|
|
// UMD
|
|
|
|
fs.writeFileSync(INPUT_DIR + 'primevue.js', umd.exports.join(''));
|