Skip to content

Sabre VObject Property FlatText

Evert Pot edited this page Sep 1, 2014 · 5 revisions

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.

Constants

REPAIR

const REPAIR = 1

Properties

$delimiter

public string $delimiter = ';'

In case this is a multi-value property. This string will be used as a delimiter.

  • Visibility: public

$structuredValues

protected array $structuredValues = array('N', 'ADR', 'ORG', 'GENDER', 'REQUEST-STATUS')

List of properties that are considered 'structured'.

  • Visibility: protected

$minimumPropertyValues

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

$name

public string $name

Property name.

This will contain a string such as DTSTART, SUMMARY, FN.

  • Visibility: public

$group

public string $group

Property group.

This is only used in vcards

  • Visibility: public

$parameters

public array $parameters = array()

List of parameters

  • Visibility: public

$value

protected mixed $value

Current value

  • Visibility: protected

$parent

public \Sabre\VObject\Node $parent

Reference to the parent object, if this is not the top object.

  • Visibility: public

$iterator

protected \Sabre\VObject\ElementList $iterator = null

Iterator override

  • Visibility: protected

$root

protected \Sabre\VObject\Component $root

The root document

  • Visibility: protected

Methods

setQuotedPrintableValue

void Sabre\VObject\Property\FlatText::setQuotedPrintableValue(string $val)

Sets the value as a quoted-printable encoded string.

  • Visibility: public

Arguments

  • $val string

__construct

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

Arguments

  • $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>

setRawMimeDirValue

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.

Arguments

  • $val string

getRawMimeDirValue

string Sabre\VObject\Property\FlatText::getRawMimeDirValue()

Returns a raw mime-dir representation of the value.

  • Visibility: public
  • This method is abstract.

getJsonValue

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

getValueType

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.

serialize

string Sabre\VObject\Property\FlatText::serialize()

Serializes the node into a mimedir format

  • Visibility: public
  • This method is abstract.

validate

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

Arguments

  • $options integer

setValue

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

Arguments

  • $value string|array

getValue

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

setParts

void Sabre\VObject\Property\FlatText::setParts(array $parts)

Sets a multi-valued property.

  • Visibility: public

Arguments

  • $parts array

getParts

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

add

\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

Arguments

  • $name string
  • $value string|null|array

parameters

array Sabre\VObject\Property\FlatText::parameters()

Returns an iterable list of children

  • Visibility: public

setJsonValue

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

Arguments

  • $value array

jsonSerialize

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.

__toString

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

offsetExists

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

Arguments

  • $offset integer

offsetGet

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

Arguments

  • $offset integer

offsetSet

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

Arguments

  • $offset integer
  • $value mixed

offsetUnset

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

Arguments

  • $offset integer

__clone

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

getIterator

\Sabre\VObject\ElementList Sabre\VObject\Property\FlatText::getIterator()

Returns the iterator for this object

  • Visibility: public

setIterator

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

Arguments

count

integer Sabre\VObject\Property\FlatText::count()

Returns the number of elements

  • Visibility: public
Clone this wiki locally