Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
100.00% covered (success)
100.00%
21 / 21
100.00% covered (success)
100.00%
5 / 5
CRAP
100.00% covered (success)
100.00%
1 / 1
Color
100.00% covered (success)
100.00%
21 / 21
100.00% covered (success)
100.00%
5 / 5
11
100.00% covered (success)
100.00%
1 / 1
 rgb
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 hsl
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 hex
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 parse
100.00% covered (success)
100.00%
10 / 10
100.00% covered (success)
100.00%
1 / 1
4
 parseColorValues
100.00% covered (success)
100.00%
8 / 8
100.00% covered (success)
100.00%
1 / 1
4
1<?php
2/**
3 * Pop PHP Framework (http://www.popphp.org/)
4 *
5 * @link       https://github.com/popphp/popphp-framework
6 * @author     Nick Sagona, III <dev@nolainteractive.com>
7 * @copyright  Copyright (c) 2009-2023 NOLA Interactive, LLC. (http://www.nolainteractive.com)
8 * @license    http://www.popphp.org/license     New BSD License
9 */
10
11/**
12 * @namespace
13 */
14namespace Pop\Css;
15
16/**
17 * Pop CSS color class
18 *
19 * @category   Pop
20 * @package    Pop\Css
21 * @author     Nick Sagona, III <dev@nolainteractive.com>
22 * @copyright  Copyright (c) 2009-2023 NOLA Interactive, LLC. (http://www.nolainteractive.com)
23 * @license    http://www.popphp.org/license     New BSD License
24 * @version    1.1.0
25 */
26class Color
27{
28
29    /**
30     * Instantiate an RGB color object
31     *
32     * @param  int   $r
33     * @param  int   $g
34     * @param  int   $b
35     * @param  float $a
36     * @return Color\Rgb
37     */
38    public static function rgb($r, $g, $b, $a = null)
39    {
40        return new Color\Rgb($r, $g, $b, $a);
41    }
42
43    /**
44     * Instantiate an RGB color object
45     *
46     * @param  int   $h
47     * @param  int   $s
48     * @param  int   $l
49     * @param  float $a
50     * @return Color\Hsl
51     */
52    public static function hsl($h, $s, $l, $a = null)
53    {
54        return new Color\Hsl($h, $s, $l, $a);
55    }
56
57    /**
58     * Instantiate an RGB color object
59     *
60     * @param  string $hex
61     * @return Color\Hex
62     */
63    public static function hex($hex)
64    {
65        return new Color\Hex($hex);
66    }
67
68    /**
69     * Parse CSS color from string
70     *
71     * @param  string $colorString
72     * @throws Color\Exception
73     * @return Color\ColorInterface|object
74     */
75    public static function parse($colorString)
76    {
77        $colorString = strtolower($colorString);
78
79        if (substr($colorString, 0, 3) == 'rgb') {
80            $params = self::parseColorValues($colorString);
81            return (new \ReflectionClass('Pop\Css\Color\Rgb'))->newInstanceArgs($params);
82        } else if (substr($colorString, 0, 3) == 'hsl') {
83            $params = self::parseColorValues($colorString);
84            return (new \ReflectionClass('Pop\Css\Color\Hsl'))->newInstanceArgs($params);
85        } else if (substr($colorString, 0, 1) == '#') {
86            return new Color\Hex($colorString);
87        } else {
88            throw new Color\Exception('Error: The string was not in the correct color format.');
89        }
90    }
91
92    /**
93     * Parse CSS color values from string
94     *
95     * @param  string $colorString
96     * @throws Color\Exception
97     * @return array
98     */
99    public static function parseColorValues($colorString)
100    {
101        if ((strpos($colorString, '(') === false) || (strpos($colorString, ')') === false)) {
102            throw new Color\Exception('Error: The string was not in the correct color format.');
103        }
104        $colorString = substr($colorString, (strpos($colorString, '(') + 1));
105        $colorString = substr($colorString, 0, strpos($colorString, ')'));
106        $values      = explode(',' , $colorString);
107
108        foreach ($values as $key => $value) {
109            $values[$key] = trim($value);
110        }
111
112        return $values;
113    }
114
115}