mirror of https://github.com/nextcloud/calendar
70 lines
1.5 KiB
PHP
70 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace OCA\Calendar\Sabre\VObject\Property\VCard;
|
|
|
|
use
|
|
OCA\Calendar\Sabre\VObject\DateTimeParser,
|
|
OCA\Calendar\Sabre\VObject\Property\Text;
|
|
|
|
/**
|
|
* TimeStamp property
|
|
*
|
|
* This object encodes TIMESTAMP values.
|
|
*
|
|
* @copyright Copyright (C) 2007-2013 fruux GmbH. All rights reserved.
|
|
* @author Evert Pot (http://evertpot.com/)
|
|
* @license http://code.google.com/p/sabredav/wiki/License Modified BSD License
|
|
*/
|
|
class TimeStamp extends Text {
|
|
|
|
/**
|
|
* In case this is a multi-value property. This string will be used as a
|
|
* delimiter.
|
|
*
|
|
* @var string|null
|
|
*/
|
|
public $delimiter = null;
|
|
|
|
/**
|
|
* Returns the type of value.
|
|
*
|
|
* This corresponds to the VALUE= parameter. Every property also has a
|
|
* 'default' valueType.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getValueType() {
|
|
|
|
return "TIMESTAMP";
|
|
|
|
}
|
|
|
|
/**
|
|
* Returns the value, in the format it should be encoded for json.
|
|
*
|
|
* This method must always return an array.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getJsonValue() {
|
|
|
|
$parts = DateTimeParser::parseVCardDateTime($this->getValue());
|
|
|
|
$dateStr =
|
|
$parts['year'] . '-' .
|
|
$parts['month'] . '-' .
|
|
$parts['date'] . 'T' .
|
|
$parts['hour'] . ':' .
|
|
$parts['minute'] . ':' .
|
|
$parts['second'];
|
|
|
|
// Timezone
|
|
if (!is_null($parts['timezone'])) {
|
|
$dateStr.=$parts['timezone'];
|
|
}
|
|
|
|
return array($dateStr);
|
|
|
|
}
|
|
}
|