PSA/ee/temporal-workflows/scripts/add-js-extensions.cjs
Hermes 284313f908
Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Initial import of AlgaPSA codebase from PSA server
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz

Source: /opt/alga-psa on psa.joliet.tech
2026-06-22 16:12:17 -05:00

76 lines
2.0 KiB
JavaScript

const fs = require("fs");
const path = require("path");
/**
* Script to add .js extensions to import/export statements in compiled JavaScript files
* This fixes ES module resolution issues in Node.js
*/
function addJsExtensions(filePath) {
try {
const content = fs.readFileSync(filePath, "utf8");
// Regex to match import/export statements without .js extensions
// Matches: from "./some/path" or from '../some/path' but not from 'external-package'
const importExportRegex =
/(import|export)(.*?from\s+['"])(\.\.?\/[^'"]*?)(?<!\.js)(['"])/g;
const updatedContent = content.replace(importExportRegex, "$1$2$3.js$4");
if (content !== updatedContent) {
fs.writeFileSync(filePath, updatedContent, "utf8");
console.log(`Fixed imports in: ${filePath}`);
return true;
}
return false;
} catch (error) {
console.error(`Error processing ${filePath}:`, error.message);
return false;
}
}
function processDirectory(dirPath) {
try {
const files = fs.readdirSync(dirPath);
let fixedCount = 0;
for (const file of files) {
const fullPath = path.join(dirPath, file);
const stat = fs.statSync(fullPath);
if (stat.isDirectory()) {
fixedCount += processDirectory(fullPath);
} else if (file.endsWith(".js") && !file.endsWith(".d.ts")) {
if (addJsExtensions(fullPath)) {
fixedCount++;
}
}
}
return fixedCount;
} catch (error) {
console.error(`Error processing directory ${dirPath}:`, error.message);
return 0;
}
}
function main() {
const distDir = path.join(__dirname, "..", "dist");
if (!fs.existsSync(distDir)) {
console.error("Dist directory does not exist. Run build first.");
process.exit(1);
}
console.log("Adding .js extensions to compiled imports...");
const fixedCount = processDirectory(distDir);
console.log(`Fixed ${fixedCount} files.`);
}
if (require.main === module) {
main();
}
module.exports = { addJsExtensions, processDirectory };