locale_sheet 0.2.0
locale_sheet: ^0.2.0 copied to clipboard
CLI and library that converts Excel localization sheets into ARB and other formats.
locale_sheet #
README (English) | README (日本語)
locale_sheet is a lightweight Dart CLI and library that treats an Excel spreadsheet as a single source of truth and converts localization strings into multiple output formats (currently: ARB).
Quick Start #
- Add the dependency to your
pubspec.yaml:
dev_dependencies:
locale_sheet: ^0.2.0
- Install dependencies and run the CLI:
dart pub get
dart run locale_sheet export --input ./example/sample.xlsx --format arb --out ./lib/l10n --sheet-name Sheet1 --default-locale en
Notes:
- The
--default-localeoption (short-d) specifies the locale to be used as the default language. - If
--default-localeis omitted, the CLI will useenif present in the sheet; otherwise it uses the first locale column.
- Programmatic usage (minimal):
import 'package:args/command_runner.dart';
import 'package:locale_sheet/locale_sheet.dart';
void main() async {
final runner = CommandRunner<int>('locale_sheet', 'programmatic runner')
..addCommand(ExportCommand());
// Programmatic invocation (with default-locale):
await runner.run([
'export',
'--input',
'path/to/file.xlsx',
'--out',
'./lib/l10n',
'--default-locale',
'en',
]);
}
Features #
- Parses Excel (.xlsx) into an internal model
- Exports to ARB format (keys are sorted alphabetically)
- Available as both a CLI and a library
Usage #
-
CLI options:
--input/-i: Path to the input XLSX file (required)--format: Output format (e.g.arb)--out/-o: Output directory (default:.)--default-locale/-d: Specifies the locale to be used as the default language. If specified and the locale is not present in the sheet, the command exits with code64. If omitted, the CLI usesenif present, otherwise the first locale column.--sheet-name: Specifies the name of the sheet to convert. If omitted, the first sheet in the file is used. Sheet names are case-sensitive (Sheet1andsheet1are treated as different sheets) and only a single sheet name may be provided. If the specified sheet does not exist, parsing will fail and the command will exit with an error. This option is honored by all exporters.
-
Main public API:
convertExcelToArb({required String inputPath, required String outDir, ExcelParser? parser, LocalizationExporter? exporter, String defaultLocale = 'en', String? sheetName})convertExcelBytesToArb(Uint8List bytes, LocalizationExporter exporter, String outDir, {ExcelParser? parser, String defaultLocale = 'en', String? sheetName})ExportCommand— can be registered with aCommandRunnerto run the CLI programmatically.
Both helper functions accept an optional sheetName parameter. When provided that sheet name is parsed; when null (or omitted) the first sheet in the workbook is used. If the specified sheet is not present a SheetNotFoundException is thrown (the CLI prints available sheets and exits with code 64).
Examples #
See the example/ directory for sample XLSX files and example usage.
Exit Codes & Error Handling #
64— argument error / UsageException1— runtime error (file I/O, parsing errors, etc.)
Testing & Coverage #
Run unit tests with:
dart test
Generate coverage using the bundled script:
bash scripts/coverage.sh
Contributing #
- Format code:
dart format . - Add/update tests:
dart test - Update coverage:
bash scripts/coverage.sh
License #
MIT