Page Menu
Home
Phabricator
Search
Configure Global Search
Log In
Files
F1814176
Period.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Size
2 KB
Subscribers
None
Period.php
View Options
<?php
namespace
Sabre\VObject\Property\ICalendar
;
use
Sabre\VObject\Property
,
Sabre\VObject\Parser\MimeDir
,
Sabre\VObject\DateTimeParser
;
/**
* Period property
*
* This object represents PERIOD values, as defined here:
*
* http://tools.ietf.org/html/rfc5545#section-3.8.2.6
*
* @copyright Copyright (C) 2011-2015 fruux GmbH (https://fruux.com/).
* @author Evert Pot (http://evertpot.com/)
* @license http://sabre.io/license/ Modified BSD License
*/
class
Period
extends
Property
{
/**
* In case this is a multi-value property. This string will be used as a
* delimiter.
*
* @var string|null
*/
public
$delimiter
=
','
;
/**
* Sets a raw value coming from a mimedir (iCalendar/vCard) file.
*
* This has been 'unfolded', so only 1 line will be passed. Unescaping is
* not yet done, but parameters are not included.
*
* @param string $val
* @return void
*/
public
function
setRawMimeDirValue
(
$val
)
{
$this
->
setValue
(
explode
(
$this
->
delimiter
,
$val
));
}
/**
* Returns a raw mime-dir representation of the value.
*
* @return string
*/
public
function
getRawMimeDirValue
()
{
return
implode
(
$this
->
delimiter
,
$this
->
getParts
());
}
/**
* Returns the type of value.
*
* This corresponds to the VALUE= parameter. Every property also has a
* 'default' valueType.
*
* @return string
*/
public
function
getValueType
()
{
return
"PERIOD"
;
}
/**
* Sets the json value, as it would appear in a jCard or jCal object.
*
* The value must always be an array.
*
* @param array $value
* @return void
*/
public
function
setJsonValue
(
array
$value
)
{
$value
=
array_map
(
function
(
$item
)
{
return
strtr
(
implode
(
'/'
,
$item
),
array
(
':'
=>
''
,
'-'
=>
''
));
},
$value
);
parent
::
setJsonValue
(
$value
);
}
/**
* Returns the value, in the format it should be encoded for json.
*
* This method must always return an array.
*
* @return array
*/
public
function
getJsonValue
()
{
$return
=
array
();
foreach
(
$this
->
getParts
()
as
$item
)
{
list
(
$start
,
$end
)
=
explode
(
'/'
,
$item
,
2
);
$start
=
DateTimeParser
::
parseDateTime
(
$start
);
// This is a duration value.
if
(
$end
[
0
]===
'P'
)
{
$return
[]
=
array
(
$start
->
format
(
'Y-m-d
\\
TH:i:s'
),
$end
);
}
else
{
$end
=
DateTimeParser
::
parseDateTime
(
$end
);
$return
[]
=
array
(
$start
->
format
(
'Y-m-d
\\
TH:i:s'
),
$end
->
format
(
'Y-m-d
\\
TH:i:s'
),
);
}
}
return
$return
;
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Dec 20 2024, 10:32 AM (4 w, 2 d ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
916459
Default Alt Text
Period.php (2 KB)
Attached To
rDAVCAL DokuWiki DAVCal PlugIn
Event Timeline
Log In to Comment