fix(core): update
This commit is contained in:
parent
a265493eba
commit
33e73e9959
12522
package-lock.json
generated
12522
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -21,8 +21,7 @@
|
||||
},
|
||||
"dependencies": {
|
||||
"@pushrocks/smartpath": "^4.0.3",
|
||||
"@types/parcel-bundler": "1.12.3",
|
||||
"parcel-bundler": "1.12.3"
|
||||
"@parcel/core": "^2.3.2"
|
||||
},
|
||||
"files": [
|
||||
"ts/**/*",
|
||||
|
@ -1,64 +1,91 @@
|
||||
import * as plugins from './smartparcel.plugins';
|
||||
|
||||
export class Parcel {
|
||||
private defaultOptions: plugins.parcel.ParcelOptions = {
|
||||
outDir: plugins.path.join(process.cwd(), './dist_watch'), // The out directory to put the build files in, defaults to dist
|
||||
outFile: 'index.html', // The name of the outputFile
|
||||
publicUrl: '/', // The url to serve on, defaults to '/'
|
||||
watch: true, // Whether to watch the files and rebuild them on change, defaults to process.env.NODE_ENV !== 'production'
|
||||
cache: true, // Enabled or disables caching, defaults to true
|
||||
cacheDir: '.nogit/.parcelcache', // The directory cache gets put in, defaults to .cache
|
||||
contentHash: false, // Disable content hash from being included on the filename
|
||||
global: 'moduleName', // Expose modules as UMD under this name, disabled by default
|
||||
minify: false, // Minify files, enabled if process.env.NODE_ENV === 'production'
|
||||
scopeHoist: false, // Turn on experimental scope hoisting/tree shaking flag, for smaller production bundles
|
||||
target: 'browser', // Browser/node/electron, defaults to browser
|
||||
bundleNodeModules: true, // By default, package.json dependencies are not included when using 'node' or 'electron' with 'target' option above. Set to true to adds them to the bundle, false by default
|
||||
https: null,
|
||||
logLevel: 3, // 5 = save everything to a file, 4 = like 3, but with timestamps and additionally log http requests to dev server, 3 = log info, warnings & errors, 2 = log warnings & errors, 1 = log errors, 0 = log nothing
|
||||
hmr: true, // Enable or disable HMR while watching
|
||||
hmrPort: 3003, // The port the HMR socket runs on, defaults to a random free port (0 in node.js resolves to a random free port)
|
||||
sourceMaps: true, // Enable or disable sourcemaps, defaults to enabled (minified builds currently always create sourcemaps)
|
||||
hmrHostname: '', // A hostname for hot module reload, default to ''
|
||||
detailedReport: false, // Prints a detailed report of the bundles, assets, filesizes and times, defaults to false, reports are only printed if watch is disabled
|
||||
private options: {
|
||||
from: string | string[],
|
||||
outputDir: string,
|
||||
outputFile: string
|
||||
} = {
|
||||
from: null,
|
||||
outputDir: null,
|
||||
outputFile: null,
|
||||
}
|
||||
private defaultOptions: ConstructorParameters<typeof plugins.parcel.Parcel>[ 0 ] = {
|
||||
defaultConfig: '@parcel/config-default',
|
||||
cacheDir: './.nogit/.parcelcache',
|
||||
defaultTargetOptions: {
|
||||
distDir: plugins.path.join(process.cwd(), './dist_watch'),
|
||||
publicUrl: '/',
|
||||
engines: {
|
||||
browsers: [ 'last 1 Chrome version' ]
|
||||
}
|
||||
},
|
||||
entries: './html/index.html',
|
||||
hmrOptions: {
|
||||
port: 3003
|
||||
},
|
||||
serveOptions: {
|
||||
port: 3002
|
||||
}
|
||||
};
|
||||
public options: plugins.parcel.ParcelOptions;
|
||||
public entryFiles: string | string[] = plugins.path.join(process.cwd(), './html/index.html');
|
||||
|
||||
|
||||
public async createOptions() {
|
||||
const returnOptions: ConstructorParameters<typeof plugins.parcel.Parcel>[ 0 ] = {
|
||||
...this.defaultOptions,
|
||||
entries: this.options.from,
|
||||
defaultTargetOptions: {
|
||||
...this.defaultOptions.defaultTargetOptions,
|
||||
distDir: this.options.outputDir
|
||||
}
|
||||
}
|
||||
return returnOptions;
|
||||
}
|
||||
|
||||
/**
|
||||
* builds and serves
|
||||
*/
|
||||
public async start() {
|
||||
const bundler = new plugins.parcel(this.entryFiles, this.options);
|
||||
public async watchAndServe () {
|
||||
const bundler = new plugins.parcel.Parcel(await this.createOptions());
|
||||
|
||||
// Run the bundler, this returns the main bundle
|
||||
// Use the events if you're using watch mode as this promise will only trigger once and not for every rebuild
|
||||
const bundle = await bundler.serve(3002);
|
||||
let subscription = await bundler.watch((err, event) => {
|
||||
if (err) {
|
||||
// fatal error
|
||||
console.log(err);
|
||||
throw err;
|
||||
}
|
||||
|
||||
if (event.type === 'buildSuccess') {
|
||||
let bundles = event.bundleGraph.getBundles();
|
||||
console.log(`✨ Built ${bundles.length} bundles in ${event.buildTime}ms!`);
|
||||
} else if (event.type === 'buildFailure') {
|
||||
console.log(event.diagnostics);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* just builds
|
||||
*/
|
||||
public async build() {
|
||||
const bundler = new plugins.parcel(this.entryFiles, {
|
||||
...this.options,
|
||||
watch: false,
|
||||
});
|
||||
|
||||
// Run the bundler, this returns the main bundle
|
||||
// Use the events if you're using watch mode as this promise will only trigger once and not for every rebuild
|
||||
const bundle = await bundler.bundle().catch((e) => {
|
||||
console.error(e);
|
||||
throw e;
|
||||
});
|
||||
public async build () {
|
||||
let bundler = new plugins.parcel.Parcel(await this.createOptions());
|
||||
|
||||
try {
|
||||
let {bundleGraph, buildTime} = await bundler.run();
|
||||
let bundles = bundleGraph.getBundles();
|
||||
console.log(`✨ Built ${bundles.length} bundles in ${buildTime}ms!`);
|
||||
} catch (err: any) {
|
||||
console.log(err.diagnostics);
|
||||
}
|
||||
}
|
||||
|
||||
constructor(fromArg: string | string[], outputDirArg: string, outputFileArg: string) {
|
||||
this.entryFiles = fromArg;
|
||||
this.options = {
|
||||
...this.defaultOptions,
|
||||
outDir: outputDirArg,
|
||||
outFile: outputFileArg,
|
||||
from: fromArg,
|
||||
outputDir: outputDirArg,
|
||||
outputFile: outputFileArg
|
||||
};
|
||||
}
|
||||
}
|
||||
|
@ -9,6 +9,6 @@ import * as smartpath from '@pushrocks/smartpath';
|
||||
export { smartpath };
|
||||
|
||||
// third party scope
|
||||
import parcel from 'parcel-bundler';
|
||||
import * as parcel from '@parcel/core';
|
||||
|
||||
export { parcel };
|
||||
|
Loading…
Reference in New Issue
Block a user