114 lines
2.8 KiB
PHP
114 lines
2.8 KiB
PHP
<?php defined('SYSPATH') OR die('No direct access allowed.');
|
|
/**
|
|
* Format helper class.
|
|
*
|
|
* $Id: format.php 4679 2009-11-10 01:45:52Z isaiah $
|
|
*
|
|
* @package Core
|
|
* @author Kohana Team
|
|
* @copyright (c) 2007-2009 Kohana Team
|
|
* @license http://kohanaphp.com/license
|
|
*/
|
|
class format_Core {
|
|
|
|
/**
|
|
* Formats a number according to the current locale.
|
|
*
|
|
* @param float
|
|
* @param int|boolean number of fractional digits or TRUE to use the locale default
|
|
* @return string
|
|
*/
|
|
public static function number($number, $decimals = 0)
|
|
{
|
|
$locale = localeconv();
|
|
|
|
if ($decimals === TRUE)
|
|
return number_format($number, $locale['frac_digits'], $locale['decimal_point'], $locale['thousands_sep']);
|
|
|
|
return number_format($number, $decimals, $locale['decimal_point'], $locale['thousands_sep']);
|
|
}
|
|
|
|
/**
|
|
* Formats a phone number according to the specified format.
|
|
*
|
|
* @param string phone number
|
|
* @param string format string
|
|
* @return string
|
|
*/
|
|
public static function phone($number, $format = '3-3-4')
|
|
{
|
|
// Get rid of all non-digit characters in number string
|
|
$number_clean = preg_replace('/\D+/', '', (string) $number);
|
|
|
|
// Array of digits we need for a valid format
|
|
$format_parts = preg_split('/[^1-9][^0-9]*/', $format, -1, PREG_SPLIT_NO_EMPTY);
|
|
|
|
// Number must match digit count of a valid format
|
|
if (strlen($number_clean) !== array_sum($format_parts))
|
|
return $number;
|
|
|
|
// Build regex
|
|
$regex = '(\d{'.implode('})(\d{', $format_parts).'})';
|
|
|
|
// Build replace string
|
|
for ($i = 1, $c = count($format_parts); $i <= $c; $i++)
|
|
{
|
|
$format = preg_replace('/(?<!\$)[1-9][0-9]*/', '\$'.$i, $format, 1);
|
|
}
|
|
|
|
// Hocus pocus!
|
|
return preg_replace('/^'.$regex.'$/', $format, $number_clean);
|
|
}
|
|
|
|
/**
|
|
* Formats a URL to contain a protocol at the beginning.
|
|
*
|
|
* @param string possibly incomplete URL
|
|
* @return string
|
|
*/
|
|
public static function url($str = '')
|
|
{
|
|
// Clear protocol-only strings like "http://"
|
|
if ($str === '' OR substr($str, -3) === '://')
|
|
return '';
|
|
|
|
// If no protocol given, prepend "http://" by default
|
|
if (strpos($str, '://') === FALSE)
|
|
return 'http://'.$str;
|
|
|
|
// Return the original URL
|
|
return $str;
|
|
}
|
|
|
|
/**
|
|
* Normalizes a hexadecimal HTML color value. All values will be converted
|
|
* to lowercase, have a "#" prepended and contain six characters.
|
|
*
|
|
* @param string hexadecimal HTML color value
|
|
* @return string
|
|
*/
|
|
public static function color($str = '')
|
|
{
|
|
// Reject invalid values
|
|
if ( ! valid::color($str))
|
|
return '';
|
|
|
|
// Convert to lowercase
|
|
$str = strtolower($str);
|
|
|
|
// Prepend "#"
|
|
if ($str[0] !== '#')
|
|
{
|
|
$str = '#'.$str;
|
|
}
|
|
|
|
// Expand short notation
|
|
if (strlen($str) === 4)
|
|
{
|
|
$str = '#'.$str[1].$str[1].$str[2].$str[2].$str[3].$str[3];
|
|
}
|
|
|
|
return $str;
|
|
}
|
|
|
|
} // End format
|