salarmehr/cosmopolitan

Super efficient application localisation

Maintainers

Package info

github.com/salarmehr/cosmopolitan

Homepage

Documentation

Type:internationalisation

pkg:composer/salarmehr/cosmopolitan

Statistics

Installs: 11 128

Dependents: 0

Suggesters: 0

Stars: 48

Open Issues: 0

v3.0.0 2026-06-15 13:15 UTC

This package is auto-updated.

Last update: 2026-06-18 01:02:00 UTC


README

Turn raw values — numbers, amounts, dates, codes — into the polished text your users actually read. Effortlessly: no formatting code to write, no duplication to maintain.

Your app stores machine values — a number, a timestamp, a country code. Your users want to read them the way their part of the world writes them. Cosmo does that conversion in a single call, so you stop scattering ad-hoc formatting logic across your codebase and delete the near-duplicate code that collects around it. It's dead simple, production-ready, and fast.

You don't need a multi-language app to benefit — point Cosmo at a single region and everything just comes out right. The same one line already scales to every language, script, calendar and time zone if you ever grow, with no data to ship or maintain.

  ┌─ iphone.json ───────────────────┐     ┌─ locale ──────────────────┐
  │ {                               │     │                           │
  │   "model":    "iPhone 17 Pro",  │     │   en_US · en_GB · pt_BR   │
  │   "price":    999,              │     │   zh_CN · ar_SA · hi_IN   │
  │   "speed":    2000,             │     │                           │
  │   "pixels":   1234567,          │     └─────────────┬─────────────┘
  │   "cameras":  3,                │                   │
  │   "released": "2025-09-19"      │                   │
  │ }                               │                   │
  └────────────────┬────────────────┘                   │
                   └─────────────────┬──────────────────┘
                                     ▼
                               ┌───────────┐
                               │   Cosmo   │
                               └─────┬─────┘
                                     ▼
   🇺🇸  United States   ─►  September 19, 2025 · $999.00 · 2,000 MB/s · 1,234,567 · 3 cameras
   🇬🇧  United Kingdom  ─►  19 September 2025 · £999.00 · 2,000 MB/s · 1,234,567 · 3 cameras
   🇧🇷  Brazil          ─►  19 de setembro de 2025 · R$ 999,00 · 2.000 MB/s · 1.234.567 · 3 câmeras
   🇨🇳  China           ─►  2025年9月19日 · ¥999.00 · 2,000 MB/秒 · 1,234,567 · 3 个摄像头
   🇸🇦  Saudi Arabia    ─►  ٢٧ ربيع الأول ١٤٤٧ هـ · ٩٩٩٫٠٠ ر.س. · ٢٬٠٠٠ م.ب/ث · ١٬٢٣٤٬٥٦٧ · ٣ كاميرات
   🇮🇳  India           ─►  19 सितंबर 2025 · ₹999.00 · 2,000 MB/से॰ · 12,34,567 · 3 कैमरे

You pass a locale code; Cosmo decides the rest. There's no currency in the data, yet each region gets its own ($ / £ / R$ / ¥ / ر.س / ). The thousands separator follows local habit — even India's 12,34,567 grouping — Saudi Arabia switches to the Hijri calendar and right-to-left Arabic-Indic digits, and the camera count takes the correct plural form. All automatically.

Cosmo is implemented consistently across five languages — the same concepts, method names and behaviour: JavaScript (docs) · Python (docs) · Java (docs) · .NET / C# · PHP.

📖 Full documentation, API reference and live playground: https://cosmo.miloun.com/?lang=php

Requirements

  • PHP 8.4+ with the intl extension (php -m | grep intl)

Install

composer require salarmehr/cosmopolitan

Quick start

use Miloun\Cosmo\Cosmo;

new Cosmo('es_ES')->money(11000.4, 'EUR');                    // "11.000,40 €"
new Cosmo('tr')->unit('temperature', 'celsius', 26, 'short'); // "26°C"
new Cosmo('en')->percentage(0.2);                             // "20%"
new Cosmo('fa')->language('en');                              // "انگلیسی"

// or the helper function (not autoloaded — include src/helper.php or add it
// to the "files" array in your composer.json)
cosmo('en_AU')->country();                                    // "Australia"

Cosmo is built around the locale — a short language-and-region tag like en_US, de_DE or fa_IR that picks all of these conventions at once. Everything it produces is locale-aware and read straight from ICU/CLDR, so coverage is complete and always current — no locale tables of your own to bundle or keep up to date. Underscore locales (en_AU) and BCP-47 Unicode extensions (fa-IR-u-nu-latn-ca-buddhist) are both accepted. PHP 8.4 lets you call a method directly on new Cosmo(...) without wrapping parentheses.

What you get

  • Locale display names — languages, regions, scripts, calendars and currencies, plus emoji flags and writing direction.
  • Numbers & money — decimals, percentages, currencies (inferred from the region), units, compact notation, scientific, ranges, plus spelled-out and ordinal text.
  • Dates & times — locale formats in any calendar (Gregorian, Persian, Buddhist…), custom ICU patterns, durations, date ranges, and relative times.
  • Text — locale-aware sort and search, word/sentence/grapheme segmentation, case mapping, transliteration and quotation marks.
  • Lists"A, B, and C" conjunctions and disjunctions.
  • MessagesICU MessageFormat (plural, selectordinal, select).
  • Parsing & transforms — the inverse formatters for numbers, money and dates, transliteration, UTS #39 spoof checks, and locale tag expansion.
  • Raw ICU access — resource-bundle lookups for data the high-level methods don't cover.

See the full API reference for every method, the platform notes for ext-intl's binding limits, and resources for ICU/CLDR references.

Development

composer install
vendor/bin/phpunit

Errors

Recoverable problems throw Cosmo\CosmoException (extends \Exception), with InvalidArgumentException and UnsupportedException subclasses — an invalid currency in strict mode, an unsupported unit, an unknown symbol name, an unformattable date, and the like.

License

MIT © Aiden Adrian