nouveau-theatre-de-besancon/vendor/spatie/schema-org/src/MonetaryAmount.php

317 lines
9.7 KiB
PHP
Raw Normal View History

2024-09-19 07:36:53 +02:00
<?php
namespace Spatie\SchemaOrg;
use Spatie\SchemaOrg\Contracts\IntangibleContract;
use Spatie\SchemaOrg\Contracts\MonetaryAmountContract;
use Spatie\SchemaOrg\Contracts\StructuredValueContract;
use Spatie\SchemaOrg\Contracts\ThingContract;
/**
* A monetary value or range. This type can be used to describe an amount of
* money such as $50 USD, or a range as in describing a bank account being
* suitable for a balance between £1,000 and £1,000,000 GBP, or the value of a
* salary, etc. It is recommended to use [[PriceSpecification]] Types to
* describe the price of an Offer, Invoice, etc.
*
* @see https://schema.org/MonetaryAmount
*
*/
class MonetaryAmount extends BaseType implements MonetaryAmountContract, IntangibleContract, StructuredValueContract, ThingContract
{
/**
* An additional type for the item, typically used for adding more specific
* types from external vocabularies in microdata syntax. This is a
* relationship between something and a class that the thing is in.
* Typically the value is a URI-identified RDF class, and in this case
* corresponds to the
* use of rdf:type in RDF. Text values can be used sparingly, for cases
* where useful information can be added without their being an appropriate
* schema to reference. In the case of text values, the class label should
* follow the schema.org [style
* guide](https://schema.org/docs/styleguide.html).
*
* @param string|string[] $additionalType
*
* @return static
*
* @see https://schema.org/additionalType
*/
public function additionalType($additionalType)
{
return $this->setProperty('additionalType', $additionalType);
}
/**
* An alias for the item.
*
* @param string|string[] $alternateName
*
* @return static
*
* @see https://schema.org/alternateName
*/
public function alternateName($alternateName)
{
return $this->setProperty('alternateName', $alternateName);
}
/**
* The currency in which the monetary amount is expressed.
*
* Use standard formats: [ISO 4217 currency
* format](http://en.wikipedia.org/wiki/ISO_4217), e.g. "USD"; [Ticker
* symbol](https://en.wikipedia.org/wiki/List_of_cryptocurrencies) for
* cryptocurrencies, e.g. "BTC"; well known names for [Local Exchange
* Trading
* Systems](https://en.wikipedia.org/wiki/Local_exchange_trading_system)
* (LETS) and other currency types, e.g. "Ithaca HOUR".
*
* @param string|string[] $currency
*
* @return static
*
* @see https://schema.org/currency
* @link https://github.com/schemaorg/schemaorg/issues/1253
*/
public function currency($currency)
{
return $this->setProperty('currency', $currency);
}
/**
* A description of the item.
*
* @param \Spatie\SchemaOrg\Contracts\TextObjectContract|\Spatie\SchemaOrg\Contracts\TextObjectContract[]|string|string[] $description
*
* @return static
*
* @see https://schema.org/description
*/
public function description($description)
{
return $this->setProperty('description', $description);
}
/**
* A sub property of description. A short description of the item used to
* disambiguate from other, similar items. Information from other properties
* (in particular, name) may be necessary for the description to be useful
* for disambiguation.
*
* @param string|string[] $disambiguatingDescription
*
* @return static
*
* @see https://schema.org/disambiguatingDescription
*/
public function disambiguatingDescription($disambiguatingDescription)
{
return $this->setProperty('disambiguatingDescription', $disambiguatingDescription);
}
/**
* The identifier property represents any kind of identifier for any kind of
* [[Thing]], such as ISBNs, GTIN codes, UUIDs etc. Schema.org provides
* dedicated properties for representing many of these, either as textual
* strings or as URL (URI) links. See [background
* notes](/docs/datamodel.html#identifierBg) for more details.
*
* @param \Spatie\SchemaOrg\Contracts\PropertyValueContract|\Spatie\SchemaOrg\Contracts\PropertyValueContract[]|string|string[] $identifier
*
* @return static
*
* @see https://schema.org/identifier
*/
public function identifier($identifier)
{
return $this->setProperty('identifier', $identifier);
}
/**
* An image of the item. This can be a [[URL]] or a fully described
* [[ImageObject]].
*
* @param \Spatie\SchemaOrg\Contracts\ImageObjectContract|\Spatie\SchemaOrg\Contracts\ImageObjectContract[]|string|string[] $image
*
* @return static
*
* @see https://schema.org/image
*/
public function image($image)
{
return $this->setProperty('image', $image);
}
/**
* Indicates a page (or other CreativeWork) for which this thing is the main
* entity being described. See [background
* notes](/docs/datamodel.html#mainEntityBackground) for details.
*
* @param \Spatie\SchemaOrg\Contracts\CreativeWorkContract|\Spatie\SchemaOrg\Contracts\CreativeWorkContract[]|string|string[] $mainEntityOfPage
*
* @return static
*
* @see https://schema.org/mainEntityOfPage
*/
public function mainEntityOfPage($mainEntityOfPage)
{
return $this->setProperty('mainEntityOfPage', $mainEntityOfPage);
}
/**
* The upper value of some characteristic or property.
*
* @param float|float[]|int|int[] $maxValue
*
* @return static
*
* @see https://schema.org/maxValue
*/
public function maxValue($maxValue)
{
return $this->setProperty('maxValue', $maxValue);
}
/**
* The lower value of some characteristic or property.
*
* @param float|float[]|int|int[] $minValue
*
* @return static
*
* @see https://schema.org/minValue
*/
public function minValue($minValue)
{
return $this->setProperty('minValue', $minValue);
}
/**
* The name of the item.
*
* @param string|string[] $name
*
* @return static
*
* @see https://schema.org/name
*/
public function name($name)
{
return $this->setProperty('name', $name);
}
/**
* Indicates a potential Action, which describes an idealized action in
* which this thing would play an 'object' role.
*
* @param \Spatie\SchemaOrg\Contracts\ActionContract|\Spatie\SchemaOrg\Contracts\ActionContract[] $potentialAction
*
* @return static
*
* @see https://schema.org/potentialAction
*/
public function potentialAction($potentialAction)
{
return $this->setProperty('potentialAction', $potentialAction);
}
/**
* URL of a reference Web page that unambiguously indicates the item's
* identity. E.g. the URL of the item's Wikipedia page, Wikidata entry, or
* official website.
*
* @param string|string[] $sameAs
*
* @return static
*
* @see https://schema.org/sameAs
*/
public function sameAs($sameAs)
{
return $this->setProperty('sameAs', $sameAs);
}
/**
* A CreativeWork or Event about this Thing.
*
* @param \Spatie\SchemaOrg\Contracts\CreativeWorkContract|\Spatie\SchemaOrg\Contracts\CreativeWorkContract[]|\Spatie\SchemaOrg\Contracts\EventContract|\Spatie\SchemaOrg\Contracts\EventContract[] $subjectOf
*
* @return static
*
* @see https://schema.org/subjectOf
* @link https://github.com/schemaorg/schemaorg/issues/1670
*/
public function subjectOf($subjectOf)
{
return $this->setProperty('subjectOf', $subjectOf);
}
/**
* URL of the item.
*
* @param string|string[] $url
*
* @return static
*
* @see https://schema.org/url
*/
public function url($url)
{
return $this->setProperty('url', $url);
}
/**
* The date when the item becomes valid.
*
* @param \DateTimeInterface|\DateTimeInterface[] $validFrom
*
* @return static
*
* @see https://schema.org/validFrom
*/
public function validFrom($validFrom)
{
return $this->setProperty('validFrom', $validFrom);
}
/**
* The date after when the item is not valid. For example the end of an
* offer, salary period, or a period of opening hours.
*
* @param \DateTimeInterface|\DateTimeInterface[] $validThrough
*
* @return static
*
* @see https://schema.org/validThrough
*/
public function validThrough($validThrough)
{
return $this->setProperty('validThrough', $validThrough);
}
/**
* The value of a [[QuantitativeValue]] (including [[Observation]]) or
* property value node.
*
* * For [[QuantitativeValue]] and [[MonetaryAmount]], the recommended type
* for values is 'Number'.
* * For [[PropertyValue]], it can be 'Text', 'Number', 'Boolean', or
* 'StructuredValue'.
* * Use values from 0123456789 (Unicode 'DIGIT ZERO' (U+0030) to 'DIGIT
* NINE' (U+0039)) rather than superficially similar Unicode symbols.
* * Use '.' (Unicode 'FULL STOP' (U+002E)) rather than ',' to indicate a
* decimal point. Avoid using these symbols as a readability separator.
*
* @param \Spatie\SchemaOrg\Contracts\StructuredValueContract|\Spatie\SchemaOrg\Contracts\StructuredValueContract[]|bool|bool[]|float|float[]|int|int[]|string|string[] $value
*
* @return static
*
* @see https://schema.org/value
*/
public function value($value)
{
return $this->setProperty('value', $value);
}
}