From: Raphaƫl Gertz Date: Fri, 13 Jan 2023 02:12:34 +0000 (+0100) Subject: Add string to latin conversion function X-Git-Tag: 0.2.3~2 X-Git-Url: https://git.rapsys.eu/packbundle/commitdiff_plain/6100e3bcd4296f6dab4ea96865f17433f3fc3575?ds=sidebyside;hp=a72cc270c383205b3376abc8665039f8e7e0daf0 Add string to latin conversion function --- diff --git a/Util/SluggerUtil.php b/Util/SluggerUtil.php index 8dc50df..fc3f462 100644 --- a/Util/SluggerUtil.php +++ b/Util/SluggerUtil.php @@ -198,6 +198,31 @@ class SluggerUtil { return trim(preg_replace('/[\/_|+ -]+/', '-', strtolower(preg_replace('/[^a-zA-Z0-9\/_|+ -]/', '', str_replace(['\'', '"'], ' ', iconv('UTF-8', 'ASCII//TRANSLIT', $data))))), '-'); } + /** + * Convert string to latin + * + * @param string $data The data string + * @return ?string The slugged data + */ + function latin(?string $data): ?string { + //With null + if ($data === null) { + //Return null + return $data; + } + + //Use Transliterator if available + if (class_exists('Transliterator')) { + //Convert from any to latin, then to ascii and lowercase + $trans = \Transliterator::create('Any-Latin; Latin-ASCII'); + //Replace every non alphanumeric character by dash then trim dash + return trim($trans->transliterate($data)); + } + + //Convert from utf-8 to ascii + return trim(iconv('UTF-8', 'ASCII//TRANSLIT', $data)); + } + /** * Unshort then unserialize *