From 85aaba85bc88007a046aee2f2837944692a9edd4 Mon Sep 17 00:00:00 2001 From: Marcos Candeia Date: Thu, 31 Aug 2023 18:38:00 -0300 Subject: [PATCH] back to std types Signed-off-by: Marcos Candeia --- commerce/types.ts | 620 +++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 619 insertions(+), 1 deletion(-) diff --git a/commerce/types.ts b/commerce/types.ts index 9f5d1d32..b8261552 100644 --- a/commerce/types.ts +++ b/commerce/types.ts @@ -1 +1,619 @@ -export * from "https://denopkg.com/deco-cx/apps@0.2.5/commerce/types.ts"; +/** Used at the top-level node to indicate the context for the JSON-LD objects used. The context provided in this type is compatible with the keys and URLs in the rest of this generated file. */ +export declare type WithContext = T & { + "@context": "https://schema.org"; +}; + +export declare type Things = Thing | Product | BreadcrumbList; + +export interface Thing { + "@type": "Thing"; + /** IRI identifying the canonical address of this object. */ + "@id"?: string; + /** 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. In RDFa syntax, it is better to use the native RDFa syntax - the 'typeof' attribute - for multiple types. Schema.org tools may have only weaker understanding of extra types, in particular those defined externally. */ + additionalType?: string; + /** An alias for the item. */ + alternateName?: string; + /** A description of the item. */ + description?: string; + /** 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. */ + disambiguatingDescription?: string; + /** The identifier property represents any kind of identifier for any kind of {@link https://schema.org/Thing 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 {@link /docs/datamodel.html#identifierBg background notes} for more details. */ + identifier?: string; + /** An image of the item. This can be a {@link https://schema.org/URL URL} or a fully described {@link https://schema.org/ImageObject ImageObject}. */ + image?: ImageObject[]; + /** The name of the item. */ + name?: string; + /** 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. */ + sameAs?: string; + /** A CreativeWork or Event about this Thing. */ + subjectOf?: string; + /** URL of the item. */ + url?: string; +} + +export interface ImageObject extends Omit { + "@type": "ImageObject"; +} + +export interface PropertyValue extends Omit { + "@type": "PropertyValue"; + /** The upper value of some characteristic or property. */ + maxValue?: number; + /** The lower value of some characteristic or property. */ + minValue?: number; + /** A commonly used identifier for the characteristic represented by the property, e.g. a manufacturer or a standard code for a property. propertyID can be (1) a prefixed string, mainly meant to be used with standards for product properties; (2) a site-specific, non-prefixed string (e.g. the primary key of the property or the vendor-specific id of the property), or (3) a URL indicating the type of the property, either pointing to an external vocabulary, or a Web resource that describes the property (e.g. a glossary entry). Standards bodies should promote a standard prefix for the identifiers of properties from their standards. */ + propertyID?: string; + /** The unit of measurement given using the UN/CEFACT Common Code (3 characters) or a URL. Other codes than the UN/CEFACT Common Code may be used with a prefix followed by a colon. */ + unitCode?: string; + /** A string or text indicating the unit of measurement. Useful if you cannot provide a standard unit code for {@link unitCode unitCode}. */ + unitText?: string; + /** + * The value of the quantitative value or property value node. + * - For {@link https://schema.org/QuantitativeValue QuantitativeValue} and {@link https://schema.org/MonetaryAmount MonetaryAmount}, the recommended type for values is 'Number'. + * - For {@link https://schema.org/PropertyValue 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 similiar Unicode symbols. + * - Use '.' (Unicode 'FULL STOP' (U+002E)) rather than ',' to indicate a decimal point. Avoid using these symbols as a readability separator. + */ + value?: string; + /** A secondary value that provides additional information on the original value, e.g. a reference temperature or a type of measurement. */ + valueReference?: string; +} + +export interface AggregateRating { + "@type": "AggregateRating"; + /** The count of total number of ratings. */ + ratingCount?: number; + /** The count of total number of reviews. */ + reviewCount?: number; + /** The rating for the content. */ + ratingValue?: number; +} + +export declare type ItemAvailability = + | "https://schema.org/BackOrder" + | "https://schema.org/Discontinued" + | "https://schema.org/InStock" + | "https://schema.org/InStoreOnly" + | "https://schema.org/LimitedAvailability" + | "https://schema.org/OnlineOnly" + | "https://schema.org/OutOfStock" + | "https://schema.org/PreOrder" + | "https://schema.org/PreSale" + | "https://schema.org/SoldOut"; + +export declare type OfferItemCondition = + | "https://schema.org/DamagedCondition" + | "https://schema.org/NewCondition" + | "https://schema.org/RefurbishedCondition" + | "https://schema.org/UsedCondition"; + +export interface QuantitativeValue { + value?: number; +} + +export declare type PriceTypeEnumeration = + | "https://schema.org/InvoicePrice" + | "https://schema.org/ListPrice" + | "https://schema.org/MinimumAdvertisedPrice" + | "https://schema.org/MSRP" + | "https://schema.org/SalePrice" + | "https://schema.org/SRP"; + +export declare type PriceComponentTypeEnumeration = + | "https://schema.org/ActivationFee" + | "https://schema.org/CleaningFee" + | "https://schema.org/DistanceFee" + | "https://schema.org/Downpayment" + | "https://schema.org/Installment" + | "https://schema.org/Subscription"; + +export interface PriceSpecification extends Omit { + "@type": "PriceSpecification"; + /** The interval and unit of measurement of ordering quantities for which the offer or price specification is valid. This allows e.g. specifying that a certain freight charge is valid only for a certain quantity. */ + eligibleQuantity?: QuantitativeValue; + /** + * The offer price of a product, or of a price component when attached to PriceSpecification and its subtypes. + * + * Usage guidelines: + * - Use the {@link https://schema.org/priceCurrency priceCurrency} property (with standard formats: {@link http://en.wikipedia.org/wiki/ISO_4217 ISO 4217 currency format} e.g. "USD"; {@link https://en.wikipedia.org/wiki/List_of_cryptocurrencies Ticker symbol} for cryptocurrencies e.g. "BTC"; well known names for {@link https://en.wikipedia.org/wiki/Local_exchange_trading_system Local Exchange Tradings Systems} (LETS) and other currency types e.g. "Ithaca HOUR") instead of including {@link http://en.wikipedia.org/wiki/Dollar_sign#Currencies_that_use_the_dollar_or_peso_sign ambiguous symbols} such as '$' in the value. + * - Use '.' (Unicode 'FULL STOP' (U+002E)) rather than ',' to indicate a decimal point. Avoid using these symbols as a readability separator. + * - Note that both {@link http://www.w3.org/TR/xhtml-rdfa-primer/#using-the-content-attribute RDFa} and Microdata syntax allow the use of a "content=" attribute for publishing simple machine-readable values alongside more human-friendly formatting. + * - Use values from 0123456789 (Unicode 'DIGIT ZERO' (U+0030) to 'DIGIT NINE' (U+0039)) rather than superficially similiar Unicode symbols. + */ + price: number; + /** + * The currency of the price, or a price component when attached to {@link https://schema.org/PriceSpecification PriceSpecification} and its subtypes. + * + * Use standard formats: {@link http://en.wikipedia.org/wiki/ISO_4217 ISO 4217 currency format} e.g. "USD"; {@link https://en.wikipedia.org/wiki/List_of_cryptocurrencies Ticker symbol} for cryptocurrencies e.g. "BTC"; well known names for {@link https://en.wikipedia.org/wiki/Local_exchange_trading_system Local Exchange Tradings Systems} (LETS) and other currency types e.g. "Ithaca HOUR". + */ + priceCurrency?: string; +} + +export interface UnitPriceSpecification + extends Omit { + "@type": "UnitPriceSpecification"; + /** Identifies a price component (for example, a line item on an invoice), part of the total price for an offer. */ + priceComponentType?: PriceComponentTypeEnumeration; + /** Defines the type of a price specified for an offered product, for example a list price, a (temporary) sale price or a manufacturer suggested retail price. If multiple prices are specified for an offer the {@link https://schema.org/priceType priceType} property can be used to identify the type of each such specified price. The value of priceType can be specified as a value from enumeration PriceTypeEnumeration or as a free form text string for price types that are not already predefined in PriceTypeEnumeration. */ + priceType: PriceTypeEnumeration; + /** Specifies for how long this price (or price component) will be billed. Can be used, for example, to model the contractual duration of a subscription or payment plan. Type can be either a Duration or a Number (in which case the unit of measurement, for example month, is specified by the unitCode property). */ + billingDuration?: number; + /** This property specifies the minimal quantity and rounding increment that will be the basis for the billing. The unit of measurement is specified by the unitCode property. */ + billingIncrement?: number; +} + +export interface TeasersParameters { + name: string; + value: string; +} + +export interface TeasersConditions { + minimumQuantity: number; + parameters: TeasersParameters[]; +} + +export interface TeasersEffect { + parameters: TeasersParameters[]; +} + +export interface Teasers { + name: string; + generalValues?: unknown; + conditions: TeasersConditions; + effects: TeasersEffect; +} + +export interface Offer extends Omit { + "@type": "Offer"; + /** The availability of this item—for example In stock, Out of stock, Pre-order, etc. */ + availability: ItemAvailability; + /** A Global Trade Item Number ({@link https://www.gs1.org/standards/id-keys/gtin GTIN}). GTINs identify trade items, including products and services, using numeric identification codes. The {@link https://schema.org/gtin gtin} property generalizes the earlier {@link https://schema.org/gtin8 gtin8}, {@link https://schema.org/gtin12 gtin12}, {@link https://schema.org/gtin13 gtin13}, and {@link https://schema.org/gtin14 gtin14} properties. The GS1 {@link https://www.gs1.org/standards/Digital-Link/ digital link specifications} express GTINs as URLs. A correct {@link https://schema.org/gtin gtin} value should be a valid GTIN, which means that it should be an all-numeric string of either 8, 12, 13 or 14 digits, or a "GS1 Digital Link" URL based on such a string. The numeric component should also have a {@link https://www.gs1.org/services/check-digit-calculator valid GS1 check digit} and meet the other rules for valid GTINs. See also {@link http://www.gs1.org/barcodes/technical/idkeys/gtin GS1's GTIN Summary} and {@link https://en.wikipedia.org/wiki/Global_Trade_Item_Number Wikipedia} for more details. Left-padding of the gtin values is not required or encouraged. */ + gtin?: string; + /** The current approximate inventory level for the item or items. */ + inventoryLevel: QuantitativeValue; + /** A predefined value from OfferItemCondition specifying the condition of the product or service, or the products or services included in the offer. Also used for product return policies to specify the condition of products accepted for returns. */ + itemCondition?: OfferItemCondition; + /** + * The offer price of a product, or of a price component when attached to PriceSpecification and its subtypes. + * + * Usage guidelines: + * - Use the {@link https://schema.org/priceCurrency priceCurrency} property (with standard formats: {@link http://en.wikipedia.org/wiki/ISO_4217 ISO 4217 currency format} e.g. "USD"; {@link https://en.wikipedia.org/wiki/List_of_cryptocurrencies Ticker symbol} for cryptocurrencies e.g. "BTC"; well known names for {@link https://en.wikipedia.org/wiki/Local_exchange_trading_system Local Exchange Tradings Systems} (LETS) and other currency types e.g. "Ithaca HOUR") instead of including {@link http://en.wikipedia.org/wiki/Dollar_sign#Currencies_that_use_the_dollar_or_peso_sign ambiguous symbols} such as '$' in the value. + * - Use '.' (Unicode 'FULL STOP' (U+002E)) rather than ',' to indicate a decimal point. Avoid using these symbols as a readability separator. + * - Note that both {@link http://www.w3.org/TR/xhtml-rdfa-primer/#using-the-content-attribute RDFa} and Microdata syntax allow the use of a "content=" attribute for publishing simple machine-readable values alongside more human-friendly formatting. + * - Use values from 0123456789 (Unicode 'DIGIT ZERO' (U+0030) to 'DIGIT NINE' (U+0039)) rather than superficially similiar Unicode symbols. + */ + price: number; + /** One or more detailed price specifications, indicating the unit price and delivery or payment charges. */ + priceSpecification: UnitPriceSpecification[]; + /** The date after which the price is no longer available. */ + priceValidUntil?: string; + /** An entity which offers (sells / leases / lends / loans) the services / goods. A seller may also be a provider. */ + seller?: string; + /** The Stock Keeping Unit (SKU), i.e. a merchant-specific identifier for a product or service, or the product to which the offer refers. */ + sku?: string; + /** Used by some ecommerce providers (e.g: VTEX) to describe special promotions that depend on some conditions */ + teasers?: Teasers[]; +} + +export interface AggregateOffer { + "@type": "AggregateOffer"; + /** + * The highest price of all offers available. + * + * Usage guidelines: + * - Use values from 0123456789 (Unicode 'DIGIT ZERO' (U+0030) to 'DIGIT NINE' (U+0039)) rather than superficially similiar Unicode symbols. + * - Use '.' (Unicode 'FULL STOP' (U+002E)) rather than ',' to indicate a decimal point. Avoid using these symbols as a readability separator. + */ + highPrice: number; + /** + * The lowest price of all offers available. + * + * Usage guidelines: + * - Use values from 0123456789 (Unicode 'DIGIT ZERO' (U+0030) to 'DIGIT NINE' (U+0039)) rather than superficially similiar Unicode symbols. + * - Use '.' (Unicode 'FULL STOP' (U+002E)) rather than ',' to indicate a decimal point. Avoid using these symbols as a readability separator. + */ + lowPrice: number; + /** The number of offers for the product. */ + offerCount: number; + /** An offer to provide this item—for example, an offer to sell a product, rent the DVD of a movie, perform a service, or give away tickets to an event. Use {@link https://schema.org/businessFunction businessFunction} to indicate the kind of transaction offered, i.e. sell, lease, etc. This property can also be used to describe a {@link https://schema.org/Demand Demand}. While this property is listed as expected on a number of common types, it can be used in others. In that case, using a second type, such as Product or a subtype of Product, can clarify the nature of the offer. */ + offers: Offer[]; + /** + * The currency of the price, or a price component when attached to {@link https://schema.org/PriceSpecification PriceSpecification} and its subtypes. + * + * Use standard formats: {@link http://en.wikipedia.org/wiki/ISO_4217 ISO 4217 currency format} e.g. "USD"; {@link https://en.wikipedia.org/wiki/List_of_cryptocurrencies Ticker symbol} for cryptocurrencies e.g. "BTC"; well known names for {@link https://en.wikipedia.org/wiki/Local_exchange_trading_system Local Exchange Tradings Systems} (LETS) and other currency types e.g. "Ithaca HOUR". + */ + priceCurrency?: string; +} + +export interface Review extends Omit { + "@type": "Review"; + /** The item that is being reviewed/rated. */ + itemReviewed?: string; + /** Indicates, in the context of a {@link https://schema.org/Review Review} (e.g. framed as 'pro' vs 'con' considerations), negative considerations - either as unstructured text, or a list. */ + negativeNotes?: string[]; + /** Indicates, in the context of a {@link https://schema.org/Review Review} (e.g. framed as 'pro' vs 'con' considerations), positive considerations - either as unstructured text, or a list. */ + positiveNotes?: string[]; + /** This Review or Rating is relevant to this part or facet of the itemReviewed. */ + reviewAspect?: string; + /** The actual body of the review. */ + reviewBody?: string; + /** The rating given in this review. Note that reviews can themselves be rated. The `reviewRating` applies to rating given by the review. The {@link https://schema.org/aggregateRating aggregateRating} property applies to the review itself, as a creative work. */ + reviewRating?: AggregateRating; +} + +// TODO: fix this hack and use Product directly where it appears +// Hack to prevent type self referencing and we end up with an infinite loop +// deno-lint-ignore no-empty-interface +export interface ProductLeaf extends Omit {} + +export interface ProductGroup extends Omit { + "@type": "ProductGroup"; + /** Indicates a {@link https://schema.org/Product Product} that is a member of this {@link https://schema.org/ProductGroup ProductGroup} (or {@link https://schema.org/ProductModel ProductModel}). */ + hasVariant: ProductLeaf[]; + /** Indicates a textual identifier for a ProductGroup. */ + productGroupID: string; + /** + * A property-value pair representing an additional characteristics of the entitity, e.g. a product feature or another characteristic for which there is no matching property in schema.org. + * + * Note: Publishers should be aware that applications designed to use specific schema.org properties (e.g. https://schema.org/width, https://schema.org/color, https://schema.org/gtin13, ...) will typically expect such data to be provided using those properties, rather than using the generic property/value mechanism. + */ + additionalProperty: PropertyValue[]; + /** docs https://schema.org/gtin */ + model?: string; +} + +export interface Brand extends Omit { + "@type": "Brand"; + /** Brand's image url */ + logo?: string; +} + +export interface Product extends Omit { + "@type": "Product"; + /** + * A property-value pair representing an additional characteristics of the entitity, e.g. a product feature or another characteristic for which there is no matching property in schema.org. + * + * Note: Publishers should be aware that applications designed to use specific schema.org properties (e.g. https://schema.org/width, https://schema.org/color, https://schema.org/gtin13, ...) will typically expect such data to be provided using those properties, rather than using the generic property/value mechanism. + */ + additionalProperty?: PropertyValue[]; + /** The overall rating, based on a collection of reviews or ratings, of the item. */ + aggregateRating?: AggregateRating; + /** An award won by or for this item. */ + award?: string; + /** The brand(s) associated with a product or service, or the brand(s) maintained by an organization or business person. */ + brand?: Brand; + /** A category for the item. Greater signs or slashes can be used to informally indicate a category hierarchy. */ + category?: string; + /** A Global Trade Item Number ({@link https://www.gs1.org/standards/id-keys/gtin GTIN}). GTINs identify trade items, including products and services, using numeric identification codes. The {@link https://schema.org/gtin gtin} property generalizes the earlier {@link https://schema.org/gtin8 gtin8}, {@link https://schema.org/gtin12 gtin12}, {@link https://schema.org/gtin13 gtin13}, and {@link https://schema.org/gtin14 gtin14} properties. The GS1 {@link https://www.gs1.org/standards/Digital-Link/ digital link specifications} express GTINs as URLs. A correct {@link https://schema.org/gtin gtin} value should be a valid GTIN, which means that it should be an all-numeric string of either 8, 12, 13 or 14 digits, or a "GS1 Digital Link" URL based on such a string. The numeric component should also have a {@link https://www.gs1.org/services/check-digit-calculator valid GS1 check digit} and meet the other rules for valid GTINs. See also {@link http://www.gs1.org/barcodes/technical/idkeys/gtin GS1's GTIN Summary} and {@link https://en.wikipedia.org/wiki/Global_Trade_Item_Number Wikipedia} for more details. Left-padding of the gtin values is not required or encouraged. */ + gtin?: string; + /** Indicates the {@link https://schema.org/productGroupID productGroupID} for a {@link https://schema.org/ProductGroup ProductGroup} that this product {@link https://schema.org/isVariantOf isVariantOf}. */ + inProductGroupWithID?: string; + // TODO: Make json schema generator support self-referencing types + // /** A pointer to another, somehow related product (or multiple products). */ + // isRelatedTo?: Product[]; + /** A pointer to another, functionally similar product (or multiple products). */ + isSimilarTo?: Product[]; + /** Indicates the kind of product that this is a variant of. In the case of {@link https://schema.org/ProductModel ProductModel}, this is a pointer (from a ProductModel) to a base product from which this product is a variant. It is safe to infer that the variant inherits all product features from the base model, unless defined locally. This is not transitive. In the case of a {@link https://schema.org/ProductGroup ProductGroup}, the group description also serves as a template, representing a set of Products that vary on explicitly defined, specific dimensions only (so it defines both a set of variants, as well as which values distinguish amongst those variants). When used with {@link https://schema.org/ProductGroup ProductGroup}, this property can apply to any {@link https://schema.org/Product Product} included in the group. */ + isVariantOf?: ProductGroup; + /** An offer to provide this item—for example, an offer to sell a product, rent the DVD of a movie, perform a service, or give away tickets to an event. Use {@link https://schema.org/businessFunction businessFunction} to indicate the kind of transaction offered, i.e. sell, lease, etc. This property can also be used to describe a {@link https://schema.org/Demand Demand}. While this property is listed as expected on a number of common types, it can be used in others. In that case, using a second type, such as Product or a subtype of Product, can clarify the nature of the offer. */ + offers?: AggregateOffer; + /** The product identifier, such as ISBN. For example: `meta itemprop="productID" content="isbn:123-456-789"`. */ + productID: string; + /** The date of production of the item, e.g. vehicle. */ + productionDate?: string; + /** The release date of a product or product model. This can be used to distinguish the exact variant of a product. */ + releaseDate?: string; + /** A review of the item. */ + review?: Review; + /** The Stock Keeping Unit (SKU), i.e. a merchant-specific identifier for a product or service, or the product to which the offer refers. */ + sku: string; + /** A pointer to another product (or multiple products) for which this product is an accessory or spare part. */ + isAccessoryOrSparePartFor?: ProductLeaf[]; +} + +export interface ListItem extends Omit { + "@type": "ListItem"; + /** An entity represented by an entry in a list or data feed (e.g. an 'artist' in a list of 'artists')’. */ + item: T; + /** The position of an item in a series or sequence of items. */ + position: number; +} + +export interface ItemList extends Omit { + "@type": "ItemList"; + /** + * For itemListElement values, you can use simple strings (e.g. "Peter", "Paul", "Mary"), existing entities, or use ListItem. + * + * Text values are best if the elements in the list are plain strings. Existing entities are best for a simple, unordered list of existing things in your data. ListItem is used with ordered lists when you want to provide additional context about the element in that list or when the same item might be in different places in different lists. + * + * Note: The order of elements in your mark-up is not sufficient for indicating the order or elements. Use ListItem with a 'position' property in such cases. + */ + itemListElement: ListItem[]; + /** The number of items in an ItemList. Note that some descriptions might not fully describe all items in a list (e.g., multi-page pagination); in such cases, the numberOfItems would be for the entire list. */ + numberOfItems: number; +} + +export interface BreadcrumbList extends Omit { + "@type": "BreadcrumbList"; +} + +export interface FilterToggleValue { + quantity: number; + label: string; + value: string; + selected: boolean; + url: string; +} + +export interface FilterRangeValue { + min: number; + max: number; +} + +export interface FilterBase { + label: string; + key: string; +} + +export interface FilterToggle extends FilterBase { + "@type": "FilterToggle"; + values: FilterToggleValue[]; + quantity: number; +} + +export interface FilterRange extends FilterBase { + "@type": "FilterRange"; + values: FilterRangeValue; +} + +export type Filter = FilterToggle | FilterRange; +export type SortOption = { value: string; label: string }; +export interface ProductDetailsPage { + "@type": "ProductDetailsPage"; + breadcrumbList: BreadcrumbList; + product: Product; + seo?: Seo | null; +} + +export interface ProductListingPage { + "@type": "ProductListingPage"; + breadcrumb: BreadcrumbList; + filters: Filter[]; + products: Product[]; + pageInfo: { + currentPage: number; + nextPage: string | undefined; + previousPage: string | undefined; + records?: number | undefined; + recordPerPage?: number | undefined; + }; + sortOptions: SortOption[]; + seo?: Seo | null; +} + +export interface Seo { + title: string; + description: string; + canonical: string; +} + +export interface Search { + term: string; +} + +export interface Suggestion { + searches?: Search[]; + products?: Product[]; +} + +export interface NavItem { + label: string; + href: string; + image?: { src?: string; alt?: string }; +} + +export interface Navbar extends NavItem { + // TODO: The schema generator is not handling recursive types leading in a infinite recursion loop + // deno-lint-ignore no-explicit-any + children?: any[]; +} + +// deno-lint-ignore no-explicit-any +export interface IEvent { + name: string; + params: Params; +} + +// 3 letter ISO 4217 - Doc: https://en.wikipedia.org/wiki/ISO_4217#Active_codes +type Currency = string; +type Value = number; + +interface WithItemId { + item_id: string; +} + +interface WithItemName { + item_name: string; +} + +type ItemIdentifier = WithItemId | WithItemName; + +interface AnalyticsItemWithoutIdentifier { + affiliation?: string; + coupon?: string; + discount?: number; + index?: number; + item_brand?: string; + item_category?: string; + item_category2?: string; + item_category3?: string; + item_category4?: string; + item_category5?: string; + item_list_id?: string; + item_list_name?: string; + item_variant?: string; + location_id?: string; + price?: Value; + quantity: number; +} + +export type AnalyticsItem = AnalyticsItemWithoutIdentifier & ItemIdentifier; + +export interface AddShippingInfoParams { + currency?: Currency; + value?: Value; + coupun?: string; + shipping_tier?: string; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#add_shipping_info */ +export interface AddShippingInfoEvent extends IEvent { + name: "add_shipping_info"; +} + +export interface AddToCartParams { + currency?: Currency; + value?: Value; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#add_to_cart */ +export interface AddToCartEvent extends IEvent { + name: "add_to_cart"; +} + +export interface AddToWishlistParams { + currency?: Currency; + value?: Value; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#add_to_wishlist */ +export interface AddToWishlistEvent extends IEvent { + name: "add_to_wishlist"; +} + +export interface BeginCheckoutParams { + currency: Currency; + value: Value; + items: AnalyticsItem[]; + coupon?: string; +} + +/** docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#begin_checkout */ +export interface BeginCheckoutEvent extends IEvent { + name: "begin_checkout"; +} + +export interface LoginParams { + method?: string; +} +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#login */ +export interface LoginEvent extends IEvent { + name: "login"; +} + +export interface RemoveFromCartParams { + currency?: Currency; + value?: Value; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#remove_from_cart */ +export interface RemoveFromCartEvent extends IEvent { + name: "remove_from_cart"; +} + +export interface SearchParams { + search_term: string; +} + +export interface SearchEvent extends IEvent { + name: "search"; +} + +export interface SelectItemParams { + item_list_id?: string; + item_list_name?: string; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#select_item */ +export interface SelectItemEvent extends IEvent { + name: "select_item"; +} + +export interface SelectPromotionParams { + creative_name?: string; + creative_slot?: string; + promotion_id?: string; + promotion_name?: string; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#select_promotion */ +export interface SelectPromotionEvent extends IEvent { + name: "select_promotion"; +} + +export interface ViewCartParams { + currency: Currency; + value: Value; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#view_cart */ +export interface ViewCartEvent extends IEvent { + name: "view_cart"; +} + +export interface ViewItemParams { + currency?: Currency; + value?: Value; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtag#view_item */ +export interface ViewItemEvent extends IEvent { + name: "view_item"; +} + +export interface ViewItemListParams { + item_list_id?: string; + item_list_name?: string; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#view_item_list */ +export interface ViewItemListEvent extends IEvent { + name: "view_item_list"; +} + +export interface ViewPromotionParams { + creative_name?: string; + creative_slot?: string; + promotion_id?: string; + promotion_name?: string; + items: AnalyticsItem[]; +} + +/** @docs https://developers.google.com/analytics/devguides/collection/ga4/reference/events?client_type=gtm#view_promotion */ +export interface ViewPromotionEvent extends IEvent { + name: "view_promotion"; +} + +export type AnalyticsEvent = + | AddShippingInfoEvent + | AddToCartEvent + | AddToWishlistEvent + | BeginCheckoutEvent + | LoginEvent + | RemoveFromCartEvent + | SearchEvent + | SelectItemEvent + | SelectPromotionEvent + | ViewCartEvent + | ViewItemEvent + | ViewItemListEvent + | ViewPromotionEvent;