PHPackages                             valksor/php-functions-latvian - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Localization &amp; i18n](/categories/localization)
4. /
5. valksor/php-functions-latvian

ActiveLibrary[Localization &amp; i18n](/categories/localization)

valksor/php-functions-latvian
=============================

A PHP library providing functions specific to Latvian language and data formats, including Latvian text comparison, sorting according to Latvian alphabet rules, and validation of Latvian personal identification codes

10PHPCI passing

Since Dec 28Pushed 3mo agoCompare

[ Source](https://github.com/valksor/php-functions-latvian)[ Packagist](https://packagist.org/packages/valksor/php-functions-latvian)[ RSS](/packages/valksor-php-functions-latvian/feed)WikiDiscussions master Synced 1mo ago

READMEChangelogDependenciesVersions (1)Used By (0)

Valksor Functions: Latvian
==========================

[](#valksor-functions-latvian)

[![valksor](https://camo.githubusercontent.com/2af5a6a7e5f7da47cd0a924c8b00038f208f45f9b0d5be8d7a497a9808168187/68747470733a2f2f62616467656e2e6e65742f7374617469632f6f72672f76616c6b736f722f677265656e)](https://github.com/valksor)[![BSD-3-Clause](https://camo.githubusercontent.com/72547f8afb6b5ace804caebbf95c3bcbfc027ce9214777bc452f308f3165db01/68747470733a2f2f696d672e736869656c64732e696f2f62616467652f4253442d2d332d2d436c617573652d677265656e3f7374796c653d666c6174)](https://github.com/valksor/php-functions-latvian/blob/master/LICENSE)[![Coverage Status](https://camo.githubusercontent.com/c4591681ee08ec858c4d15fb0ca5d243800ca386028a7d0f43be01d27edc3575/68747470733a2f2f636f766572616c6c732e696f2f7265706f732f6769746875622f76616c6b736f722f7068702d66756e6374696f6e732d6c61747669616e2f62616467652e7376673f6272616e63683d6d6173746572)](https://coveralls.io/github/valksor/php-functions-latvian?branch=master)[![php](https://camo.githubusercontent.com/77da2f7bbc049873edb2d1045a756d7a32e3ba50440a8e0e76a9109f62f0771b/68747470733a2f2f62616467656e2e6e65742f7374617469632f7068702f2533453d382e342f707572706c65)](https://www.php.net/releases/8.4/en.php)

A PHP library providing functions specific to Latvian language and data formats, including Latvian text comparison, sorting according to Latvian alphabet rules, and validation of Latvian personal identification codes.

Installation
------------

[](#installation)

Install the package via Composer:

```
composer require valksor/php-functions-latvian
```

Requirements
------------

[](#requirements)

PHP 8.4 or higher

Usage
-----

[](#usage)

There are two ways to use this package: via the Functions class or by directly using the traits.

### Using the Functions Class

[](#using-the-functions-class)

The Functions class provides utilities for working with Latvian-specific data and text.

```
use Valksor\Functions\Latvian\Functions;

// Create a new Functions instance
$functions = new Functions();

// Validate a Latvian personal identification code
$isValid = $functions->validatePersonCode('32XXXXXXXXX'); // For new format
$isValid = $functions->validatePersonCode('XXXXXXXXXXX'); // For old format

// Sort an array of names according to Latvian alphabet rules
$names = [
    ['name' => 'Ēriks'],
    ['name' => 'Andris'],
    ['name' => 'Čalis'],
    ['name' => 'Zane'],
];
$functions->sortLatvian($names, 'name');
// Result: Andris, Čalis, Ēriks, Zane

// Compare two strings using Latvian alphabet rules
$result = $functions->compare(['name' => 'Ēriks'], ['name' => 'Andris'], 'name');
// Result: positive integer (Ēriks comes after Andris in Latvian alphabet)
```

### Using Traits Directly

[](#using-traits-directly)

Alternatively, you can use the traits directly in your own classes:

```
use Valksor\Functions\Latvian\Traits\_Compare;
use Valksor\Functions\Latvian\Traits\_SortLatvian;
use Valksor\Functions\Latvian\Traits\_ValidatePersonCode;

class MyClass
{
    // Import the traits you need
    use _Compare;
    use _SortLatvian;
    use _ValidatePersonCode;

    public function doSomething(): void
    {
        // Validate a Latvian personal identification code
        $isValid = $this->validatePersonCode('32XXXXXXXXX');

        // Sort an array of names according to Latvian alphabet rules
        $names = [
            ['name' => 'Ēriks'],
            ['name' => 'Andris'],
            ['name' => 'Čalis'],
            ['name' => 'Zane'],
        ];
        $this->sortLatvian($names, 'name');

        // Compare two strings using Latvian alphabet rules
        $result = $this->compare(['name' => 'Ēriks'], ['name' => 'Andris'], 'name');
    }
}
```

Note that some traits may depend on other helper traits. For example, the `_ValidatePersonCode` trait uses `_ValidatePersonCodeNew` and `_ValidatePersonCodeOld` internally. The Functions class handles these dependencies for you, but if you use the traits directly, you may need to include these helper traits as well.

Features
--------

[](#features)

For a complete list of all functions available in this package, see [Features](docs/features.md).

Contributing
------------

[](#contributing)

Contributions are welcome!

- Code style requirements (PSR-12)
- Testing requirements for PRs
- One feature per pull request
- Development setup instructions

To contribute to Latvian functions:

1. Fork the repository
2. Create a feature branch (`git checkout -b feature/new-latvian-function`)
3. Implement your function following existing patterns
4. Add comprehensive tests including edge cases
5. Ensure all tests pass and code style is correct
6. Submit a pull request

Security
--------

[](#security)

If you discover any security-related issues, please email us at  instead of using the issue tracker.

Support
-------

[](#support)

- **Documentation**: [Full documentation](https://github.com/valksor/php-valksor)
- **Issues**: [GitHub Issues](https://github.com/valksor/php-valksor/issues) for bug reports and feature requests
- **Discussions**: [GitHub Discussions](https://github.com/orgs/valksor/discussions/categories/php-valksor) for questions and community support

Credits
-------

[](#credits)

- **[Original Author](https://github.com/valksor)** - Creator and maintainer
- **[All Contributors](https://github.com/valksor/php-valksor/graphs/contributors)** - Thank you to all who contributed
- **[Latvian Language Resources](https://www.lv/)** - Latvian language standards and inspiration
- **[Valksor Project](https://github.com/valksor)** - Part of the larger Valksor PHP ecosystem

License
-------

[](#license)

This package is licensed under the [BSD-3-Clause License](LICENSE).

About Valksor
-------------

[](#about-valksor)

This package is part of the [valksor/php-valksor](https://github.com/valksor/php-valksor) project - a comprehensive PHP library and Symfony bundle that provides a collection of utilities, components, and integrations for Symfony applications.

The main project includes:

- Various utility functions and components
- Doctrine ORM tools and extensions
- Symfony bundle for easy configuration
- And much more

If you find this Latvian functions component useful, you might want to check out the full Valksor project for additional tools and utilities that can enhance your Symfony application development.

To install the complete package:

```
composer require valksor/php-valksor
```

###  Health Score

19

—

LowBetter than 10% of packages

Maintenance57

Moderate activity, may be stable

Popularity2

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity12

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

### Community

Maintainers

![](https://www.gravatar.com/avatar/c4db85e32518c5a6caa2fd625032a2b016ef42d60cf8a101c165cc5c0048b221?d=identicon)[k0d3r1s](/maintainers/k0d3r1s)

---

Top Contributors

[![k0d3r1s](https://avatars.githubusercontent.com/u/38725938?v=4)](https://github.com/k0d3r1s "k0d3r1s (34 commits)")

### Embed Badge

![Health badge](/badges/valksor-php-functions-latvian/health.svg)

```
[![Health](https://phpackages.com/badges/valksor-php-functions-latvian/health.svg)](https://phpackages.com/packages/valksor-php-functions-latvian)
```

###  Alternatives

[symfony/translation

Provides tools to internationalize your application

6.6k836.5M2.0k](/packages/symfony-translation)[nesbot/carbon

An API extension for DateTime that supports 281 different languages.

169661.4M4.8k](/packages/nesbot-carbon)[joedixon/laravel-translation

A tool for managing all of your Laravel translations

717911.4k11](/packages/joedixon-laravel-translation)[illuminate/translation

The Illuminate Translation package.

6936.4M491](/packages/illuminate-translation)[lajax/yii2-translate-manager

Translation management extension for Yii 2

227578.8k13](/packages/lajax-yii2-translate-manager)[larswiegers/laravel-translations-checker

Make sure your laravel translations are checked and are included in all languages.

256423.2k2](/packages/larswiegers-laravel-translations-checker)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
