* or the GNU Affero General Public License, version 3: * iCalcreator is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero General Public License * as published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * iCalcreator is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * You should have received a copy of the GNU Affero General Public * License along with this program. * If not, see . */ namespace kigkonsult\iCalcreator\traits; use kigkonsult\iCalcreator\util\util; /** * CLASS property functions * * @author Kjell-Inge Gustafsson, kigkonsult * @since 2.22.23 - 2017-02-17 */ trait CLASStrait { /** * @var string component property CLASS value * @access protected */ protected $class = null; /** * Return formatted output for calendar component property class * * @return string */ public function createClass() { if( empty( $this->class )) return null; if( empty( $this->class[util::$LCvalue] )) return ( $this->getConfig( util::$ALLOWEMPTY )) ? util::createElement( util::$CLASS ) : null; return util::createElement( util::$CLASS, util::createParams( $this->class[util::$LCparams] ), $this->class[util::$LCvalue] ); } /** * Set calendar component property class * * @param string $value "PUBLIC" / "PRIVATE" / "CONFIDENTIAL" / iana-token / x-name * @param array $params * @return bool */ public function setClass( $value, $params=null ) { if( empty( $value )) { if( $this->getConfig( util::$ALLOWEMPTY )) $value = util::$EMPTYPROPERTY; else return false; } $this->class = [util::$LCvalue => util::trimTrailNL( $value ), util::$LCparams => util::setParams( $params )]; return true; } }