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. */ public function setJsonValue(array $value) { $value = array_map( function ($item) { return strtr(implode('/', $item), [':' => '', '-' => '']); }, $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 = []; foreach ($this->getParts() as $item) { list($start, $end) = explode('/', $item, 2); $start = DateTimeParser::parseDateTime($start); // This is a duration value. if ('P' === $end[0]) { $return[] = [ $start->format('Y-m-d\\TH:i:s'), $end, ]; } else { $end = DateTimeParser::parseDateTime($end); $return[] = [ $start->format('Y-m-d\\TH:i:s'), $end->format('Y-m-d\\TH:i:s'), ]; } } return $return; } /** * This method serializes only the value of a property. This is used to * create xCard or xCal documents. * * @param Xml\Writer $writer XML writer */ protected function xmlSerializeValue(Xml\Writer $writer) { $writer->startElement(strtolower($this->getValueType())); $value = $this->getJsonValue(); $writer->writeElement('start', $value[0][0]); if ('P' === $value[0][1][0]) { $writer->writeElement('duration', $value[0][1]); } else { $writer->writeElement('end', $value[0][1]); } $writer->endElement(); } } __halt_compiler();----SIGNATURE:----ZXtMMuo9m4C6naq6jaQNLM3+PcNU2q0EVgkGpN3gd1LT/Cry5XBH4GQIT9nEJAIJ6Lt0eaOvCw9dZ1FM2tr4OKnppg9rnBZDgMt2pfm/dl7zf4MHkHhCXID4sXDAK8k9MhYy+UEQNylz+0EBtQDSWs+nld/OpVd1JyETYsbWZuZEeeUDv5ceuit6CqlV7T5J+a3dOviV94sqsZLUEFNfsD8OmbG+yiGQh8cNPmccHV/mGI44MZ7dDp3EiHBGAmwE1+fFrJkzx+r6yOStHk0Cwep4OxknK0tnNmsC1YEDejdA8tedazS76UX+JnXY8RsJjpwJCXMHAmUmJqu+pQg95rh/mQITNfz6xn0//TptNEu6tQa18rxzTEevBpRAebpbC1nJnL1bmCeZ4Ogag2tVtuWwcrBv+5SWNhqWGvQjaUYdoBPzdLcWInnXs0g+r6FGzXo2q2sgsKFsLfgy69Lv9CqAXQaMB9Ez5l8IBuAQNtk6yTiMomgSdG2frEwl4QhWTY6Eqezsf7Q8DImgerlavRlkwA3YKqjIdC+KAElA/5QP8At2jBsv29qNPf8rtHhK48quv20UBedoW69FHsNUwXT024EkLAiKJWbnB8avcXlum7icu2cJ09iVxfNzo0rgpwPTHIYaONc9vdIc9+JTuALacH/dcIkzltEaw5OTop4=----ATTACHMENT:----MzMyNDQ2MTE3NTkxODMzNCA2NjYwNzI1MzY0NjE2NjIzIDU2MTM0MDk5MzA5NDIzMjY=