@storm-software/unbuild
Version:
A package containing `unbuild` utilities for building Storm Software libraries and applications
1,103 lines (1,038 loc) • 54.3 kB
JavaScript
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
var _chunkE74YDPSVcjs = require('./chunk-E74YDPSV.cjs');
var _chunkBN66ODNOcjs = require('./chunk-BN66ODNO.cjs');
var _chunkWCQ3HMVKcjs = require('./chunk-WCQ3HMVK.cjs');
var _chunkKV76QDPTcjs = require('./chunk-KV76QDPT.cjs');
var _chunk4D3WT42Ncjs = require('./chunk-4D3WT42N.cjs');
var _chunkBGYQAVKQcjs = require('./chunk-BGYQAVKQ.cjs');
// src/build.ts
var _devkit = require('@nx/devkit');
var _js = require('@nx/js');
var _buildablelibsutils = require('@nx/js/src/utils/buildable-libs-utils');
// ../build-tools/src/plugins/swc.ts
var _core = require('@swc/core');
// ../build-tools/src/plugins/ts-resolve.ts
var _fs = require('fs'); var _fs2 = _interopRequireDefault(_fs);
var _module = require('module');
var _path = require('path'); var _path2 = _interopRequireDefault(_path);
var _resolve2 = require('resolve'); var _resolve3 = _interopRequireDefault(_resolve2);
// ../build-tools/src/plugins/type-definitions.ts
// ../build-tools/src/utilities/copy-assets.ts
var _copyassetshandler = require('@nx/js/src/utils/assets/copy-assets-handler');
var _glob = require('glob');
var _promises = require('fs/promises');
var copyAssets = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, async (config, assets, outputPath, projectRoot, sourceRoot, generatePackageJson2 = true, includeSrc = false, banner, footer) => {
const pendingAssets = Array.from(_nullishCoalesce(assets, () => ( [])));
pendingAssets.push({
input: projectRoot,
glob: "*.md",
output: "."
});
pendingAssets.push({
input: ".",
glob: "LICENSE",
output: "."
});
if (generatePackageJson2 === false) {
pendingAssets.push({
input: projectRoot,
glob: "package.json",
output: "."
});
}
if (includeSrc === true) {
pendingAssets.push({
input: sourceRoot,
glob: "**/{*.ts,*.tsx,*.js,*.jsx}",
output: "src/"
});
}
_chunk4D3WT42Ncjs.writeTrace.call(void 0, `\u{1F4DD} Copying the following assets to the output directory:
${pendingAssets.map((pendingAsset) => typeof pendingAsset === "string" ? ` - ${pendingAsset} -> ${outputPath}` : ` - ${pendingAsset.input}/${pendingAsset.glob} -> ${_chunk4D3WT42Ncjs.joinPaths.call(void 0, outputPath, pendingAsset.output)}`).join("\n")}`, config);
const assetHandler = new (0, _copyassetshandler.CopyAssetsHandler)({
projectDir: projectRoot,
rootDir: config.workspaceRoot,
outputDir: outputPath,
assets: pendingAssets
});
await assetHandler.processAllAssetsOnce();
if (includeSrc === true) {
_chunk4D3WT42Ncjs.writeDebug.call(void 0, `\u{1F4DD} Adding banner and writing source files: ${_chunk4D3WT42Ncjs.joinPaths.call(void 0, outputPath, "src")}`, config);
const files = await _glob.glob.call(void 0, [
_chunk4D3WT42Ncjs.joinPaths.call(void 0, config.workspaceRoot, outputPath, "src/**/*.ts"),
_chunk4D3WT42Ncjs.joinPaths.call(void 0, config.workspaceRoot, outputPath, "src/**/*.tsx"),
_chunk4D3WT42Ncjs.joinPaths.call(void 0, config.workspaceRoot, outputPath, "src/**/*.js"),
_chunk4D3WT42Ncjs.joinPaths.call(void 0, config.workspaceRoot, outputPath, "src/**/*.jsx")
]);
await Promise.allSettled(files.map(async (file) => _promises.writeFile.call(void 0, file, `${banner && typeof banner === "string" ? banner.startsWith("//") ? banner : `// ${banner}` : ""}
${await _promises.readFile.call(void 0, file, "utf8")}
${footer && typeof footer === "string" ? footer.startsWith("//") ? footer : `// ${footer}` : ""}`)));
}
}, "copyAssets");
// ../build-tools/src/utilities/generate-package-json.ts
var _projectgraph = require('nx/src/project-graph/project-graph');
var addPackageDependencies = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, async (workspaceRoot, projectRoot, projectName, packageJson) => {
const projectGraph = _projectgraph.readCachedProjectGraph.call(void 0, );
const projectDependencies = _buildablelibsutils.calculateProjectBuildableDependencies.call(void 0, void 0, projectGraph, workspaceRoot, projectName, process.env.NX_TASK_TARGET_TARGET || "build", process.env.NX_TASK_TARGET_CONFIGURATION || "production", true);
const localPackages = [];
for (const project of projectDependencies.dependencies.filter((dep) => dep.node.type === "lib" && _optionalChain([dep, 'access', _ => _.node, 'access', _2 => _2.data, 'optionalAccess', _3 => _3.root]) !== projectRoot && _optionalChain([dep, 'access', _4 => _4.node, 'access', _5 => _5.data, 'optionalAccess', _6 => _6.root]) !== workspaceRoot)) {
const projectNode = project.node;
if (projectNode.data.root) {
const projectPackageJsonPath = _chunk4D3WT42Ncjs.joinPaths.call(void 0, workspaceRoot, projectNode.data.root, "package.json");
if (_fs.existsSync.call(void 0, projectPackageJsonPath)) {
const projectPackageJsonContent = await _promises.readFile.call(void 0, projectPackageJsonPath, "utf8");
const projectPackageJson = JSON.parse(projectPackageJsonContent);
if (projectPackageJson.private !== true) {
localPackages.push(projectPackageJson);
}
}
}
}
if (localPackages.length > 0) {
_chunk4D3WT42Ncjs.writeTrace.call(void 0, `\u{1F4E6} Adding local packages to package.json: ${localPackages.map((p) => p.name).join(", ")}`);
const projectJsonFile = await _promises.readFile.call(void 0, _chunk4D3WT42Ncjs.joinPaths.call(void 0, projectRoot, "project.json"), "utf8");
const projectJson = JSON.parse(projectJsonFile);
const projectName2 = projectJson.name;
const projectConfigurations = _projectgraph.readProjectsConfigurationFromProjectGraph.call(void 0, projectGraph);
if (!_optionalChain([projectConfigurations, 'optionalAccess', _7 => _7.projects, 'optionalAccess', _8 => _8[projectName2]])) {
throw new Error("The Build process failed because the project does not have a valid configuration in the project.json file. Check if the file exists in the root of the project.");
}
const implicitDependencies = _optionalChain([projectConfigurations, 'access', _9 => _9.projects, 'optionalAccess', _10 => _10[projectName2], 'access', _11 => _11.implicitDependencies, 'optionalAccess', _12 => _12.reduce, 'call', _13 => _13((ret, dep) => {
if (_optionalChain([projectConfigurations, 'access', _14 => _14.projects, 'optionalAccess', _15 => _15[dep]])) {
const depPackageJsonPath = _chunk4D3WT42Ncjs.joinPaths.call(void 0, workspaceRoot, projectConfigurations.projects[dep].root, "package.json");
if (_fs.existsSync.call(void 0, depPackageJsonPath)) {
const depPackageJsonContent = _fs.readFileSync.call(void 0, depPackageJsonPath, "utf8");
const depPackageJson = JSON.parse(depPackageJsonContent);
if (depPackageJson.private !== true && !ret.includes(depPackageJson.name)) {
ret.push(depPackageJson.name);
}
}
}
return ret;
}, [])]);
packageJson.dependencies = localPackages.reduce((ret, localPackage) => {
if (!ret[localPackage.name] && !_optionalChain([implicitDependencies, 'optionalAccess', _16 => _16.includes, 'call', _17 => _17(localPackage.name)]) && _optionalChain([packageJson, 'access', _18 => _18.devDependencies, 'optionalAccess', _19 => _19[localPackage.name]]) === void 0) {
ret[localPackage.name] = `^${localPackage.version || "0.0.1"}`;
}
return ret;
}, _nullishCoalesce(packageJson.dependencies, () => ( {})));
packageJson.devDependencies = localPackages.reduce((ret, localPackage) => {
if (!ret[localPackage.name] && _optionalChain([implicitDependencies, 'optionalAccess', _20 => _20.includes, 'call', _21 => _21(localPackage.name)]) && _optionalChain([packageJson, 'access', _22 => _22.dependencies, 'optionalAccess', _23 => _23[localPackage.name]]) === void 0) {
ret[localPackage.name] = localPackage.version || "0.0.1";
}
return ret;
}, _nullishCoalesce(packageJson.devDependencies, () => ( {})));
} else {
_chunk4D3WT42Ncjs.writeTrace.call(void 0, "\u{1F4E6} No local packages dependencies to add to package.json");
}
return packageJson;
}, "addPackageDependencies");
var addWorkspacePackageJsonFields = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, async (config, projectRoot, sourceRoot, projectName, includeSrc = false, packageJson) => {
const workspaceRoot = config.workspaceRoot ? config.workspaceRoot : _chunk4D3WT42Ncjs.findWorkspaceRoot.call(void 0, );
const workspacePackageJsonContent = await _promises.readFile.call(void 0, _chunk4D3WT42Ncjs.joinPaths.call(void 0, workspaceRoot, "package.json"), "utf8");
const workspacePackageJson = JSON.parse(workspacePackageJsonContent);
packageJson.type ??= "module";
packageJson.sideEffects ??= false;
if (includeSrc === true) {
let distSrc = sourceRoot.replace(projectRoot, "");
if (distSrc.startsWith("/")) {
distSrc = distSrc.substring(1);
}
packageJson.source ??= `${_chunk4D3WT42Ncjs.joinPaths.call(void 0, distSrc, "index.ts").replaceAll("\\", "/")}`;
}
packageJson.files ??= [
"dist/**/*"
];
if (includeSrc === true && !packageJson.files.includes("src")) {
packageJson.files.push("src/**/*");
}
packageJson.publishConfig ??= {
access: "public"
};
packageJson.description ??= workspacePackageJson.description;
packageJson.homepage ??= workspacePackageJson.homepage;
packageJson.bugs ??= workspacePackageJson.bugs;
packageJson.license ??= workspacePackageJson.license;
packageJson.keywords ??= workspacePackageJson.keywords;
packageJson.funding ??= workspacePackageJson.funding;
packageJson.author ??= workspacePackageJson.author;
packageJson.maintainers ??= workspacePackageJson.maintainers;
if (!packageJson.maintainers && packageJson.author) {
packageJson.maintainers = [
packageJson.author
];
}
packageJson.contributors ??= workspacePackageJson.contributors;
if (!packageJson.contributors && packageJson.author) {
packageJson.contributors = [
packageJson.author
];
}
packageJson.repository ??= workspacePackageJson.repository;
packageJson.repository.directory ??= projectRoot ? projectRoot : _chunk4D3WT42Ncjs.joinPaths.call(void 0, "packages", projectName);
return packageJson;
}, "addWorkspacePackageJsonFields");
// ../config-tools/src/config-file/get-config-file.ts
var _c12 = require('c12');
var _defu = require('defu'); var _defu2 = _interopRequireDefault(_defu);
var getConfigFileByName = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, async (fileName, filePath, options = {}) => {
const workspacePath = filePath || _chunk4D3WT42Ncjs.findWorkspaceRoot.call(void 0, filePath);
const configs = await Promise.all([
_c12.loadConfig.call(void 0, {
cwd: workspacePath,
packageJson: true,
name: fileName,
envName: _optionalChain([fileName, 'optionalAccess', _24 => _24.toUpperCase, 'call', _25 => _25()]),
jitiOptions: {
debug: false,
fsCache: process.env.STORM_SKIP_CACHE === "true" ? false : _chunk4D3WT42Ncjs.joinPaths.call(void 0, process.env.STORM_CACHE_DIR || "node_modules/.cache/storm", "jiti")
},
...options
}),
_c12.loadConfig.call(void 0, {
cwd: workspacePath,
packageJson: true,
name: fileName,
envName: _optionalChain([fileName, 'optionalAccess', _26 => _26.toUpperCase, 'call', _27 => _27()]),
jitiOptions: {
debug: false,
fsCache: process.env.STORM_SKIP_CACHE === "true" ? false : _chunk4D3WT42Ncjs.joinPaths.call(void 0, process.env.STORM_CACHE_DIR || "node_modules/.cache/storm", "jiti")
},
configFile: fileName,
...options
})
]);
return _defu2.default.call(void 0, _nullishCoalesce(configs[0], () => ( {})), _nullishCoalesce(configs[1], () => ( {})));
}, "getConfigFileByName");
var getConfigFile = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, async (filePath, additionalFileNames = []) => {
const workspacePath = filePath ? filePath : _chunk4D3WT42Ncjs.findWorkspaceRoot.call(void 0, filePath);
const result = await getConfigFileByName("storm-workspace", workspacePath);
let config = result.config;
const configFile = result.configFile;
if (config && configFile && Object.keys(config).length > 0 && !config.skipConfigLogging) {
_chunk4D3WT42Ncjs.writeTrace.call(void 0, `Found Storm configuration file "${configFile.includes(`${workspacePath}/`) ? configFile.replace(`${workspacePath}/`, "") : configFile}" at "${workspacePath}"`, {
logLevel: "all"
});
}
if (additionalFileNames && additionalFileNames.length > 0) {
const results = await Promise.all(additionalFileNames.map((fileName) => getConfigFileByName(fileName, workspacePath)));
for (const result2 of results) {
if (_optionalChain([result2, 'optionalAccess', _28 => _28.config]) && _optionalChain([result2, 'optionalAccess', _29 => _29.configFile]) && Object.keys(result2.config).length > 0) {
if (!config.skipConfigLogging && !result2.config.skipConfigLogging) {
_chunk4D3WT42Ncjs.writeTrace.call(void 0, `Found alternative configuration file "${result2.configFile.includes(`${workspacePath}/`) ? result2.configFile.replace(`${workspacePath}/`, "") : result2.configFile}" at "${workspacePath}"`, {
logLevel: "all"
});
}
config = _defu2.default.call(void 0, _nullishCoalesce(result2.config, () => ( {})), _nullishCoalesce(config, () => ( {})));
}
}
}
if (!config) {
return void 0;
}
config.configFile = configFile;
return config;
}, "getConfigFile");
// ../config-tools/src/create-storm-config.ts
// ../config-tools/src/env/get-env.ts
var getExtensionEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (extensionName) => {
const prefix = `STORM_EXTENSION_${extensionName.toUpperCase()}_`;
return Object.keys(process.env).filter((key) => key.startsWith(prefix)).reduce((ret, key) => {
const name = key.replace(prefix, "").split("_").map((i) => i.length > 0 ? i.trim().charAt(0).toUpperCase() + i.trim().slice(1) : "").join("");
if (name) {
ret[name] = process.env[key];
}
return ret;
}, {});
}, "getExtensionEnv");
var getConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, () => {
const prefix = "STORM_";
let config = {
extends: process.env[`${prefix}EXTENDS`] || void 0,
name: process.env[`${prefix}NAME`] || void 0,
namespace: process.env[`${prefix}NAMESPACE`] || void 0,
owner: process.env[`${prefix}OWNER`] || void 0,
bot: {
name: process.env[`${prefix}BOT_NAME`] || void 0,
email: process.env[`${prefix}BOT_EMAIL`] || void 0
},
release: {
banner: process.env[`${prefix}RELEASE_BANNER`] || void 0,
header: process.env[`${prefix}RELEASE_HEADER`] || void 0,
footer: process.env[`${prefix}RELEASE_FOOTER`] || void 0
},
error: {
codesFile: process.env[`${prefix}ERROR_CODES_FILE`] || void 0,
url: process.env[`${prefix}ERROR_URL`] || void 0
},
account: {
twitter: process.env[`${prefix}ACCOUNT_TWITTER`] || void 0,
discord: process.env[`${prefix}ACCOUNT_DISCORD`] || void 0,
telegram: process.env[`${prefix}ACCOUNT_TELEGRAM`] || void 0,
slack: process.env[`${prefix}ACCOUNT_SLACK`] || void 0,
medium: process.env[`${prefix}ACCOUNT_MEDIUM`] || void 0,
github: process.env[`${prefix}ACCOUNT_GITHUB`] || void 0
},
organization: process.env[`${prefix}ORGANIZATION`] || void 0,
packageManager: process.env[`${prefix}PACKAGE_MANAGER`] || void 0,
license: process.env[`${prefix}LICENSE`] || void 0,
homepage: process.env[`${prefix}HOMEPAGE`] || void 0,
docs: process.env[`${prefix}DOCS`] || void 0,
licensing: process.env[`${prefix}LICENSING`] || void 0,
contact: process.env[`${prefix}CONTACT`] || void 0,
timezone: process.env[`${prefix}TIMEZONE`] || process.env.TZ || void 0,
locale: process.env[`${prefix}LOCALE`] || process.env.LOCALE || void 0,
configFile: process.env[`${prefix}CONFIG_FILE`] ? _chunk4D3WT42Ncjs.correctPaths.call(void 0, process.env[`${prefix}CONFIG_FILE`]) : void 0,
workspaceRoot: process.env[`${prefix}WORKSPACE_ROOT`] ? _chunk4D3WT42Ncjs.correctPaths.call(void 0, process.env[`${prefix}WORKSPACE_ROOT`]) : void 0,
directories: {
cache: process.env[`${prefix}CACHE_DIR`] ? _chunk4D3WT42Ncjs.correctPaths.call(void 0, process.env[`${prefix}CACHE_DIR`]) : void 0,
data: process.env[`${prefix}DATA_DIR`] ? _chunk4D3WT42Ncjs.correctPaths.call(void 0, process.env[`${prefix}DATA_DIR`]) : void 0,
config: process.env[`${prefix}CONFIG_DIR`] ? _chunk4D3WT42Ncjs.correctPaths.call(void 0, process.env[`${prefix}CONFIG_DIR`]) : void 0,
temp: process.env[`${prefix}TEMP_DIR`] ? _chunk4D3WT42Ncjs.correctPaths.call(void 0, process.env[`${prefix}TEMP_DIR`]) : void 0,
log: process.env[`${prefix}LOG_DIR`] ? _chunk4D3WT42Ncjs.correctPaths.call(void 0, process.env[`${prefix}LOG_DIR`]) : void 0,
build: process.env[`${prefix}BUILD_DIR`] ? _chunk4D3WT42Ncjs.correctPaths.call(void 0, process.env[`${prefix}BUILD_DIR`]) : void 0
},
skipCache: process.env[`${prefix}SKIP_CACHE`] !== void 0 ? Boolean(process.env[`${prefix}SKIP_CACHE`]) : void 0,
mode: (_nullishCoalesce(_nullishCoalesce(process.env[`${prefix}MODE`], () => ( process.env.NODE_ENV)), () => ( process.env.ENVIRONMENT))) || void 0,
// ci:
// process.env[`${prefix}CI`] !== undefined
// ? Boolean(
// process.env[`${prefix}CI`] ??
// process.env.CI ??
// process.env.CONTINUOUS_INTEGRATION
// )
// : undefined,
repository: process.env[`${prefix}REPOSITORY`] || void 0,
branch: process.env[`${prefix}BRANCH`] || void 0,
preid: process.env[`${prefix}PRE_ID`] || void 0,
externalPackagePatterns: process.env[`${prefix}EXTERNAL_PACKAGE_PATTERNS`] ? JSON.parse(process.env[`${prefix}EXTERNAL_PACKAGE_PATTERNS`]) : [],
registry: {
github: process.env[`${prefix}REGISTRY_GITHUB`] || void 0,
npm: process.env[`${prefix}REGISTRY_NPM`] || void 0,
cargo: process.env[`${prefix}REGISTRY_CARGO`] || void 0,
cyclone: process.env[`${prefix}REGISTRY_CYCLONE`] || void 0,
container: process.env[`${prefix}REGISTRY_CONTAINER`] || void 0
},
logLevel: process.env[`${prefix}LOG_LEVEL`] !== null && process.env[`${prefix}LOG_LEVEL`] !== void 0 ? process.env[`${prefix}LOG_LEVEL`] && Number.isSafeInteger(Number.parseInt(process.env[`${prefix}LOG_LEVEL`])) ? _chunk4D3WT42Ncjs.getLogLevelLabel.call(void 0, Number.parseInt(process.env[`${prefix}LOG_LEVEL`])) : process.env[`${prefix}LOG_LEVEL`] : void 0,
skipConfigLogging: process.env[`${prefix}SKIP_CONFIG_LOGGING`] !== void 0 ? Boolean(process.env[`${prefix}SKIP_CONFIG_LOGGING`]) : void 0
};
const themeNames = Object.keys(process.env).filter((envKey) => envKey.startsWith(`${prefix}COLOR_`) && _chunk4D3WT42Ncjs.COLOR_KEYS.every((colorKey) => !envKey.startsWith(`${prefix}COLOR_LIGHT_${colorKey}`) && !envKey.startsWith(`${prefix}COLOR_DARK_${colorKey}`)));
config.colors = themeNames.length > 0 ? themeNames.reduce((ret, themeName) => {
ret[themeName] = getThemeColorConfigEnv(prefix, themeName);
return ret;
}, {}) : getThemeColorConfigEnv(prefix);
if (config.docs === _chunk4D3WT42Ncjs.STORM_DEFAULT_DOCS) {
if (config.homepage === _chunk4D3WT42Ncjs.STORM_DEFAULT_HOMEPAGE) {
config.docs = `${_chunk4D3WT42Ncjs.STORM_DEFAULT_HOMEPAGE}/projects/${config.name}/docs`;
} else {
config.docs = `${config.homepage}/docs`;
}
}
if (config.licensing === _chunk4D3WT42Ncjs.STORM_DEFAULT_LICENSING) {
if (config.homepage === _chunk4D3WT42Ncjs.STORM_DEFAULT_HOMEPAGE) {
config.licensing = `${_chunk4D3WT42Ncjs.STORM_DEFAULT_HOMEPAGE}/projects/${config.name}/licensing`;
} else {
config.licensing = `${config.homepage}/docs`;
}
}
const serializedConfig = process.env[`${prefix}CONFIG`];
if (serializedConfig) {
const parsed = JSON.parse(serializedConfig);
config = {
...config,
...parsed,
colors: {
...config.colors,
...parsed.colors
},
extensions: {
...config.extensions,
...parsed.extensions
}
};
}
return config;
}, "getConfigEnv");
var getThemeColorConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (prefix, theme) => {
const themeName = `COLOR_${theme && theme !== "base" ? `${theme}_` : ""}`.toUpperCase();
return process.env[`${prefix}${themeName}LIGHT_BRAND`] || process.env[`${prefix}${themeName}DARK_BRAND`] ? getMultiThemeColorConfigEnv(prefix + themeName) : getSingleThemeColorConfigEnv(prefix + themeName);
}, "getThemeColorConfigEnv");
var getSingleThemeColorConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (prefix) => {
return {
dark: process.env[`${prefix}DARK`],
light: process.env[`${prefix}LIGHT`],
brand: process.env[`${prefix}BRAND`],
alternate: process.env[`${prefix}ALTERNATE`],
accent: process.env[`${prefix}ACCENT`],
link: process.env[`${prefix}LINK`],
help: process.env[`${prefix}HELP`],
success: process.env[`${prefix}SUCCESS`],
info: process.env[`${prefix}INFO`],
warning: process.env[`${prefix}WARNING`],
danger: process.env[`${prefix}DANGER`],
fatal: process.env[`${prefix}FATAL`],
positive: process.env[`${prefix}POSITIVE`],
negative: process.env[`${prefix}NEGATIVE`]
};
}, "getSingleThemeColorConfigEnv");
var getMultiThemeColorConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (prefix) => {
return {
light: getBaseThemeColorConfigEnv(`${prefix}_LIGHT_`),
dark: getBaseThemeColorConfigEnv(`${prefix}_DARK_`)
};
}, "getMultiThemeColorConfigEnv");
var getBaseThemeColorConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (prefix) => {
return {
foreground: process.env[`${prefix}FOREGROUND`],
background: process.env[`${prefix}BACKGROUND`],
brand: process.env[`${prefix}BRAND`],
alternate: process.env[`${prefix}ALTERNATE`],
accent: process.env[`${prefix}ACCENT`],
link: process.env[`${prefix}LINK`],
help: process.env[`${prefix}HELP`],
success: process.env[`${prefix}SUCCESS`],
info: process.env[`${prefix}INFO`],
warning: process.env[`${prefix}WARNING`],
danger: process.env[`${prefix}DANGER`],
fatal: process.env[`${prefix}FATAL`],
positive: process.env[`${prefix}POSITIVE`],
negative: process.env[`${prefix}NEGATIVE`]
};
}, "getBaseThemeColorConfigEnv");
// ../config-tools/src/env/set-env.ts
var setExtensionEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (extensionName, extension) => {
for (const key of Object.keys(_nullishCoalesce(extension, () => ( {})))) {
if (extension[key]) {
const result = _nullishCoalesce(_optionalChain([key, 'optionalAccess', _30 => _30.replace, 'call', _31 => _31(/([A-Z])+/g, (input) => input ? _optionalChain([input, 'access', _32 => _32[0], 'optionalAccess', _33 => _33.toUpperCase, 'call', _34 => _34()]) + input.slice(1) : ""), 'access', _35 => _35.split, 'call', _36 => _36(/(?=[A-Z])|[.\-\s_]/), 'access', _37 => _37.map, 'call', _38 => _38((x) => x.toLowerCase())]), () => ( []));
let extensionKey;
if (result.length === 0) {
return;
}
if (result.length === 1) {
extensionKey = _nullishCoalesce(_optionalChain([result, 'access', _39 => _39[0], 'optionalAccess', _40 => _40.toUpperCase, 'call', _41 => _41()]), () => ( ""));
} else {
extensionKey = result.reduce((ret, part) => {
return `${ret}_${part.toLowerCase()}`;
});
}
process.env[`STORM_EXTENSION_${extensionName.toUpperCase()}_${extensionKey.toUpperCase()}`] = extension[key];
}
}
}, "setExtensionEnv");
var setConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (config) => {
const prefix = "STORM_";
if (config.extends) {
process.env[`${prefix}EXTENDS`] = Array.isArray(config.extends) ? JSON.stringify(config.extends) : config.extends;
}
if (config.name) {
process.env[`${prefix}NAME`] = config.name;
}
if (config.namespace) {
process.env[`${prefix}NAMESPACE`] = config.namespace;
}
if (config.owner) {
process.env[`${prefix}OWNER`] = config.owner;
}
if (config.bot) {
process.env[`${prefix}BOT_NAME`] = config.bot.name;
process.env[`${prefix}BOT_EMAIL`] = config.bot.email;
}
if (config.error) {
process.env[`${prefix}ERROR_CODES_FILE`] = config.error.codesFile;
process.env[`${prefix}ERROR_URL`] = config.error.url;
}
if (config.release) {
process.env[`${prefix}RELEASE_BANNER`] = config.release.banner;
process.env[`${prefix}RELEASE_HEADER`] = config.release.header;
process.env[`${prefix}RELEASE_FOOTER`] = config.release.footer;
}
if (config.account) {
if (config.account.twitter) {
process.env[`${prefix}ACCOUNT_TWITTER`] = config.account.twitter;
}
if (config.account.discord) {
process.env[`${prefix}ACCOUNT_DISCORD`] = config.account.discord;
}
if (config.account.telegram) {
process.env[`${prefix}ACCOUNT_TELEGRAM`] = config.account.telegram;
}
if (config.account.slack) {
process.env[`${prefix}ACCOUNT_SLACK`] = config.account.slack;
}
if (config.account.medium) {
process.env[`${prefix}ACCOUNT_MEDIUM`] = config.account.medium;
}
if (config.account.github) {
process.env[`${prefix}ACCOUNT_GITHUB`] = config.account.github;
}
}
if (config.organization) {
process.env[`${prefix}ORGANIZATION`] = config.organization;
}
if (config.packageManager) {
process.env[`${prefix}PACKAGE_MANAGER`] = config.packageManager;
}
if (config.license) {
process.env[`${prefix}LICENSE`] = config.license;
}
if (config.homepage) {
process.env[`${prefix}HOMEPAGE`] = config.homepage;
}
if (config.docs) {
process.env[`${prefix}DOCS`] = config.docs;
}
if (config.licensing) {
process.env[`${prefix}LICENSING`] = config.licensing;
}
if (config.contact) {
process.env[`${prefix}CONTACT`] = config.contact;
}
if (config.timezone) {
process.env[`${prefix}TIMEZONE`] = config.timezone;
process.env.TZ = config.timezone;
process.env.DEFAULT_TIMEZONE = config.timezone;
}
if (config.locale) {
process.env[`${prefix}LOCALE`] = config.locale;
process.env.LOCALE = config.locale;
process.env.DEFAULT_LOCALE = config.locale;
process.env.LANG = config.locale ? `${config.locale.replaceAll("-", "_")}.UTF-8` : "en_US.UTF-8";
}
if (config.configFile) {
process.env[`${prefix}CONFIG_FILE`] = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.configFile);
}
if (config.workspaceRoot) {
process.env[`${prefix}WORKSPACE_ROOT`] = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.workspaceRoot);
process.env.NX_WORKSPACE_ROOT = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.workspaceRoot);
process.env.NX_WORKSPACE_ROOT_PATH = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.workspaceRoot);
}
if (config.directories) {
if (!config.skipCache && config.directories.cache) {
process.env[`${prefix}CACHE_DIR`] = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.directories.cache);
}
if (config.directories.data) {
process.env[`${prefix}DATA_DIR`] = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.directories.data);
}
if (config.directories.config) {
process.env[`${prefix}CONFIG_DIR`] = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.directories.config);
}
if (config.directories.temp) {
process.env[`${prefix}TEMP_DIR`] = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.directories.temp);
}
if (config.directories.log) {
process.env[`${prefix}LOG_DIR`] = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.directories.log);
}
if (config.directories.build) {
process.env[`${prefix}BUILD_DIR`] = _chunk4D3WT42Ncjs.correctPaths.call(void 0, config.directories.build);
}
}
if (config.skipCache !== void 0) {
process.env[`${prefix}SKIP_CACHE`] = String(config.skipCache);
if (config.skipCache) {
process.env.NX_SKIP_NX_CACHE ??= String(config.skipCache);
process.env.NX_CACHE_PROJECT_GRAPH ??= String(config.skipCache);
}
}
if (config.mode) {
process.env[`${prefix}MODE`] = config.mode;
process.env.NODE_ENV = config.mode;
process.env.ENVIRONMENT = config.mode;
}
if (_optionalChain([config, 'access', _42 => _42.colors, 'optionalAccess', _43 => _43.base, 'optionalAccess', _44 => _44.light]) || _optionalChain([config, 'access', _45 => _45.colors, 'optionalAccess', _46 => _46.base, 'optionalAccess', _47 => _47.dark])) {
for (const key of Object.keys(config.colors)) {
setThemeColorConfigEnv(`${prefix}COLOR_${key}_`, config.colors[key]);
}
} else {
setThemeColorConfigEnv(`${prefix}COLOR_`, config.colors);
}
if (config.repository) {
process.env[`${prefix}REPOSITORY`] = config.repository;
}
if (config.branch) {
process.env[`${prefix}BRANCH`] = config.branch;
}
if (config.preid) {
process.env[`${prefix}PRE_ID`] = String(config.preid);
}
if (config.externalPackagePatterns) {
process.env[`${prefix}EXTERNAL_PACKAGE_PATTERNS`] = JSON.stringify(config.externalPackagePatterns);
}
if (config.registry) {
if (config.registry.github) {
process.env[`${prefix}REGISTRY_GITHUB`] = String(config.registry.github);
}
if (config.registry.npm) {
process.env[`${prefix}REGISTRY_NPM`] = String(config.registry.npm);
}
if (config.registry.cargo) {
process.env[`${prefix}REGISTRY_CARGO`] = String(config.registry.cargo);
}
if (config.registry.cyclone) {
process.env[`${prefix}REGISTRY_CYCLONE`] = String(config.registry.cyclone);
}
if (config.registry.container) {
process.env[`${prefix}REGISTRY_CONTAINER`] = String(config.registry.container);
}
}
if (config.logLevel) {
process.env[`${prefix}LOG_LEVEL`] = String(config.logLevel);
process.env.LOG_LEVEL = String(config.logLevel);
process.env.NX_VERBOSE_LOGGING = String(_chunk4D3WT42Ncjs.getLogLevel.call(void 0, config.logLevel) >= _chunk4D3WT42Ncjs.LogLevel.DEBUG ? true : false);
process.env.RUST_BACKTRACE = _chunk4D3WT42Ncjs.getLogLevel.call(void 0, config.logLevel) >= _chunk4D3WT42Ncjs.LogLevel.DEBUG ? "full" : "none";
}
if (config.skipConfigLogging !== void 0) {
process.env[`${prefix}SKIP_CONFIG_LOGGING`] = String(config.skipConfigLogging);
}
process.env[`${prefix}CONFIG`] = JSON.stringify(config);
for (const key of Object.keys(_nullishCoalesce(config.extensions, () => ( {})))) {
if (config.extensions[key] && Object.keys(config.extensions[key])) {
setExtensionEnv(key, config.extensions[key]);
}
}
}, "setConfigEnv");
var setThemeColorConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (prefix, config) => {
return _optionalChain([config, 'optionalAccess', _48 => _48.light, 'optionalAccess', _49 => _49.brand]) || _optionalChain([config, 'optionalAccess', _50 => _50.dark, 'optionalAccess', _51 => _51.brand]) ? setMultiThemeColorConfigEnv(prefix, config) : setSingleThemeColorConfigEnv(prefix, config);
}, "setThemeColorConfigEnv");
var setSingleThemeColorConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (prefix, config) => {
if (config.dark) {
process.env[`${prefix}DARK`] = config.dark;
}
if (config.light) {
process.env[`${prefix}LIGHT`] = config.light;
}
if (config.brand) {
process.env[`${prefix}BRAND`] = config.brand;
}
if (config.alternate) {
process.env[`${prefix}ALTERNATE`] = config.alternate;
}
if (config.accent) {
process.env[`${prefix}ACCENT`] = config.accent;
}
if (config.link) {
process.env[`${prefix}LINK`] = config.link;
}
if (config.help) {
process.env[`${prefix}HELP`] = config.help;
}
if (config.success) {
process.env[`${prefix}SUCCESS`] = config.success;
}
if (config.info) {
process.env[`${prefix}INFO`] = config.info;
}
if (config.warning) {
process.env[`${prefix}WARNING`] = config.warning;
}
if (config.danger) {
process.env[`${prefix}DANGER`] = config.danger;
}
if (config.fatal) {
process.env[`${prefix}FATAL`] = config.fatal;
}
if (config.positive) {
process.env[`${prefix}POSITIVE`] = config.positive;
}
if (config.negative) {
process.env[`${prefix}NEGATIVE`] = config.negative;
}
}, "setSingleThemeColorConfigEnv");
var setMultiThemeColorConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (prefix, config) => {
return {
light: setBaseThemeColorConfigEnv(`${prefix}LIGHT_`, config.light),
dark: setBaseThemeColorConfigEnv(`${prefix}DARK_`, config.dark)
};
}, "setMultiThemeColorConfigEnv");
var setBaseThemeColorConfigEnv = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (prefix, config) => {
if (config.foreground) {
process.env[`${prefix}FOREGROUND`] = config.foreground;
}
if (config.background) {
process.env[`${prefix}BACKGROUND`] = config.background;
}
if (config.brand) {
process.env[`${prefix}BRAND`] = config.brand;
}
if (config.alternate) {
process.env[`${prefix}ALTERNATE`] = config.alternate;
}
if (config.accent) {
process.env[`${prefix}ACCENT`] = config.accent;
}
if (config.link) {
process.env[`${prefix}LINK`] = config.link;
}
if (config.help) {
process.env[`${prefix}HELP`] = config.help;
}
if (config.success) {
process.env[`${prefix}SUCCESS`] = config.success;
}
if (config.info) {
process.env[`${prefix}INFO`] = config.info;
}
if (config.warning) {
process.env[`${prefix}WARNING`] = config.warning;
}
if (config.danger) {
process.env[`${prefix}DANGER`] = config.danger;
}
if (config.fatal) {
process.env[`${prefix}FATAL`] = config.fatal;
}
if (config.positive) {
process.env[`${prefix}POSITIVE`] = config.positive;
}
if (config.negative) {
process.env[`${prefix}NEGATIVE`] = config.negative;
}
}, "setBaseThemeColorConfigEnv");
// ../config-tools/src/create-storm-config.ts
var _extension_cache = /* @__PURE__ */ new WeakMap();
var _static_cache = void 0;
var createStormWorkspaceConfig = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, async (extensionName, schema, workspaceRoot, skipLogs = false) => {
let result;
if (!_optionalChain([_static_cache, 'optionalAccess', _52 => _52.data]) || !_optionalChain([_static_cache, 'optionalAccess', _53 => _53.timestamp]) || _static_cache.timestamp < Date.now() - 8e3) {
let _workspaceRoot = workspaceRoot;
if (!_workspaceRoot) {
_workspaceRoot = _chunk4D3WT42Ncjs.findWorkspaceRoot.call(void 0, );
}
const configEnv = getConfigEnv();
const defaultConfig = await _chunk4D3WT42Ncjs.getDefaultConfig.call(void 0, _workspaceRoot);
const configFile = await getConfigFile(_workspaceRoot);
if (!configFile && !skipLogs) {
_chunk4D3WT42Ncjs.writeWarning.call(void 0, "No Storm Workspace configuration file found in the current repository. Please ensure this is the expected behavior - you can add a `storm-workspace.json` file to the root of your workspace if it is not.\n", {
logLevel: "all"
});
}
result = await _chunk4D3WT42Ncjs.stormWorkspaceConfigSchema.parseAsync(_defu2.default.call(void 0, configEnv, configFile, defaultConfig));
result.workspaceRoot ??= _workspaceRoot;
} else {
result = _static_cache.data;
}
if (schema && extensionName) {
result.extensions = {
...result.extensions,
[extensionName]: createConfigExtension(extensionName, schema)
};
}
_static_cache = {
timestamp: Date.now(),
data: result
};
return result;
}, "createStormWorkspaceConfig");
var createConfigExtension = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (extensionName, schema) => {
const extension_cache_key = {
extensionName
};
if (_extension_cache.has(extension_cache_key)) {
return _extension_cache.get(extension_cache_key);
}
let extension = getExtensionEnv(extensionName);
if (schema) {
extension = schema.parse(extension);
}
_extension_cache.set(extension_cache_key, extension);
return extension;
}, "createConfigExtension");
var loadStormWorkspaceConfig = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, async (workspaceRoot, skipLogs = false) => {
const config = await createStormWorkspaceConfig(void 0, void 0, workspaceRoot, skipLogs);
setConfigEnv(config);
if (!skipLogs && !config.skipConfigLogging) {
_chunk4D3WT42Ncjs.writeTrace.call(void 0, `\u2699\uFE0F Using Storm Workspace configuration:
${_chunk4D3WT42Ncjs.formatLogMessage.call(void 0, config)}`, config);
}
return config;
}, "loadStormWorkspaceConfig");
// ../config-tools/src/get-config.ts
var getConfig = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (workspaceRoot, skipLogs = false) => {
return loadStormWorkspaceConfig(workspaceRoot, skipLogs);
}, "getConfig");
// ../build-tools/src/utilities/get-entry-points.ts
// ../build-tools/src/utilities/read-nx-config.ts
// ../build-tools/src/utilities/task-graph.ts
var _createtaskgraph = require('nx/src/tasks-runner/create-task-graph');
// src/build.ts
var _findworkspaceroot = require('nx/src/utils/find-workspace-root');
var _unbuild = require('unbuild');
async function resolveOptions(options, config) {
_chunk4D3WT42Ncjs.writeDebug.call(void 0, " \u2699\uFE0F Resolving build options", config);
const stopwatch = _chunk4D3WT42Ncjs.getStopwatch.call(void 0, "Build options resolution");
if (options.configPath) {
const configFile = await _chunkKV76QDPTcjs.loadConfig.call(void 0, options.configPath);
if (configFile) {
options = _defu2.default.call(void 0, options, configFile);
}
}
const outputPath = options.outputPath || _chunk4D3WT42Ncjs.joinPaths.call(void 0, "dist", options.projectRoot);
const projectGraph = _devkit.readCachedProjectGraph.call(void 0, );
const projectJsonPath = _chunk4D3WT42Ncjs.joinPaths.call(void 0, config.workspaceRoot, options.projectRoot, "project.json");
if (!_fs.existsSync.call(void 0, projectJsonPath)) {
throw new Error("Cannot find project.json configuration");
}
const projectJsonContent = await _promises.readFile.call(void 0, projectJsonPath, "utf8");
const projectJson = JSON.parse(projectJsonContent);
const projectName = projectJson.name;
const packageJsonPath = _chunk4D3WT42Ncjs.joinPaths.call(void 0, config.workspaceRoot, options.projectRoot, "package.json");
if (!_fs.existsSync.call(void 0, packageJsonPath)) {
throw new Error("Cannot find package.json configuration");
}
const packageJsonContent = await _promises.readFile.call(void 0, packageJsonPath, "utf8");
const packageJson = JSON.parse(packageJsonContent);
let tsconfig = options.tsconfig;
if (!tsconfig) {
tsconfig = _chunk4D3WT42Ncjs.joinPaths.call(void 0, options.projectRoot, "tsconfig.json");
}
if (!tsconfig.startsWith(config.workspaceRoot)) {
tsconfig = _chunk4D3WT42Ncjs.joinPaths.call(void 0, config.workspaceRoot, tsconfig);
}
if (!_fs.existsSync.call(void 0, tsconfig)) {
throw new Error("Cannot find tsconfig.json configuration");
}
let sourceRoot = projectJson.sourceRoot;
if (!sourceRoot) {
sourceRoot = _chunk4D3WT42Ncjs.joinPaths.call(void 0, options.projectRoot, "src");
}
if (!_fs.existsSync.call(void 0, sourceRoot)) {
throw new Error("Cannot find sourceRoot directory");
}
const result = _buildablelibsutils.calculateProjectBuildableDependencies.call(void 0, void 0, projectGraph, config.workspaceRoot, projectName, process.env.NX_TASK_TARGET_TARGET || "build", process.env.NX_TASK_TARGET_CONFIGURATION || "production", true);
let dependencies = result.dependencies;
const tsLibDependency = _js.getHelperDependency.call(void 0, _js.HelperDependency.tsc, tsconfig, dependencies, projectGraph, true);
if (tsLibDependency) {
dependencies = dependencies.filter((deps) => deps.name !== tsLibDependency.name);
dependencies.push(tsLibDependency);
}
const name = options.name || projectName;
const entries = _nullishCoalesce(options.entry, () => ( [
sourceRoot
]));
const resolvedOptions = {
...options,
name,
config,
projectRoot: options.projectRoot,
sourceRoot,
projectName,
tsconfig,
platform: options.platform || "neutral",
generatePackageJson: true,
clean: false,
entries: entries.reduce((ret, entry) => {
let entryPath = entry.replace(options.projectRoot, "");
while (entryPath.startsWith(".")) {
entryPath = entryPath.substring(1);
}
while (entryPath.startsWith("/")) {
entryPath = entryPath.substring(1);
}
const outDir = _chunk4D3WT42Ncjs.joinPaths.call(void 0, _path.relative.call(void 0, _chunk4D3WT42Ncjs.joinPaths.call(void 0, config.workspaceRoot, options.projectRoot), config.workspaceRoot), outputPath, "dist");
ret.push({
name: `${name}-esm`,
builder: "mkdist",
input: `./${entryPath}`,
outDir,
declaration: options.emitTypes !== false ? "compatible" : false,
format: "esm",
ext: "mjs"
});
ret.push({
name: `${name}-cjs`,
builder: "mkdist",
input: `./${entryPath}`,
outDir,
declaration: options.emitTypes !== false ? "compatible" : false,
format: "cjs",
ext: "cjs"
});
return ret;
}, []),
declaration: options.emitTypes !== false ? "compatible" : false,
failOnWarn: false,
sourcemap: _nullishCoalesce(options.sourcemap, () => ( !!options.debug)),
outDir: outputPath,
parallel: true,
externals: options.external,
dependencies: [],
peerDependencies: [],
devDependencies: [],
hooks: {},
alias: {},
replace: {},
rollup: {
replace: {},
alias: {},
json: {},
commonjs: {
sourceMap: _nullishCoalesce(options.sourcemap, () => ( true))
},
emitCJS: true,
cjsBridge: true,
dts: {
respectExternal: true,
tsconfig
},
output: {
banner: options.banner || `
// \u26A1 Built by Storm Software
`,
footer: options.footer
},
resolve: {
preferBuiltins: true,
extensions: [
".tsx",
".ts",
".cts",
".mts",
".jsx",
".js",
".cjs",
".mjs",
".css",
".json"
]
},
esbuild: {
minify: _nullishCoalesce(options.minify, () => ( !options.debug)),
sourceMap: _nullishCoalesce(options.sourcemap, () => ( !!options.debug)),
splitting: options.splitting !== false,
treeShaking: options.treeShaking !== false,
platform: options.platform || "neutral",
color: true,
logLevel: config.logLevel === _chunk4D3WT42Ncjs.LogLevelLabel.FATAL ? _chunk4D3WT42Ncjs.LogLevelLabel.ERROR : _chunk4D3WT42Ncjs.isVerbose.call(void 0, ) ? "verbose" : config.logLevel
}
}
};
dependencies = dependencies.filter((dep) => dep.node.type === "npm" || dep.node.type === "lib" || dep.node.type === "app");
if (dependencies.length > 0) {
resolvedOptions.dependencies = dependencies.map((dep) => dep.name);
}
if (packageJson.devDependencies) {
resolvedOptions.devDependencies = Object.keys(packageJson.devDependencies);
}
if (packageJson.peerDependencies) {
resolvedOptions.peerDependencies = Object.keys(packageJson.peerDependencies);
}
if (options.rollup) {
let rollup = {};
if (typeof options.rollup === "string") {
const rollupFile = await _chunkKV76QDPTcjs.loadConfig.call(void 0, options.rollup);
if (rollupFile) {
rollup = rollupFile;
}
} else {
rollup = options.rollup;
}
resolvedOptions.rollup = _defu2.default.call(void 0, _nullishCoalesce(resolvedOptions.rollup, () => ( {})), rollup);
}
resolvedOptions.hooks = {
"rollup:options": /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, async (ctx, opts) => {
if (options.plugins && options.plugins.length > 0) {
_chunk4D3WT42Ncjs.writeDebug.call(void 0, ` \u{1F9E9} Found ${options.plugins.length} plugins in provided build options`, config);
opts.plugins = options.plugins;
} else {
_chunk4D3WT42Ncjs.writeDebug.call(void 0, ` \u{1F9E9} No plugins found in provided build options, using default plugins`, config);
opts.plugins = await Promise.all([
_chunkBN66ODNOcjs.analyzePlugin.call(void 0, resolvedOptions),
_chunkKV76QDPTcjs.tscPlugin.call(void 0, resolvedOptions),
_chunkWCQ3HMVKcjs.onErrorPlugin.call(void 0, resolvedOptions)
]);
}
}, "rollup:options"),
"mkdist:entry:options": /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, async (ctx, entry, opts) => {
opts.esbuild ||= {};
opts.esbuild.platform ??= resolvedOptions.platform;
opts.esbuild.minify ??= _nullishCoalesce(resolvedOptions.minify, () => ( !resolvedOptions.debug));
opts.esbuild.sourcemap ??= _nullishCoalesce(resolvedOptions.sourcemap, () => ( !!options.debug));
if (options.loaders) {
if (typeof options.loaders === "function") {
opts.loaders = await Promise.resolve(options.loaders(ctx, entry, opts));
} else {
opts.loaders = options.loaders;
}
}
}, "mkdist:entry:options")
};
stopwatch();
return resolvedOptions;
}
_chunkBGYQAVKQcjs.__name.call(void 0, resolveOptions, "resolveOptions");
var addPackageJsonExport = /* @__PURE__ */ _chunkBGYQAVKQcjs.__name.call(void 0, (file, type = "module", sourceRoot, projectRoot) => {
let root = sourceRoot.replace(projectRoot, "");
while (root.startsWith(".")) {
root = root.substring(1);
}
while (root.startsWith("/")) {
root = root.substring(1);
}
let entry = file.replaceAll("\\", "/").replace(sourceRoot, "");
while (entry.startsWith(".")) {
entry = entry.substring(1);
}
while (entry.startsWith("/")) {
entry = entry.substring(1);
}
return {
import: {
types: `./dist/${entry}.d.ts`,
default: `./dist/${entry}.mjs`
},
require: {
types: `./dist/${entry}.d.ts`,
default: `./dist/${entry}.cjs`
},
default: {
types: `./dist/${entry}.d.ts`,
default: type === "commonjs" ? `./dist/${entry}.cjs` : `./dist/${entry}.mjs`
}
};
}, "addPackageJsonExport");
async function generatePackageJson(options) {
if (options.generatePackageJson !== false && _fs.existsSync.call(void 0, _chunk4D3WT42Ncjs.joinPaths.call(void 0, options.projectRoot, "package.json"))) {
_chunk4D3WT42Ncjs.writeDebug.call(void 0, " \u270D\uFE0F Writing package.json file", options.config);
const stopwatch = _chunk4D3WT42Ncjs.getStopwatch.call(void 0, "Write package.json file");
const packageJsonPath = _chunk4D3WT42Ncjs.joinPaths.call(void 0, options.projectRoot, "project.json");
if (!_fs.existsSync.call(void 0, packageJsonPath)) {
throw new Error("Cannot find package.json configuration");
}
const packageJsonContent = await _promises.readFile.call(void 0, _chunk4D3WT42Ncjs.joinPaths.call(void 0, options.config.workspaceRoot, options.projectRoot, "package.json"), "utf8");
if (!packageJsonContent) {
throw new Error("Cannot find package.json configuration file");
}
let packageJson = JSON.parse(packageJsonContent);
packageJson = await addPackageDependencies(options.config.workspaceRoot, options.projectRoot, options.projectName, packageJson);
packageJson = await addWorkspacePackageJsonFields(options.config, options.projectRoot, options.sourceRoot, options.projectName, false, packageJson);
packageJson.exports ??= {};
await Promise.all(options.entries.reduce((ret, entry) => {
let entryPath = typeof entry === "string" ? entry : entry.input;
entryPath = entryPath.replaceAll("\\", "/");
while (entryPath.startsWith(".")) {
entryPath = entryPath.substring(1);
}
while (entryPath.startsWith("/")) {
entryPath = entryPath.substring(1);
}
entryPath = `./${_chunk4D3WT42Ncjs.joinPaths.call(void 0, options.projectRoot, entryPath)}`;
if (!ret.includes(entryPath)) {
ret.push(entryPath);
}
return ret;
}, []).map(async (entryPath) => {
const files = await new (0, _glob.Glob)("**/*.{ts,tsx}", {
absolute: false,
cwd: entryPath,
root: entryPath
}).walk();
files.forEach((file) => {
addPackageJsonExport(file, packageJson.type, options.sourceRoot, options.projectRoot);
const split = file.split(".");
split.pop();
const entry = split.join(".").replaceAll("\\", "/");
packageJson.exports[`./${entry}`] ??= addPackageJsonExport(entry, packageJson.type, options.sourceRoot, options.projectRoot);
});
}));
packageJson.main ??= "./dist/index.cjs";
packageJson.module ??= "./dist/index.mjs";
packageJ