1<?php 2 3namespace Sabre\VObject\Property\ICalendar; 4 5use Sabre\VObject\DateTimeParser; 6use Sabre\VObject\Property; 7 8/** 9 * Duration property. 10 * 11 * This object represents DURATION values, as defined here: 12 * 13 * http://tools.ietf.org/html/rfc5545#section-3.3.6 14 * 15 * @copyright Copyright (C) fruux GmbH (https://fruux.com/) 16 * @author Evert Pot (http://evertpot.com/) 17 * @license http://sabre.io/license/ Modified BSD License 18 */ 19class Duration extends Property { 20 21 /** 22 * In case this is a multi-value property. This string will be used as a 23 * delimiter. 24 * 25 * @var string|null 26 */ 27 public $delimiter = ','; 28 29 /** 30 * Sets a raw value coming from a mimedir (iCalendar/vCard) file. 31 * 32 * This has been 'unfolded', so only 1 line will be passed. Unescaping is 33 * not yet done, but parameters are not included. 34 * 35 * @param string $val 36 * 37 * @return void 38 */ 39 function setRawMimeDirValue($val) { 40 41 $this->setValue(explode($this->delimiter, $val)); 42 43 } 44 45 /** 46 * Returns a raw mime-dir representation of the value. 47 * 48 * @return string 49 */ 50 function getRawMimeDirValue() { 51 52 return implode($this->delimiter, $this->getParts()); 53 54 } 55 56 /** 57 * Returns the type of value. 58 * 59 * This corresponds to the VALUE= parameter. Every property also has a 60 * 'default' valueType. 61 * 62 * @return string 63 */ 64 function getValueType() { 65 66 return 'DURATION'; 67 68 } 69 70 /** 71 * Returns a DateInterval representation of the Duration property. 72 * 73 * If the property has more than one value, only the first is returned. 74 * 75 * @return \DateInterval 76 */ 77 function getDateInterval() { 78 79 $parts = $this->getParts(); 80 $value = $parts[0]; 81 return DateTimeParser::parseDuration($value); 82 83 } 84 85} 86