-
Notifications
You must be signed in to change notification settings - Fork 129
Sabre VObject Property FlatText
FlatText property
This object represents certain TEXT values.
Specifically, this property is used for text values where there is only 1 part. Semi-colons and colons will be de-escaped when deserializing, but if any semi-colons or commas appear without a backslash, we will not assume that they are delimiters.
vCard 2.1 specifically has a whole bunch of properties where this may happen, as it only defines a delimiter for a few properties.
vCard 4.0 states something similar. An unescaped semi-colon may be a delimiter, depending on the property.
- Class name: FlatText
- Namespace: Sabre\VObject\Property
- Parent class: Sabre\VObject\Property\Text
const REPAIR = 1
public string $delimiter = ';'
In case this is a multi-value property. This string will be used as a delimiter.
- Visibility: public
protected array $structuredValues = array('N', 'ADR', 'ORG', 'GENDER', 'REQUEST-STATUS')
List of properties that are considered 'structured'.
- Visibility: protected
protected array $minimumPropertyValues = array('N' => 5, 'ADR' => 7)
Some text components have a minimum number of components.
N must for instance be represented as 5 components, separated by ;, even if the last few components are unused.
- Visibility: protected
public string $name
Property name.
This will contain a string such as DTSTART, SUMMARY, FN.
- Visibility: public
public string $group
Property group.
This is only used in vcards
- Visibility: public
public array $parameters = array()
List of parameters
- Visibility: public
protected mixed $value
Current value
- Visibility: protected
public \Sabre\VObject\Node $parent
Reference to the parent object, if this is not the top object.
- Visibility: public
protected \Sabre\VObject\ElementList $iterator = null
Iterator override
- Visibility: protected
protected \Sabre\VObject\Component $root
The root document
- Visibility: protected
void Sabre\VObject\Property\FlatText::setQuotedPrintableValue(string $val)
Sets the value as a quoted-printable encoded string.
- Visibility: public
- $val string
void Sabre\VObject\Property\FlatText::__construct(\Sabre\VObject\Component $root, string $name, string|array|null $value, array $parameters, string $group)
Creates the generic property.
Parameters must be specified in key=>value syntax.
- Visibility: public
- $root Sabre\VObject\Component - <p>The root document</p>
- $name string
- $value string|array|null
- $parameters array - <p>List of parameters</p>
- $group string - <p>The vcard property group</p>
void Sabre\VObject\Property\FlatText::setRawMimeDirValue(string $val)
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.
- Visibility: public
- This method is abstract.
- $val string
string Sabre\VObject\Property\FlatText::getRawMimeDirValue()
Returns a raw mime-dir representation of the value.
- Visibility: public
- This method is abstract.
array Sabre\VObject\Property\FlatText::getJsonValue()
Returns the value, in the format it should be encoded for json.
This method must always return an array.
- Visibility: public
string Sabre\VObject\Property\FlatText::getValueType()
Returns the type of value.
This corresponds to the VALUE= parameter. Every property also has a 'default' valueType.
- Visibility: public
- This method is abstract.
string Sabre\VObject\Property\FlatText::serialize()
Serializes the node into a mimedir format
- Visibility: public
- This method is abstract.
array Sabre\VObject\Property\FlatText::validate(integer $options)
Validates the node for correctness.
The following options are supported: Node::REPAIR - May attempt to automatically repair the problem.
This method returns an array with detected problems. Every element has the following properties:
- level - problem level.
- message - A human-readable string describing the issue.
- node - A reference to the problematic node.
The level means: 1 - The issue was repaired (only happens if REPAIR was turned on) 2 - An inconsequential issue 3 - A severe issue.
- Visibility: public
- $options integer
void Sabre\VObject\Property\FlatText::setValue(string|array $value)
Updates the current value.
This may be either a single, or multiple strings in an array.
- Visibility: public
- $value string|array
string Sabre\VObject\Property\FlatText::getValue()
Returns the current value.
This method will always return a singular value. If this was a multi-value object, some decision will be made first on how to represent it as a string.
To get the correct multi-value version, use getParts.
- Visibility: public
void Sabre\VObject\Property\FlatText::setParts(array $parts)
Sets a multi-valued property.
- Visibility: public
- $parts array
array Sabre\VObject\Property\FlatText::getParts()
Returns a multi-valued property.
This method always returns an array, if there was only a single value, it will still be wrapped in an array.
- Visibility: public
\Sabre\VObject\Node Sabre\VObject\Property\FlatText::add(string $name, string|null|array $value)
Adds a new parameter, and returns the new item.
If a parameter with same name already existed, the values will be combined. If nameless parameter is added, we try to guess it's name.
- Visibility: public
- $name string
- $value string|null|array
array Sabre\VObject\Property\FlatText::parameters()
Returns an iterable list of children
- Visibility: public
void Sabre\VObject\Property\FlatText::setJsonValue(array $value)
Sets the json value, as it would appear in a jCard or jCal object.
The value must always be an array.
- Visibility: public
- $value array
array Sabre\VObject\Property\FlatText::jsonSerialize()
This method returns an array, with the representation as it should be encoded in json. This is used to create jCard or jCal documents.
- Visibility: public
- This method is abstract.
string Sabre\VObject\Property\FlatText::__toString()
Called when this object is being cast to a string.
If the property only had a single value, you will get just that. In the case the property had multiple values, the contents will be escaped and combined with ,.
- Visibility: public
boolean Sabre\VObject\Property\FlatText::offsetExists(integer $offset)
Checks if an item exists through ArrayAccess.
This method just forwards the request to the inner iterator
- Visibility: public
- $offset integer
mixed Sabre\VObject\Property\FlatText::offsetGet(integer $offset)
Gets an item through ArrayAccess.
This method just forwards the request to the inner iterator
- Visibility: public
- $offset integer
void Sabre\VObject\Property\FlatText::offsetSet(integer $offset, mixed $value)
Sets an item through ArrayAccess.
This method just forwards the request to the inner iterator
- Visibility: public
- $offset integer
- $value mixed
void Sabre\VObject\Property\FlatText::offsetUnset(integer $offset)
Sets an item through ArrayAccess.
This method just forwards the request to the inner iterator
- Visibility: public
- $offset integer
void Sabre\VObject\Property\FlatText::__clone()
This method is automatically called when the object is cloned.
Specifically, this will ensure all child elements are also cloned.
- Visibility: public
\Sabre\VObject\ElementList Sabre\VObject\Property\FlatText::getIterator()
Returns the iterator for this object
- Visibility: public
void Sabre\VObject\Property\FlatText::setIterator(\Sabre\VObject\ElementList $iterator)
Sets the overridden iterator
Note that this is not actually part of the iterator interface
- Visibility: public
- $iterator Sabre\VObject\ElementList
integer Sabre\VObject\Property\FlatText::count()
Returns the number of elements
- Visibility: public