Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

22 changes: 17 additions & 5 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,22 +3,34 @@
"version": "0.2.1",
"description": "Modern TypeScript API for accessing the complete Hebrew Bible (Tanach) text",
"type": "module",
"main": "./dist/tanach.cjs.js",
"module": "./dist/tanach.es.js",
"main": "./dist/index.cjs",
"module": "./dist/index.js",
"types": "./dist/index.d.ts",
"exports": {
".": {
"import": "./dist/tanach.es.js",
"require": "./dist/tanach.cjs.js",
"import": "./dist/index.js",
"require": "./dist/index.cjs",
"types": "./dist/index.d.ts"
},
"./preferred": {
"import": "./dist/preferred.js",
"require": "./dist/preferred.cjs",
"types": "./dist/preferred.d.ts"
},
"./dynamic": {
"import": "./dist/dynamic.js",
"require": "./dist/dynamic.cjs",
"types": "./dist/dynamic.d.ts"
}
},
"files": [
"dist"
],
"scripts": {
"dev": "vite",
"build": "tsc && vite build",
"generate:preferred": "tsx scripts/generate-preferred-with-text.ts",
"generate:books": "tsx scripts/generate-book-data.ts",
"build": "vite build && tsc --emitDeclarationOnly && npx tsx scripts/generate-book-data.ts",
"test": "vitest run",
"test:watch": "vitest",
"test:coverage": "vitest run --coverage",
Expand Down
36 changes: 36 additions & 0 deletions scripts/generate-book-data.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
/**
* Script to split data.ts into per-book JSON files.
* These files can be served as static assets and fetched at runtime
* by the dynamic entry point, avoiding bundling the full 6+ MB dataset.
*
* Usage: npx tsx scripts/generate-book-data.ts
*
* Output: dist/books/<bookName>.json for each of the 24 books
*/
import { data } from '../src/data.js';
import { writeFileSync, mkdirSync } from 'fs';
import { resolve, dirname } from 'path';
import { fileURLToPath } from 'url';

const __filename = fileURLToPath(import.meta.url);
const __dirname = dirname(__filename);
const booksDir = resolve(__dirname, '../dist/books');

mkdirSync(booksDir, { recursive: true });

const bookNames: string[] = [];

for (const [bookName, bookData] of Object.entries(data)) {
const outputPath = resolve(booksDir, `${bookName}.json`);
writeFileSync(outputPath, JSON.stringify(bookData), 'utf-8');

const stats = JSON.stringify(bookData).length;
console.log(` ${bookName}.json - ${(stats / 1024).toFixed(1)} KB`);
bookNames.push(bookName);
}

// Write a manifest file listing all books
const manifestPath = resolve(booksDir, '_manifest.json');
writeFileSync(manifestPath, JSON.stringify(bookNames), 'utf-8');

console.log(`\nGenerated ${bookNames.length} book files + manifest in dist/books/`);
105 changes: 105 additions & 0 deletions scripts/generate-preferred-with-text.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,105 @@
/**
* Script to generate preferred verses data with embedded verse text.
* This allows consumers to use preferred verses without importing the full Tanach data (6.3 MB).
*
* Usage: npx tsx scripts/generate-preferred-with-text.ts
*/
import { data } from '../src/data.js';
import { preferredVerses } from '../src/preferred-verses.js';

interface EnrichedVerse {
startLetter: string;
endLetter: string;
book: string;
chapter: number;
verse: number;
text: string;
bookHebrew: string;
bookEnglish: string;
notes?: string;
}

const enriched: EnrichedVerse[] = [];

for (const pv of preferredVerses) {
const bookData = data[pv.book];
if (!bookData) {
console.warn(`Book not found: ${pv.book}`);
continue;
}

const chapterData = bookData.chapters[pv.chapter];
if (!chapterData) {
console.warn(`Chapter not found: ${pv.book} ${pv.chapter}`);
continue;
}

const verseData = chapterData.find(([v]) => v === pv.verse);
if (!verseData) {
console.warn(`Verse not found: ${pv.book} ${pv.chapter}:${pv.verse}`);
continue;
}

const entry: EnrichedVerse = {
startLetter: pv.startLetter,
endLetter: pv.endLetter,
book: pv.book,
chapter: pv.chapter,
verse: pv.verse,
text: verseData[1],
bookHebrew: bookData.meta.he,
bookEnglish: bookData.meta.en,
};

if (pv.notes) {
entry.notes = pv.notes;
}

enriched.push(entry);
}

// Generate the TypeScript file
const output = `/**
* Preferred verses with embedded text for lightweight imports.
* This file is auto-generated by scripts/generate-preferred-with-text.ts
* DO NOT EDIT MANUALLY - run: npx tsx scripts/generate-preferred-with-text.ts
*
* This module contains ${enriched.length} preferred verses with their full text,
* allowing consumers to look up preferred verses without importing the full Tanach data (6+ MB).
*/

export interface PreferredVerseWithText {
/** Starting letter of the name */
startLetter: string;
/** Ending letter of the name */
endLetter: string;
/** Book name (transliterated) */
book: string;
/** Chapter number */
chapter: number;
/** Verse number */
verse: number;
/** Full Hebrew verse text */
text: string;
/** Hebrew book name */
bookHebrew: string;
/** English book name */
bookEnglish: string;
/** Notes or alternative information */
notes?: string;
}

export const preferredVersesWithText: PreferredVerseWithText[] = ${JSON.stringify(enriched, null, 2)};
`;

// Write to src/preferred-verses-data.ts
import { writeFileSync } from 'fs';
import { resolve, dirname } from 'path';
import { fileURLToPath } from 'url';

const __filename = fileURLToPath(import.meta.url);
const __dirname = dirname(__filename);
const outputPath = resolve(__dirname, '../src/preferred-verses-data.ts');
writeFileSync(outputPath, output, 'utf-8');

console.log(`Generated ${outputPath} with ${enriched.length} enriched preferred verses.`);
Loading
Loading