2024-06-27 07:34:42 +00:00
import alias from '@rollup/plugin-alias' ;
import { babel } from '@rollup/plugin-babel' ;
import terser from '@rollup/plugin-terser' ;
import postcss from 'rollup-plugin-postcss' ;
import vue from 'rollup-plugin-vue' ;
import fs from 'fs-extra' ;
import path from 'path' ;
import viteConfig , { THEME _PRESETS } from './nuxt-vite.config.js' ;
import pkg from './package.json' ;
// globals
const GLOBALS = {
vue : 'Vue'
} ;
// externals
const GLOBAL _EXTERNALS = [ 'vue' , 'chart.js/auto' , 'quill' ] ;
const INLINE _EXTERNALS = Object . keys ( viteConfig . resolve . alias ) ;
const EXTERNALS = [ ... GLOBAL _EXTERNALS , ... INLINE _EXTERNALS ] ;
// alias
const ALIAS _ENTRIES = Object . entries ( viteConfig . resolve . alias ) . map ( ( [ key , value ] ) => ( { find : key , replacement : value } ) ) ;
// plugins
const BABEL _PLUGIN _OPTIONS = {
extensions : [ '.js' , '.vue' ] ,
exclude : 'node_modules/**' ,
presets : [ '@babel/preset-env' ] ,
plugins : [ ] ,
skipPreflightCheck : true ,
babelHelpers : 'runtime' ,
babelrc : false
} ;
const ALIAS _PLUGIN _OPTIONS = {
entries : ALIAS _ENTRIES
} ;
const POSTCSS _PLUGIN _OPTIONS = {
sourceMap : false
} ;
const TERSER _PLUGIN _OPTIONS = {
compress : {
keep _infinity : true ,
pure _getters : true ,
reduce _funcs : true
} ,
mangle : {
reserved : [ 'theme' , 'css' ]
}
} ;
const PLUGINS = [ vue ( ) , postcss ( POSTCSS _PLUGIN _OPTIONS ) , babel ( BABEL _PLUGIN _OPTIONS ) ] ;
const ENTRY = {
entries : [ ] ,
onwarn ( warning ) {
if ( warning . code === 'CIRCULAR_DEPENDENCY' ) {
//console.error(`(!) ${warning.message}`);
return ;
}
} ,
format : {
cjs _es ( options ) {
return ENTRY . format . cjs ( options ) . es ( options ) ;
} ,
cjs ( { input , output , minify } ) {
ENTRY . entries . push ( {
onwarn : ENTRY . onwarn ,
input ,
plugins : [ ... PLUGINS , minify && terser ( TERSER _PLUGIN _OPTIONS ) ] ,
external : EXTERNALS ,
inlineDynamicImports : true ,
output : [
{
format : 'cjs' ,
file : ` ${ output } ${ minify ? '.min' : '' } .cjs ` ,
sourcemap : true ,
exports : 'auto'
}
]
} ) ;
return ENTRY . format ;
} ,
es ( { input , output , minify } ) {
ENTRY . entries . push ( {
onwarn : ENTRY . onwarn ,
input ,
plugins : [ ... PLUGINS , minify && terser ( TERSER _PLUGIN _OPTIONS ) ] ,
external : EXTERNALS ,
inlineDynamicImports : true ,
output : [
{
format : 'es' ,
file : ` ${ output } ${ minify ? '.min' : '' } .mjs ` ,
sourcemap : true ,
exports : 'auto'
}
]
} ) ;
return ENTRY . format ;
} ,
umd ( { name , input , output , minify } ) {
ENTRY . entries . push ( {
onwarn : ENTRY . onwarn ,
input ,
plugins : [ alias ( ALIAS _PLUGIN _OPTIONS ) , ... PLUGINS , minify && terser ( TERSER _PLUGIN _OPTIONS ) ] ,
external : GLOBAL _EXTERNALS ,
inlineDynamicImports : true ,
output : [
{
format : 'umd' ,
name : name ? ? 'PrimeVue' ,
file : ` ${ output } ${ minify ? '.min' : '' } .js ` ,
globals : GLOBALS ,
exports : 'auto'
}
]
} ) ;
return ENTRY . format ;
}
}
} ;
function addFile ( ) {
fs . readdirSync ( path . resolve ( _ _dirname , process . env . INPUT _DIR ) , { withFileTypes : true } )
. filter ( ( dir ) => dir . isDirectory ( ) )
. forEach ( ( { name : folderName } ) => {
fs . readdirSync ( path . resolve ( _ _dirname , process . env . INPUT _DIR + folderName ) ) . forEach ( ( file ) => {
let name = file . split ( /(.vue)$|(.js)$/ ) [ 0 ] . toLowerCase ( ) ;
if ( name === folderName ) {
const input = process . env . INPUT _DIR + folderName + '/' + file ;
const output = process . env . OUTPUT _DIR + folderName + '/' + name ;
ENTRY . format . es ( { input , output } ) ;
}
} ) ;
} ) ;
}
function addIcon ( ) {
const iconDir = path . resolve ( _ _dirname , process . env . INPUT _DIR + 'icons' ) ;
fs . readdirSync ( path . resolve ( _ _dirname , iconDir ) , { withFileTypes : true } )
. filter ( ( dir ) => dir . isDirectory ( ) )
. forEach ( ( { name : folderName } ) => {
fs . readdirSync ( path . resolve ( _ _dirname , iconDir + '/' + folderName ) ) . forEach ( ( file ) => {
if ( /\.vue$/ . test ( file ) ) {
const name = file . split ( /(.vue)$/ ) [ 0 ] . toLowerCase ( ) ;
const input = process . env . INPUT _DIR + 'icons/' + folderName + '/' + file ;
const output = process . env . OUTPUT _DIR + 'icons/' + folderName + '/' + name ;
ENTRY . format . es ( { input , output } ) ;
}
} ) ;
} ) ;
}
function addStyle ( ) {
fs . readdirSync ( path . resolve ( _ _dirname , process . env . INPUT _DIR ) , { withFileTypes : true } )
. filter ( ( dir ) => dir . isDirectory ( ) )
. forEach ( ( { name : folderName } ) => {
try {
fs . readdirSync ( path . resolve ( _ _dirname , process . env . INPUT _DIR + folderName + '/style' ) ) . forEach ( ( file ) => {
if ( /\.js$/ . test ( file ) ) {
const name = file . split ( /(.js)$/ ) [ 0 ] . toLowerCase ( ) ;
const input = process . env . INPUT _DIR + folderName + '/style/' + file ;
const output = process . env . OUTPUT _DIR + folderName + '/style/' + name ;
ENTRY . format . es ( { input , output } ) ;
}
} ) ;
} catch { }
} ) ;
}
function traverseDir ( dir , condition , callback ) {
try {
const files = fs . readdirSync ( dir ) ;
files . forEach ( ( file ) => {
const filePath = path . join ( dir , file ) ;
const fileStat = fs . statSync ( filePath ) ;
if ( fileStat . isDirectory ( ) ) {
traverseDir ( filePath , condition , callback ) ;
} else if ( condition ? . ( file ) && fileStat . isFile ( ) ) {
callback ? . ( file , filePath , dir ) ;
}
} ) ;
} catch { }
}
function addThemes ( ) {
traverseDir (
path . resolve ( _ _dirname , process . env . INPUT _DIR + 'themes' ) ,
( file ) => file === 'index.js' ,
( file , filePath , folderPath ) => {
const searchFolder = '/' + process . env . INPUT _DIR ;
const folderName = folderPath . substring ( folderPath . indexOf ( searchFolder ) + searchFolder . length ) ;
const input = process . env . INPUT _DIR + folderName + '/' + file ;
const output = process . env . OUTPUT _DIR + folderName + '/' + 'index' ;
ENTRY . format . es ( { input , output } ) ;
}
) ;
}
function addCore ( ) {
ENTRY . format . es ( { input : process . env . INPUT _DIR + 'config/PrimeVue.js' , output : process . env . OUTPUT _DIR + 'config/config' } ) ;
ENTRY . format . es ( { input : process . env . INPUT _DIR + 'service/PrimeVueService.js' , output : process . env . OUTPUT _DIR + 'service/primevueservice' } ) ;
}
function addPassThrough ( ) {
ENTRY . format . es ( { input : process . env . INPUT _DIR + 'passthrough/index.js' , output : process . env . OUTPUT _DIR + 'passthrough/index' } ) ;
}
function addLibrary ( ) {
THEME _PRESETS ? . forEach ( ( preset ) => {
ENTRY . format . umd ( { name : ` PrimeVue.Themes. ${ preset [ 0 ] . toUpperCase ( ) + preset . slice ( 1 ) } ` , input : process . env . INPUT _DIR + ` themes/ ${ preset } /index.js ` , output : process . env . OUTPUT _DIR + ` umd/themes/ ${ preset } ` , minify : true } ) ;
} ) ;
ENTRY . format . umd ( { name : 'PrimeVue' , input : process . env . INPUT _DIR + 'primevue.js' , output : process . env . OUTPUT _DIR + 'umd/primevue' , minify : true } ) ;
}
function addPackageJson ( ) {
const outputDir = path . resolve ( _ _dirname , process . env . OUTPUT _DIR ) ;
const packageJson = ` {
"name" : "primevue" ,
"version" : "${pkg.version}" ,
"private" : "false" ,
"author" : "PrimeTek Informatics" ,
"description" : "PrimeVue is an open source UI library for Vue featuring a rich set of 80+ components, a theme designer, various theme alternatives such as Material, Bootstrap, Tailwind, premium templates and professional support. In addition, it integrates with PrimeBlock, which has 370+ ready to use UI blocks to build spectacular applications in no time." ,
"homepage" : "https://primevue.org/" ,
"repository" : {
"type" : "git" ,
"url" : "https://github.com/primefaces/primevue.git"
} ,
"license" : "MIT" ,
"bugs" : {
"url" : "https://github.com/primefaces/primevue/issues"
} ,
"keywords" : [
"primevue" ,
"vue" ,
"vue.js" ,
"vue2" ,
"vue3" ,
"ui library" ,
"component library" ,
"material" ,
"bootstrap" ,
"fluent" ,
"tailwind" ,
"unstyled" ,
"passthrough"
] ,
"unpkg" : "umd/primevue.min.js" ,
"jsdelivr" : "umd/primevue.min.js" ,
"web-types" : "./web-types.json" ,
"vetur" : {
"tags" : "./vetur-tags.json" ,
"attributes" : "./vetur-attributes.json"
} ,
"sideEffects" : [
"*.vue"
] ,
"peerDependencies" : {
2025-01-14 11:06:43 +00:00
"vue" : "^3.5.0"
2024-06-27 07:34:42 +00:00
} ,
"engines" : {
"node" : ">=12.11.0"
}
} ` ;
! fs . existsSync ( outputDir ) && fs . mkdirSync ( outputDir ) ;
fs . writeFileSync ( path . resolve ( outputDir , 'package.json' ) , packageJson ) ;
}
addCore ( ) ;
addStyle ( ) ;
addThemes ( ) ;
addIcon ( ) ;
addFile ( ) ;
addPassThrough ( ) ;
addLibrary ( ) ;
addPackageJson ( ) ;
export default ENTRY . entries ;