1
0
mirror of https://github.com/wbbaddons/Tims-Chat.git synced 2025-01-24 02:20:39 +00:00
Tims-Chat/file/lib/util/ChatUtil.class.php

152 lines
3.9 KiB
PHP
Raw Normal View History

2011-12-05 16:53:12 +01:00
<?php
2013-01-19 20:36:40 +01:00
namespace chat\util;
2013-01-07 18:46:19 +01:00
use \wcf\data\package\PackageCache;
use \wcf\system\WCF;
2011-12-05 16:53:12 +01:00
/**
* Chat utilities
*
* @author Tim Düsterhus
2014-02-27 23:05:09 +01:00
* @copyright 2010-2014 Tim Düsterhus
2011-12-05 16:53:12 +01:00
* @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
2013-01-19 20:36:40 +01:00
* @package be.bastelstu.chat
2011-12-05 16:53:12 +01:00
* @subpackage util
*/
2012-03-12 22:51:29 +01:00
final class ChatUtil {
2011-12-10 14:43:18 +01:00
/**
* Matches a time-interval with modifiers.
* Each part may be optionally separated by a comma
*
2013-01-19 20:36:40 +01:00
* @see \chat\util\ChatUtil::timeModifier()
2011-12-10 14:43:18 +01:00
*/
2011-12-14 17:25:16 +01:00
const TIME_MODIFIER_REGEX = '((?:[0-9]+[s|h|d|w|m|y|S|H|D|W|M|Y]?,?)+)';
2011-12-10 14:43:18 +01:00
/**
* Package identifier of Tims Chat.
*
* @var string
*/
2013-01-19 20:36:40 +01:00
const PACKAGE_IDENTIFIER = 'be.bastelstu.chat';
/**
* Cached packageID of Tims Chat.
*
* @var integer
*/
private static $packageID = null;
/**
* Returns the packageID of Tims Chat.
*/
public static function getPackageID() {
if (self::$packageID === null) {
2013-01-07 18:46:19 +01:00
self::$packageID = PackageCache::getInstance()->getPackageID(self::PACKAGE_IDENTIFIER);
}
return self::$packageID;
}
2011-12-05 16:53:12 +01:00
/**
* Creates a gradient out of two colors represented by an integer.
* The first byte is red, the second byte is green, the third one is blue.
* The numbers can be easily expressed in hexadecimal notation: 0xFF0000 being red.
2014-02-28 17:06:50 +01:00
*
2011-12-05 16:53:12 +01:00
* @param string $string
* @param integer $start
* @param integer $end
* @return string
2011-12-05 16:53:12 +01:00
*/
public static function gradient($string, $start, $end) {
if (($length = mb_strlen($string)) === 0) return '';
2011-12-14 17:24:41 +01:00
2013-04-23 16:36:04 +02:00
if ($start === $end) {
2013-04-23 16:49:54 +02:00
return '<span style="color:rgb('.($start >> 16 & 255).','.($start >> 8 & 255).','.($start & 255).')">'.\wcf\util\StringUtil::encodeHTML($string).'</span>';
2013-04-23 16:36:04 +02:00
}
$r = (int) ((($start >> 16 & 255) - ($end >> 16 & 255)) / ($length - 1));
$g = (int) ((($start >> 8 & 255) - ($end >> 8 & 255)) / ($length - 1));
$b = (int) ((($start & 255) - ($end & 255)) / ($length - 1));
2011-12-05 16:53:12 +01:00
$result = '';
$string = self::str_split($string);
for ($i = 0; $i < $length; $i++) {
2013-01-19 20:36:40 +01:00
$result .= '<span style="color:rgb('.(($start >> 16 & 255) - $i * $r).','.(($start >> 8 & 255) - $i * $g).','.(($start & 255) - $i * $b).')">'.\wcf\util\StringUtil::encodeHTML($string[$i]).'</span>';
2011-12-05 16:53:12 +01:00
}
return $result;
}
2011-12-10 14:25:36 +01:00
2011-12-13 18:15:30 +01:00
/**
* Splits a string into smaller chunks.
* UTF-8 safe version of str_split().
*
* @param string $string
* @param integer $length
* @return array<string>
*/
public static function str_split($string, $length = 1) {
$result = array();
for ($i = 0, $max = mb_strlen($string); $i < $max; $i += $length) {
$result[] = mb_substr($string, $i, $length);
2011-12-13 18:15:30 +01:00
}
return $result;
}
2011-12-10 14:43:18 +01:00
/**
* Creates an interval out of a string with modifiers.
* Modifiers may be mixed. Valid modifiers are: _s_econd, _h_our, _d_ay, _w_week, _m_onth, _y_ear
* '2' -> 2 minutes
* '2h' -> 2 hours
* '1y12m2w3d12h' -> 1 year, 12 months, 2 weeks, 3 days, 12 hours
*
* @param string $time
* @return integer
*/
public static function timeModifier($time) {
2013-05-23 22:09:47 +02:00
$regex = new \wcf\system\Regex('([0-9]+)([shdwmy]?)', \wcf\system\Regex::CASE_INSENSITIVE);
if (!$regex->match($time, true, \wcf\system\Regex::ORDER_MATCH_BY_SET)) return 0;
2011-12-23 20:28:09 +01:00
$matches = $regex->getMatches();
2013-05-23 22:09:47 +02:00
$result = '';
foreach ($matches as $match) {
list(, $time, $modifier) = $match;
2011-12-10 14:43:18 +01:00
switch ($modifier) {
case 'y':
case 'Y':
2013-05-23 22:09:47 +02:00
$result .= '+'.$time.'year';
break;
2011-12-10 14:43:18 +01:00
case 'm':
case 'M':
2013-05-23 22:09:47 +02:00
$result .= '+'.$time.'month';
break;
2011-12-10 14:43:18 +01:00
case 'w':
case 'W':
2013-05-23 22:09:47 +02:00
$result .= '+'.$time.'week';
break;
2011-12-10 14:43:18 +01:00
case 'd':
case 'D':
2013-05-23 22:09:47 +02:00
$result .= '+'.$time.'day';
break;
2011-12-10 14:43:18 +01:00
case 'h':
case 'H':
2013-05-23 22:09:47 +02:00
$result .= '+'.$time.'hour';
2011-12-10 14:43:18 +01:00
break;
case 's':
case 'S':
2013-05-23 22:09:47 +02:00
$result .= '+'.$time.'second';
break;
default:
$result .= '+'.$time.'minute';
2011-12-10 14:43:18 +01:00
}
}
2013-05-23 22:09:47 +02:00
return $result;
2011-12-10 14:43:18 +01:00
}
2012-06-04 21:34:07 +02:00
/**
* Disables the constructor.
*/
2012-03-12 22:51:29 +01:00
private function __construct() { }
2011-12-05 16:53:12 +01:00
}