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
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz Source: /opt/alga-psa on psa.joliet.tech
76 lines
2.0 KiB
JavaScript
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 };
|