{"id":18717351,"url":"https://github.com/diego-ninja/sorter","last_synced_at":"2025-11-10T12:30:20.047Z","repository":{"id":172852392,"uuid":"649867370","full_name":"diego-ninja/sorter","owner":"diego-ninja","description":"Sort arrays and objects by multiple fields with unicode characters","archived":false,"fork":false,"pushed_at":"2024-04-18T09:35:50.000Z","size":284,"stargazers_count":0,"open_issues_count":9,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2024-12-28T10:38:06.502Z","etag":null,"topics":["satis-enabled"],"latest_commit_sha":null,"homepage":"","language":"PHP","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"bsd-3-clause","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/diego-ninja.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null},"funding":{"ko_fi":"diegoninja","custom":["https://paypal.me/diegorin","https://www.buymeacoffee.com/diegoninja"]}},"created_at":"2023-06-05T20:16:22.000Z","updated_at":"2024-07-01T12:32:55.000Z","dependencies_parsed_at":"2024-01-17T17:19:27.373Z","dependency_job_id":"2e42ad60-c50d-42b1-85cd-a4a01559af59","html_url":"https://github.com/diego-ninja/sorter","commit_stats":null,"previous_names":["diego-ninja/sorter"],"tags_count":2,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diego-ninja%2Fsorter","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diego-ninja%2Fsorter/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diego-ninja%2Fsorter/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diego-ninja%2Fsorter/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/diego-ninja","download_url":"https://codeload.github.com/diego-ninja/sorter/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":239581796,"owners_count":19662958,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["satis-enabled"],"created_at":"2024-11-07T13:15:53.574Z","updated_at":"2025-11-10T12:30:20.008Z","avatar_url":"https://github.com/diego-ninja.png","language":"PHP","funding_links":["https://ko-fi.com/diegoninja","https://paypal.me/diegorin","https://www.buymeacoffee.com/diegoninja"],"categories":[],"sub_categories":[],"readme":"# Sorter\n\n[![Latest Version on Packagist](https://img.shields.io/packagist/v/diego-ninja/sorter.svg?style=flat)](https://packagist.org/packages/diego-ninja/sorter)\n[![Total Downloads](https://img.shields.io/packagist/dt/diego-ninja/sorter.svg?style=flat\u0026color=blue)](https://packagist.org/packages/diego-ninja/sorter)\n![PHP Version](https://img.shields.io/packagist/php-v/diego-ninja/sorter.svg?style=flat)\n[![wakatime](https://wakatime.com/badge/user/bd65f055-c9f3-4f73-92aa-3c9810f70cc3/project/faea46b2-0902-4284-ab88-d971fe3b3390.svg)](https://wakatime.com/badge/user/bd65f055-c9f3-4f73-92aa-3c9810f70cc3/project/faea46b2-0902-4284-ab88-d971fe3b3390)\n[![License](https://poser.pugx.org/diego-ninja/sorter/license.svg)](https://packagist.org/packages/diego-ninja/sorter)\n[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/diego-ninja/sorter/badges/quality-score.png?b=main)](https://scrutinizer-ci.com/g/diego-ninja/sorter/?branch=main)\n[![Build Status](https://scrutinizer-ci.com/g/diego-ninja/sorter/badges/build.png?b=main)](https://scrutinizer-ci.com/g/diego-ninja/sorter/build-status/main)\n[![Code Coverage](https://scrutinizer-ci.com/g/diego-ninja/sorter/badges/coverage.png?b=main)](https://scrutinizer-ci.com/g/diego-ninja/sorter/?branch=main)\n\n1. [Installation](#installation)\n2. [Usage](#usage)\n    - [Sort using default settings](#sort-using-default-settings)\n    - [Sort using a specific locale](#sort-using-a-specific-locale)\n    - [Sorting arrays keeping the keys intact](#sorting-arrays-keeping-the-keys-intact)\n    - [Sorting complex objects](#sorting-complex-objects)\n    - [Customizing](#customizing)\n3. [Contributing](#contributing)\n4. [Authors](#authors)\n\n## Installation\n\nInstallation is done using [Composer](https://getcomposer.org/):\n\n    composer require diego-ninja/sorter\n\nYou can test the library using `phpunit` by running the following command (assuming that you have `phpunit` command available):\n\n    phpunit ./tests\n\n\n## Usage\n\n### Sort using default settings\n\n```php\nuse Ninja\\Sorter\\Sorter;\n\n$data = array('ccc', 'aaa', 'bbb');\n$sorter = new Sorter();\n$data = $sorter-\u003esort($data);\nprint_r($data); \n\n// prints array('aaa', 'bbb', 'ccc');\n```\n### Sort using a specific locale\n\n`UnicodeCIComparator` (case-insensitive) comparator is the **default comparator** used in this library and by default during creation it uses current system locale (from php.ini).\n\n\u003e It's worth to notice that when using this comparator, it may produce **odd-looking results for numbers**. For example `-1000` is greater than `-100`.\n\u003e If you want to compare numbers by their real value, use `NumericComparator`.\n\n```php\n\nuse Ninja\\Sorter\\Comparator\\UnicodeCIComparator;\nuse Ninja\\Sorter\\Sorter;\nuse Ninja\\Sorter\\Strategy\\SimpleSortStrategy;\n\n$strategy = new SimpleSortStrategy();\n$strategy-\u003esetComparator(new UnicodeCIComparator('pl_PL'));\n$sorter = new Sorter($strategy);\n$sorter-\u003esort(...);\n\n```\n\n### Sorting arrays keeping the keys intact\n\n```php\n\nuse Ninja\\Sorter\\Sorter;\nuse Ninja\\Sorter\\Strategy\\SimpleSortStrategy;\n\n$array = array(0 =\u003e 'a', 1 =\u003e 'c', 2 =\u003e 'b');\n\n$strategy = new SimpleSortStrategy();\n$strategy-\u003esetPreserveKeys(true);\n\n$sorter = new Sorter($strategy);\n$sorter-\u003esort($array);\n\nprint_r($array); // prints array(0 =\u003e 'a', 2 =\u003e 'b', 1 =\u003e 'c')\n```\n\n### Sorting complex objects\n\n```php\n\nuse Ninja\\Sorter\\Sorter;\nuse Ninja\\Sorter\\Strategy\\ComplexSortStrategy;\n\n$data = array(\n    (object)array('name' =\u003e 'Ann', 'position' =\u003e '3', 'rating' =\u003e '3'),\n    (object)array('name' =\u003e 'Ann', 'position' =\u003e '2', 'rating' =\u003e '2'),\n    (object)array('name' =\u003e 'Ann', 'position' =\u003e '2', 'rating' =\u003e '1'),\n    (object)array('name' =\u003e 'Betty', 'position' =\u003e '1', 'rating' =\u003e '2'),\n);\n\n$strategy = new ComplexSortStrategy();\n$strategy\n    -\u003esetSortOrder(Sorter::ASC)\n    -\u003esortBy('position')                                    // sort by position\n    -\u003esortBy('name')                                        // sort by name if position is equal\n    -\u003esortBy(function($object){return $object-\u003erating})     // sort by rating if name is equal\n;\n\n$sorter = new src\\Sorter();\n$data = $sorter-\u003esetStrategy($strategy)-\u003esort($data);\n\nprint_r($data);\n\n//    prints:\n//\n//    Array\n//    (\n//        [0] =\u003e stdClass Object\n//        (\n//            [name] =\u003e Betty\n//            [position] =\u003e 1\n//            [rating] =\u003e 2\n//        )\n//\n//        [1] =\u003e stdClass Object\n//        (\n//            [name] =\u003e Ann\n//            [position] =\u003e 2\n//            [rating] =\u003e 1\n//        )\n//\n//        [2] =\u003e stdClass Object\n//        (\n//            [name] =\u003e Ann\n//            [position] =\u003e 2\n//            [rating] =\u003e 2\n//        )\n//\n//        [3] =\u003e stdClass Object\n//        (\n//            [name] =\u003e Ann\n//            [position] =\u003e 3\n//            [rating] =\u003e 3\n//        )\n//    )\n\n```\n\n### Customizing\n\nYou can create your own strategies for more complicated data sets.\nProvided `ComplexSortStrategy` should cover most of your needs, and if it does not, try using your own comparators.\nYou can replace default comparators for a whole strategy or define your own only for specific properties:\n\n```php\n\n$strategy\n    -\u003esetSortOrder(Sorter::ASC)\n    -\u003esortBy('position')\n    -\u003esortBy('name', Sorter::DESC, new MyOwnPropertyComparator())\n    -\u003esortBy('rating')\n;\n\n// or set your own comparator\n\n$strategy-\u003esetComparator(new MyOwnPropertyComparator());\n\n```\n## Contributing\n\nAll code contributions must go through a pull request.  \nFork the project, create a feature branch, and send me a pull request.\n\n## Authors\n\nThis library was inspired by [https://github.com/graze/sort](https://github.com/graze/sort).\n\n- Jacek Kobus - \u003ckobus.jacek@gmail.com\u003e\n- Diego Rin - \u003cyosoy@diego.ninja\u003e\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdiego-ninja%2Fsorter","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdiego-ninja%2Fsorter","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdiego-ninja%2Fsorter/lists"}