1<?php 2 3/** 4 * webtrees: online genealogy 5 * Copyright (C) 2022 webtrees development team 6 * This program is free software: you can redistribute it and/or modify 7 * it under the terms of the GNU General Public License as published by 8 * the Free Software Foundation, either version 3 of the License, or 9 * (at your option) any later version. 10 * This program is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU General Public License for more details. 14 * You should have received a copy of the GNU General Public License 15 * along with this program. If not, see <https://www.gnu.org/licenses/>. 16 */ 17 18declare(strict_types=1); 19 20namespace Fisharebest\Webtrees\Module; 21 22use Fisharebest\Localization\Locale\LocaleHu; 23use Fisharebest\Localization\Locale\LocaleInterface; 24use Illuminate\Database\Query\Builder; 25 26use function mb_substr; 27use function str_starts_with; 28 29/** 30 * Class LanguageHungarian. 31 */ 32class LanguageHungarian extends AbstractModule implements ModuleLanguageInterface 33{ 34 use ModuleLanguageTrait; 35 36 /** 37 * Phone-book ordering of letters. 38 * 39 * @return array<int,string> 40 */ 41 public function alphabet(): array 42 { 43 return ['A', 'Á', 'B', 'C', 'CS', 'D', 'DZ', 'DZS', 'E', 'É', 'F', 'G', 'GY', 'H', 'I', 'Í', 'J', 'K', 'L', 'LY', 'M', 'N', 'NY', 'O', 'Ó', 'Ö', 'Ő', 'P', 'Q', 'R', 'S', 'SZ', 'T', 'TY', 'U', 'Ú', 'Ü', 'Ű', 'V', 'W', 'X', 'Y', 'Z', 'ZS']; 44 } 45 46 /** 47 * One of: 'DMY', 'MDY', 'YMD'. 48 * 49 * @return string 50 */ 51 public function dateOrder(): string 52 { 53 return 'YMD'; 54 } 55 56 /** 57 * Some languages use digraphs and trigraphs. 58 * 59 * @param string $string 60 * 61 * @return string 62 */ 63 public function initialLetter(string $string): string 64 { 65 foreach (['DZS', 'DZ', 'GY', 'LY', 'NY', 'SZ', 'TY', 'ZS'] as $digraph) { 66 if (str_starts_with($string, $digraph)) { 67 return $digraph; 68 } 69 } 70 71 return mb_substr($string, 0, 1); 72 } 73 74 /** 75 * @param string $column 76 * @param string $letter 77 * @param Builder $query 78 * 79 * @return void 80 */ 81 public function initialLetterSQL(string $column, string $letter, Builder $query): void 82 { 83 $query->where($column . ' /*! COLLATE utf8_hungarian_ci */', 'LIKE', '\\' . $letter . '%'); 84 } 85 86 /** 87 * @return LocaleInterface 88 */ 89 public function locale(): LocaleInterface 90 { 91 return new LocaleHu(); 92 } 93} 94