-
-
Notifications
You must be signed in to change notification settings - Fork 15
Expand file tree
/
Copy pathADFormatter.php
More file actions
41 lines (33 loc) · 1.04 KB
/
ADFormatter.php
File metadata and controls
41 lines (33 loc) · 1.04 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<?php
declare(strict_types=1);
namespace Brick\Postcode\Formatter;
use Brick\Postcode\CountryPostcodeFormatter;
use function preg_match;
use function str_starts_with;
use function substr;
/**
* Validates and formats postcodes in Andorra.
*
* Postcodes consist of the letters AD, followed by 3 digits, without separator.
* This formatter accepts the 3 digits with and without the AD prefix, and always outputs with the prefix.
*
* @see https://en.wikipedia.org/wiki/List_of_postal_codes
* @see https://en.wikipedia.org/wiki/Postal_codes_in_Andorra
*/
final class ADFormatter implements CountryPostcodeFormatter
{
public function hint(): string
{
return 'Postcodes consist of the letters AD, followed by 3 digits, without separator.';
}
public function format(string $postcode): ?string
{
if (str_starts_with($postcode, 'AD')) {
$postcode = substr($postcode, 2);
}
if (preg_match('/^[0-9]{3}$/', $postcode) !== 1) {
return null;
}
return 'AD' . $postcode;
}
}