Nette\String sanitize

- timbulko
 - Člen | 85
 
Zdravím,
nebolo by vhodné vyčleniť časť funkcie webalize a vytvoriť z nej
funkciu sanitize, ktorá by iba odstraňovala diakritiku a
nenahradzovala medzery pomlčkami? Už viac krát som podobnú funkciu
v aplikácií potreboval, no príde mi zbytočné na to vytvárať vlastný
Helper, keďže táto funkcia už v podstate existuje v triede
String, len je začlenená do funkcie webalize.
Vďaka.

- jasir
 - Člen | 746
 
No mě to přijde jako dobrý nápad… Sám mám takovou funkci ve svých helperech, takže užitečné to je. Třeba když sem postneš novou implementaci webalize() a sanitize(), David to pak spíš zapracuje.
Snad jen ten název, nevím
jestli ‚sanitize‘ je typické pojménování odstranění diakritiky, ale
pokud ne, navrhoval bych něco přímočařejšího, jako
convertSpecialChars() nebo něco takového…
BTW: Feature requests by asi mělo být vé fóru pod Vývoj Frameworku
Editoval jasir (29. 6. 2009 11:52)

- timbulko
 - Člen | 85
 
Myslím, že najlepšie by to bolo rozdeliť takto:
<?php
	public static function sanitize($s, $charlist = NULL)
	{
		$s = strtr($s, '`\'"^~', '     ');
		if (ICONV_IMPL === 'glibc') {
			$s = @iconv('UTF-8', 'WINDOWS-1250//TRANSLIT', $s); // intentionally @
			$s = strtr($s, "\xa5\xa3\xbc\x8c\xa7\x8a\xaa\x8d\x8f\x8e\xaf\xb9\xb3\xbe\x9c\x9a\xba\x9d\x9f\x9e\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2"
				."\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf8\xf9\xfa\xfb\xfc\xfd\xfe",
				"ALLSSSSTZZZallssstzzzRAAAALCCCEEEEIIDDNNOOOOxRUUUUYTsraaaalccceeeeiiddnnooooruuuuyt");
		} else {
			$s = @iconv('UTF-8', 'ASCII//TRANSLIT', $s); // intentionally @
		}
		$s = str_replace(array('`', "'", '"', '^', '~'), '', $s);
		$s = preg_replace('#[^a-z0-9' . preg_quote($charlist, '#') . ']+#', ' ', $s);
		$s = trim($s);
		return $s;
	}
	/**
	 * Converts to web safe characters [a-z0-9-] text.
	 * @param  string  UTF-8 encoding
	 * @param  string  ASCII
	 * @return string
	 */
	public static function webalize($s, $charlist = NULL)
	{
		$s = self::sanitize($s, $charlist);
		$s = strtr($s, ' ', '-');
		$s = strtolower($s);
		return $s;
	}
?>
					Editoval timbulko (4. 7. 2009 21:30)

- kravčo
 - Člen | 721
 
timbulko napsal(a):
Toto len nebude nahrádzať medzery, ale pomlčky to tam bude dávať stále. Ale požadované správanie je, aby namiesto pomlčiek medzi slovami dávalo medzery. Teda aby z „áäćč ďéě ťžô“ spravilo „aacc dee tzo“ a nie „aacc-dee-tzo“.
U mňa webalize('áäćč ďéě ťžô', ' ') vráti
'aacc dee tzo'…
Problémy nastanú ak nebude text tak „jednoduchý“…
webalize('John "Johnie" Walker', ' ') vráti trochu nepríjemné
'john -johnie- walker'. V tomto prípade by možno stálo za
zváženie dať voliteľný i zástupný znak (štandardne spojovník) ako
ďalší parameter.