Mercurial > hg > rc1
comparison vendor/sabre/vobject/lib/Property/ICalendar/Period.php @ 7:430dbd5346f7
vendor sabre as distributed
author | Charlie Root |
---|---|
date | Sat, 13 Jan 2018 09:06:10 -0500 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
6:cec75ba50afc | 7:430dbd5346f7 |
---|---|
1 <?php | |
2 | |
3 namespace Sabre\VObject\Property\ICalendar; | |
4 | |
5 use | |
6 Sabre\VObject\Property, | |
7 Sabre\VObject\Parser\MimeDir, | |
8 Sabre\VObject\DateTimeParser; | |
9 | |
10 /** | |
11 * Period property | |
12 * | |
13 * This object represents PERIOD values, as defined here: | |
14 * | |
15 * http://tools.ietf.org/html/rfc5545#section-3.8.2.6 | |
16 * | |
17 * @copyright Copyright (C) 2011-2015 fruux GmbH (https://fruux.com/). | |
18 * @author Evert Pot (http://evertpot.com/) | |
19 * @license http://sabre.io/license/ Modified BSD License | |
20 */ | |
21 class Period extends Property { | |
22 | |
23 /** | |
24 * In case this is a multi-value property. This string will be used as a | |
25 * delimiter. | |
26 * | |
27 * @var string|null | |
28 */ | |
29 public $delimiter = ','; | |
30 | |
31 /** | |
32 * Sets a raw value coming from a mimedir (iCalendar/vCard) file. | |
33 * | |
34 * This has been 'unfolded', so only 1 line will be passed. Unescaping is | |
35 * not yet done, but parameters are not included. | |
36 * | |
37 * @param string $val | |
38 * @return void | |
39 */ | |
40 public function setRawMimeDirValue($val) { | |
41 | |
42 $this->setValue(explode($this->delimiter, $val)); | |
43 | |
44 } | |
45 | |
46 /** | |
47 * Returns a raw mime-dir representation of the value. | |
48 * | |
49 * @return string | |
50 */ | |
51 public function getRawMimeDirValue() { | |
52 | |
53 return implode($this->delimiter, $this->getParts()); | |
54 | |
55 } | |
56 | |
57 /** | |
58 * Returns the type of value. | |
59 * | |
60 * This corresponds to the VALUE= parameter. Every property also has a | |
61 * 'default' valueType. | |
62 * | |
63 * @return string | |
64 */ | |
65 public function getValueType() { | |
66 | |
67 return "PERIOD"; | |
68 | |
69 } | |
70 | |
71 /** | |
72 * Sets the json value, as it would appear in a jCard or jCal object. | |
73 * | |
74 * The value must always be an array. | |
75 * | |
76 * @param array $value | |
77 * @return void | |
78 */ | |
79 public function setJsonValue(array $value) { | |
80 | |
81 $value = array_map( | |
82 function($item) { | |
83 | |
84 return strtr(implode('/', $item), array(':' => '', '-' => '')); | |
85 | |
86 }, | |
87 $value | |
88 ); | |
89 parent::setJsonValue($value); | |
90 | |
91 } | |
92 | |
93 /** | |
94 * Returns the value, in the format it should be encoded for json. | |
95 * | |
96 * This method must always return an array. | |
97 * | |
98 * @return array | |
99 */ | |
100 public function getJsonValue() { | |
101 | |
102 $return = array(); | |
103 foreach($this->getParts() as $item) { | |
104 | |
105 list($start, $end) = explode('/', $item, 2); | |
106 | |
107 $start = DateTimeParser::parseDateTime($start); | |
108 | |
109 // This is a duration value. | |
110 if ($end[0]==='P') { | |
111 $return[] = array( | |
112 $start->format('Y-m-d\\TH:i:s'), | |
113 $end | |
114 ); | |
115 } else { | |
116 $end = DateTimeParser::parseDateTime($end); | |
117 $return[] = array( | |
118 $start->format('Y-m-d\\TH:i:s'), | |
119 $end->format('Y-m-d\\TH:i:s'), | |
120 ); | |
121 } | |
122 | |
123 } | |
124 | |
125 return $return; | |
126 | |
127 } | |
128 | |
129 } |