From 5e587b513928f64d4d2e893b250c5ce32268b9f5 Mon Sep 17 00:00:00 2001 From: Steve Benedick Date: Mon, 24 Jun 2024 16:52:59 -0600 Subject: [PATCH 1/4] -adding docs for content cards release --- gatsby-config.js | 32 ++- .../code-based/index.md | 13 +- .../content-card-schema-data.md | 187 ++++++++++++++++++ .../public-classes/content-card.md | 140 +++++++++++++ .../html-content-schema-data.md | 47 +++++ .../public-classes/inapp-schema-data.md | 83 ++++++++ .../public-classes/index.md | 7 +- .../json-content-schema-data.md | 45 +++++ .../public-classes/proposition-item.md | 104 +++++++--- .../public-classes/tabs/proposition-item.md | 20 ++ 10 files changed, 635 insertions(+), 43 deletions(-) create mode 100644 src/pages/edge/adobe-journey-optimizer/public-classes/content-card-schema-data.md create mode 100644 src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md create mode 100644 src/pages/edge/adobe-journey-optimizer/public-classes/html-content-schema-data.md create mode 100644 src/pages/edge/adobe-journey-optimizer/public-classes/inapp-schema-data.md create mode 100644 src/pages/edge/adobe-journey-optimizer/public-classes/json-content-schema-data.md diff --git a/gatsby-config.js b/gatsby-config.js index 08458ed89b..e037f96044 100644 --- a/gatsby-config.js +++ b/gatsby-config.js @@ -240,7 +240,7 @@ module.exports = { ] }, { - title: "Code-based Experiences", + title: "Code-based Experiences & Content Cards", path: "/edge/adobe-journey-optimizer/code-based", pages: [ { @@ -248,7 +248,7 @@ module.exports = { path: "/edge/adobe-journey-optimizer/code-based/api-reference" }, { - title: "Tutorial", + title: "Code-based Tutorial", path: "/edge/adobe-journey-optimizer/code-based/tutorial" } ] @@ -258,12 +258,24 @@ module.exports = { path: "/edge/adobe-journey-optimizer/public-classes", pages: [ { - title: "MessagingPushPayload", - path: "/edge/adobe-journey-optimizer/public-classes/messaging-push-payload" + title: "ContentCard", + path: "/edge/adobe-journey-optimizer/public-classes/content-card" }, { - title: "PushTrackingStatus", - path: "/edge/adobe-journey-optimizer/public-classes/push-tracking-status" + title: "ContentCardSchemaData", + path: "/edge/adobe-journey-optimizer/public-classes/content-card-schema-data" + }, + { + title: "HtmlContentSchemaData", + path: "/edge/adobe-journey-optimizer/public-classes/html-content-schema-data" + }, + { + title: "InAppSchemaData", + path: "/edge/adobe-journey-optimizer/public-classes/inapp-schema-data" + }, + { + title: "JsonContentSchemaData", + path: "/edge/adobe-journey-optimizer/public-classes/json-content-schema-data" }, { title: "Message", @@ -273,6 +285,10 @@ module.exports = { title: "MessagingEdgeEventType", path: "/edge/adobe-journey-optimizer/public-classes/messaging-edge-event-type" }, + { + title: "MessagingPushPayload", + path: "/edge/adobe-journey-optimizer/public-classes/messaging-push-payload" + }, { title: "Proposition", path: "/edge/adobe-journey-optimizer/public-classes/proposition" @@ -281,6 +297,10 @@ module.exports = { title: "PropositionItem", path: "/edge/adobe-journey-optimizer/public-classes/proposition-item" }, + { + title: "PushTrackingStatus", + path: "/edge/adobe-journey-optimizer/public-classes/push-tracking-status" + }, { title: "Surface", path: "/edge/adobe-journey-optimizer/public-classes/surface" diff --git a/src/pages/edge/adobe-journey-optimizer/code-based/index.md b/src/pages/edge/adobe-journey-optimizer/code-based/index.md index d59cc56296..876d919ede 100644 --- a/src/pages/edge/adobe-journey-optimizer/code-based/index.md +++ b/src/pages/edge/adobe-journey-optimizer/code-based/index.md @@ -17,7 +17,12 @@ This document guides you to integrating code-based experiences in your applicati ## Public Classes and Enums -* [Class - Proposition](../public-classes/proposition.md) -* [Class - PropositionItem](../public-classes/proposition-item.md) -* [Enum - MessagingEdgeEventType](../public-classes/messaging-edge-event-type.md) -* [Class - Surface](../public-classes/surface.md) +* [Class - ContentCard](./../public-classes/content-card.md) +* [Class - Proposition](./../public-classes/proposition.md) +* [Class - PropositionItem](./../public-classes/proposition-item.md) +* [Class - Surface](./../public-classes/surface.md) +* [Enum - MessagingEdgeEventType](./../public-classes/messaging-edge-event-type.md) +* [Schema Class - ContentCardSchemaData](./../public-classes/content-card-schema-data.md) +* [Schema Class - HtmlContentSchemaData](./../public-classes/html-content-schema-data.md) +* [Schema Class - InAppSchemaData](./../public-classes/inapp-schema-data.md) +* [Schema Class - JsonContentSchemaData](./../public-classes/json-content-schema-data.md) diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card-schema-data.md b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card-schema-data.md new file mode 100644 index 0000000000..ba730ba6e2 --- /dev/null +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card-schema-data.md @@ -0,0 +1,187 @@ +--- +title: ContentCardSchemaData +description: The `ContentCardSchemaData` class represents a "content-card" proposition received from the remote, upon a personalization query request to the Experience Edge network. +keywords: +- Adobe Journey Optimizer +- Messaging +- Proposition +- Interface +- Android +- iOS +- Code-based Experiences +- Content Cards +--- + +# ContentCardSchemaData + +Represents the proposition response object containing a `content-card` schema. + +## iOS Interface + +```swift +@objc(AEPContentCardSchemaData) +@objcMembers +public class ContentCardSchemaData: NSObject, Codable { + /// Represents the content of the ContentCardSchemaData object. Its value's type is determined by `contentType`. + public let content: Any + + /// Determines the value type of `content`. + public let contentType: ContentType + + /// Date and time this content card was published represented as epoch seconds + public let publishedDate: Int? + + /// Date and time this content card will expire represented as epoch seconds + public let expiryDate: Int? + + /// Dictionary containing any additional meta data for this content card + public let meta: [String: Any]? + + ... +} +``` + +### Public functions + +--- + +### getContentCard + +Tries to convert the `content` of this `ContentCardSchemaData` into a [`ContentCard`](./content-card.md) object. + +Returns `nil` if the `contentType` is not equal to `.applicationJson` or the data in `content` is not decodable into a `ContentCard`. + +#### Syntax + +```swift +func getContentCard() -> ContentCard? +``` + +#### Example + +```swift +var propositionItem: PropositionItem +if let contentCardSchemaData = propositionItem.contentCardSchemaData, + let contentCard = contentCardSchemaData.getContentCard() { + // do something with the ContentCard object +} +``` + +### track(_:withEdgeEventType:) + +Tracks an interaction with the given `ContentCardSchemaData`. + +#### Syntax + +```swift +public func track(_ interaction: String? = nil, withEdgeEventType eventType: MessagingEdgeEventType) +``` + +#### Parameters + +- _interaction_ - a custom `String` value to be recorded in the interaction +- _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event + +#### Example + +```swift +var contentCardSchemaData: ContentCardSchemaData + +// tracking a display +contentCardSchemaData.track(withEdgeEventType: .display) + +// tracking a user interaction +contentCardSchemaData.track("itemSelected", withEdgeEventType: .interact) +``` + + +## Android Interface + +```java +public class ContentCardSchemaData implements SchemaData { + private Object content; + private ContentType contentType; + private int publishedDate; + private int expiryDate; + private Map meta; + + @Override + public Object getContent() { + return content; + } + + public ContentType getContentType() { + return contentType; + } + + public int getPublishedDate() { + return publishedDate; + } + + public int getExpiryDate() { + return expiryDate; + } + + @Nullable public Map getMeta() { + return meta; + } + + ... +} +``` + +### Public functions + +--- + +### getContentCard + +Tries to convert the `content` of this `ContentCardSchemaData` into a [`ContentCard`](./content-card.md) object. + +Returns `nil` if the `contentType` is not equal to `.applicationJson` or the data in `content` is not decodable into a `ContentCard`. + +#### Syntax + +```java +@Nullable public ContentCard getContentCard(); +``` + +#### Example + +```java +PropositionItem propositionItem; +ContentCardSchemaData contentCardSchemaData = propositionItem.getContentCardSchemaData(); +if (contentCardSchemaData != null) { + ContentCard contentCard = contentCardSchemaData.getContentCard(); + if (contentCard != null) { + // do something with the ContentCard object + } +} +``` + +### track + +Tracks an interaction with the given `ContentCardSchemaData`. + +#### Syntax + +```java +public void track(final String interaction, final MessagingEdgeEventType eventType); +``` + +#### Parameters + +- _interaction_ - a custom `String` value to be recorded in the interaction +- _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event + +#### Example + +```java +ContentCardSchemaData contentCardSchemaData; + +// tracking a display +contentCardSchemaData.track(null, MessagingEdgeEventType.display); + +// tracking a user interaction +contentCardSchemaData.track("itemSelected", MessagingEdgeEventType.interact); +``` diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md new file mode 100644 index 0000000000..2d27832dcb --- /dev/null +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md @@ -0,0 +1,140 @@ +--- +title: ContentCard +description: An object representing the default content card created in the Adobe Journey Optimizer UI. +keywords: +- Adobe Journey Optimizer +- Messaging +- Proposition +- Interface +- Android +- iOS +- Code-based Experiences +- Content Cards +- Content Card +--- + +# ContentCard + +An object representing the default content card created in the Adobe Journey Optimizer UI. + +Content cards must be rendered by the app developer. Tracking a content card is done via calls to the [`track(_:withEdgeEventType:)`](#track_withedgeeventtype) API. + +## iOS Interface + +```swift +@objc(AEPContentCard) +@objcMembers +public class ContentCard: NSObject, Codable { + /// Plain-text title for the content card + public let title: String + + /// Plain-text body representing the content for the content card + public let body: String + + /// String representing a URI that contains an image to be used for this content card + public let imageUrl: String? + + /// Contains a URL to be opened if the user interacts with the content card + public let actionUrl: String? + + /// Required if `actionUrl` is provided. Text to be used in title of button or link in content card + public let actionTitle: String? + + ... +} +``` + +### Public functions + +--- + +### track(_:withEdgeEventType:) + +Tracks an interaction with the given `ContentCard`. + +#### Syntax + +```swift +public func track(_ interaction: String? = nil, withEdgeEventType eventType: MessagingEdgeEventType) +``` + +#### Parameters + +- _interaction_ - a custom `String` value to be recorded in the interaction +- _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event + +#### Example + +```swift +var contentCard: ContentCard + +// tracking a display +contentCard.track(withEdgeEventType: .display) + +// tracking a user interaction +contentCard.track("itemSelected", withEdgeEventType: .interact) +``` + +## Android Interface + +```java +public class ContentCard { + // Plain-text title for the content card + private String title; + + // Plain-text body representing the content for the content card + private String body; + + // String representing a URI that contains an image to be used for this content card + private String imageUrl; + + // Contains a URL to be opened if the user interacts with the content card + private String actionUrl; + + // Required if actionUrl is provided. Text to be used in title of button or link in content card + private String actionTitle; + + public String getTitle() { return title; } + + public String getBody() { return body; } + + @Nullable public String getImageUrl() { return imageUrl; } + + @Nullable public String getActionUrl() { return actionUrl; } + + @Nullable public String getActionTitle() { return actionTitle; } + + ... +} +``` + +### Public functions + +--- + +### track + +Tracks an interaction with the given `ContentCard`. + +#### Syntax + +```java +public void track(final String interaction, final MessagingEdgeEventType eventType); +``` + +#### Parameters + +- _interaction_ - a custom `String` value to be recorded in the interaction +- _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event + +#### Example + +```java +ContentCard contentCard; + +// tracking a display +contentCardSchemaData.track(null, MessagingEdgeEventType.display); + +// tracking a user interaction +contentCardSchemaData.track("itemSelected", MessagingEdgeEventType.interact); +``` diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/html-content-schema-data.md b/src/pages/edge/adobe-journey-optimizer/public-classes/html-content-schema-data.md new file mode 100644 index 0000000000..7c4ec29e6a --- /dev/null +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/html-content-schema-data.md @@ -0,0 +1,47 @@ +--- +title: HtmlContentSchemaData +description: The `HtmlContentSchemaData` class represents a "html-content" proposition received from the remote, upon a personalization query request to the Experience Edge network. +keywords: +- Adobe Journey Optimizer +- Messaging +- Proposition +- Interface +- Android +- iOS +- Code-based Experiences +- Content Cards +--- + +# HtmlContentSchemaData + +Represents the proposition response object containing a `html-content` schema. + +## iOS Interface + +```swift +@objc(AEPHtmlContentSchemaData) +@objcMembers +public class HtmlContentSchemaData: NSObject, Codable { + /// Represents the content of the HtmlContentSchemaData object. + public let content: String + + /// Determines the value type of `content`. For HtmlContentSchemaData objects, this value is always `.textHtml`. + public let format: ContentType? + + ... +} +``` + +## Android Interface + +```java +public class HtmlContentSchemaData implements SchemaData { + private String content = null; + private ContentType format = null; + + @Override + @Nullable public String getContent() { return content; } + + public ContentType getFormat() { return format; } +} +``` diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/inapp-schema-data.md b/src/pages/edge/adobe-journey-optimizer/public-classes/inapp-schema-data.md new file mode 100644 index 0000000000..a88aa7628e --- /dev/null +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/inapp-schema-data.md @@ -0,0 +1,83 @@ +--- +title: InAppSchemaData +description: The `InAppSchemaData` class represents a "in-app" proposition received from the remote, upon a personalization query request to the Experience Edge network. +keywords: +- Adobe Journey Optimizer +- Messaging +- Proposition +- Interface +- Android +- iOS +- Code-based Experiences +- Content Cards +--- + +# InAppSchemaData + +Represents the proposition response object containing a `in-app` schema. + +## iOS Interface + +```swift +@objc(AEPInAppSchemaData) +@objcMembers +public class InAppSchemaData: NSObject, Codable { + /// Represents the content of the InAppSchemaData object. Its value's type is determined by `contentType`. + public let content: Any + + /// Determines the value type of `content`. + public let contentType: ContentType + + /// Date and time this in-app campaign was published represented as epoch seconds + public let publishedDate: Int? + + /// Date and time this in-app campaign will expire represented as epoch seconds + public let expiryDate: Int? + + /// Dictionary containing any additional meta data for this content card + public let meta: [String: Any]? + + /// Dictionary containing parameters that help control display and behavior of the in-app message on mobile + public let mobileParameters: [String: Any]? + + /// Dictionary containing parameters that help control display and behavior of the in-app message on web + public let webParameters: [String: Any]? + + /// Array of remote assets to be downloaded and cached for future use with the in-app message + public let remoteAssets: [String]? + + ... +} +``` + +## Android Interface + +```java +public class InAppSchemaData implements SchemaData { + private Object content = null; + private ContentType contentType = null; + private int publishedDate = 0; + private int expiryDate = 0; + private Map meta = null; + private Map mobileParameters = null; + private Map webParameters = null; + private List remoteAssets = null; + + @Override + public Object getContent() { return content; } + + public ContentType getContentType() { return contentType; } + + public int getPublishedDate() { return publishedDate; } + + public int getExpiryDate() { return expiryDate; } + + @Nullable public Map getMeta() { return meta; } + + @Nullable public Map getMobileParameters() { return mobileParameters; } + + @Nullable public Map getWebParameters() { return webParameters; } + + @Nullable public List getRemoteAssets() { return remoteAssets; } +} +``` diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/index.md b/src/pages/edge/adobe-journey-optimizer/public-classes/index.md index 82d4797ec0..58d0958473 100644 --- a/src/pages/edge/adobe-journey-optimizer/public-classes/index.md +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/index.md @@ -25,9 +25,14 @@ This documents lists details about the public classes and enums available in Mes * [Class - Message](./message.md) * [Enum - MessagingEdgeEventType](./messaging-edge-event-type.md) -## Code-based experiences +## Proposition-based messaging
\(Code-based experiences & Content Cards) +* [Class - ContentCard](./content-card.md) * [Class - Proposition](./proposition.md) * [Class - PropositionItem](./proposition-item.md) * [Class - Surface](./surface.md) * [Enum - MessagingEdgeEventType](./messaging-edge-event-type.md) +* [Schema Class - ContentCardSchemaData](./content-card-schema-data.md) +* [Schema Class - HtmlContentSchemaData](./html-content-schema-data.md) +* [Schema Class - InAppSchemaData](./inapp-schema-data.md) +* [Schema Class - JsonContentSchemaData](./json-content-schema-data.md) diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/json-content-schema-data.md b/src/pages/edge/adobe-journey-optimizer/public-classes/json-content-schema-data.md new file mode 100644 index 0000000000..8b6b5e587d --- /dev/null +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/json-content-schema-data.md @@ -0,0 +1,45 @@ +--- +title: JsonContentSchemaData +description: The `JsonContentSchemaData` class represents a "json-content" proposition received from the remote, upon a personalization query request to the Experience Edge network. +keywords: +- Adobe Journey Optimizer +- Messaging +- Proposition +- Interface +- Android +- iOS +- Code-based Experiences +- Content Cards +--- + +# JsonContentSchemaData + +Represents the proposition response object containing a `json-content` schema. + +## iOS Interface + +```swift +@objc(AEPJsonContentSchemaData) +@objcMembers +public class JsonContentSchemaData: NSObject, Codable { + /// Represents the content of the JsonContentSchemaData object. Its value's type is determined by `format`. + public let content: Any + + /// Determines the value type of `content`. + public let format: ContentType? + + ... +} +``` + +## Android Interface + +```java +public class JsonContentSchemaData implements SchemaData { + private Object content = null; + private ContentType format = null; + + @Override + @Nullable public Object getContent() { return content; } +} +``` diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/proposition-item.md b/src/pages/edge/adobe-journey-optimizer/public-classes/proposition-item.md index f3fbeb1ff0..a09368d019 100644 --- a/src/pages/edge/adobe-journey-optimizer/public-classes/proposition-item.md +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/proposition-item.md @@ -16,16 +16,36 @@ import Tabs from './tabs/proposition-item.md' The `PropositionItem` class represents the decision proposition item received from the remote, upon a personalization query to the Experience Edge network. -## iOS Interface - PropositionItem +## iOS Interface ## Public variables -### itemId +### contentCardSchemaData -Unique proposition item identifier. +Decodes and returns item data content as an [ContentCardSchemaData](./content-card-schema-data.md) object. + +Returns `nil` if decoding fails or if the proposition item schema is not `.contentCard`. ```swift -public let itemId: String +var contentCardSchemaData: ContentCardSchemaData? +``` + +### htmlContent + +Returns item data content as a string if the proposition item schema is `htmlContent`, otherwise returns `nil`. + +```swift +var htmlContent: String? +``` + +### inappSchemaData + +Decodes and returns item data content as an [InAppSchemaData](./inapp-schema-data.md) object. + +Returns `nil` if decoding fails or if the proposition item schema is not `.inApp`. + +```swift +var inappSchemaData: InAppSchemaData? ``` ### itemData @@ -36,20 +56,20 @@ Proposition item data as dictionary. public let itemData: [String: Any] ``` -### schema +### itemId -Proposition item schema string. +Unique proposition item identifier. ```swift -public let schema: String +public let itemId: String ``` -### htmlContent +### jsonContentArray -Returns item data content as a string if the proposition item schema is `htmlContent`, otherwise returns `nil`. +Returns item data content as an array if it can be parsed as an array and if the proposition item schema is `jsonContent`, otherwise returns `nil`. ```swift -var htmlContent: String? +var jsonContentArray: [Any]? ``` ### jsonContentDictionary @@ -60,12 +80,12 @@ Returns item data content as a dictionary if it can be parsed as a dictionary an var jsonContentDictionary: [String: Any]? ``` -### jsonContentArray +### schema -Returns item data content as an array if it can be parsed as an array and if the proposition item schema is `jsonContent`, otherwise returns `nil`. +Proposition item schema string. ```swift -var jsonContentArray: [Any]? +public let schema: String ``` ## Public functions @@ -90,39 +110,39 @@ iOS -## Android Interface - PropositionItem +## Android Interface ## Public functions -### getItemId +### generateInteractionXdm -Returns this proposition item's unique identifier as a string. +Returns a Map containing XDM data for interaction with the given proposition item, for the provided event type. Android - + -### getItemData +### generateInteractionXdm -Returns this proposition's unique identifier as a string. +Returns a Map containing XDM data for interaction with the given proposition item, for the provided event type and decision item tokens. Android - + -### getSchema +### getContentCardSchemaData -Returns this proposition item's content schema as a string. +Decodes and returns this proposition item's content schema as a [ContentCardSchemaData](./content-card-schema-data.md), or `null` if decoding fails. Android - + ### getHtmlContent @@ -134,15 +154,35 @@ Android -### getJsonContentMap +### getInAppSchemaData -Returns item data content as a Map if it can be parsed as a Map and if the proposition item schema is `JSON_CONTENT`, otherwise returns null. +Decodes and returns this proposition item's content schema as a [InAppSchemaData](./inapp-schema-data.md), or `null` if decoding fails. Android - + + +### getItemData + +Returns this proposition's unique identifier as a string. + + + +Android + + + +### getItemId + +Returns this proposition item's unique identifier as a string. + + + +Android + + ### getJsonContentArrayList @@ -154,25 +194,25 @@ Android -### generateInteractionXdm +### getJsonContentMap -Returns a Map containing XDM data for interaction with the given proposition item, for the provided event type. +Returns item data content as a Map if it can be parsed as a Map and if the proposition item schema is `JSON_CONTENT`, otherwise returns null. Android - + -### generateInteractionXdm +### getSchema -Returns a Map containing XDM data for interaction with the given proposition item, for the provided event type and decision item tokens. +Returns this proposition item's content schema as a string. Android - + ### track diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/tabs/proposition-item.md b/src/pages/edge/adobe-journey-optimizer/public-classes/tabs/proposition-item.md index 0db0b2b124..5d43dea8ce 100644 --- a/src/pages/edge/adobe-journey-optimizer/public-classes/tabs/proposition-item.md +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/tabs/proposition-item.md @@ -30,6 +30,26 @@ func track(_ interaction: String? = nil, withEdgeEventType eventType: MessagingE * _eventType_ is an enum specifying event type for the interaction. * _tokens_ is an array containing the decision item tokens for recording interaction. + + +#### Java + +**Syntax** + +```java +public ContentCardSchemaData getContentCardSchemaData() +``` + + + +#### Java + +**Syntax** + +```java +public InAppSchemaData getInAppSchemaData() +``` + #### Java From 8d9217a976114d80e2dcdf05229b12ec44645633 Mon Sep 17 00:00:00 2001 From: Steve Benedick Date: Mon, 24 Jun 2024 17:04:51 -0600 Subject: [PATCH 2/4] -fix linter --- .../public-classes/content-card-schema-data.md | 9 ++++----- .../public-classes/content-card.md | 8 ++++---- .../public-classes/proposition-item.md | 4 ++-- 3 files changed, 10 insertions(+), 11 deletions(-) diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card-schema-data.md b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card-schema-data.md index ba730ba6e2..471e69d942 100644 --- a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card-schema-data.md +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card-schema-data.md @@ -79,8 +79,8 @@ public func track(_ interaction: String? = nil, withEdgeEventType eventType: Mes #### Parameters -- _interaction_ - a custom `String` value to be recorded in the interaction -- _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event +* _interaction_ - a custom `String` value to be recorded in the interaction +* _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event #### Example @@ -94,7 +94,6 @@ contentCardSchemaData.track(withEdgeEventType: .display) contentCardSchemaData.track("itemSelected", withEdgeEventType: .interact) ``` - ## Android Interface ```java @@ -171,8 +170,8 @@ public void track(final String interaction, final MessagingEdgeEventType eventTy #### Parameters -- _interaction_ - a custom `String` value to be recorded in the interaction -- _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event +* _interaction_ - a custom `String` value to be recorded in the interaction +* _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event #### Example diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md index 2d27832dcb..410b137348 100644 --- a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md @@ -60,8 +60,8 @@ public func track(_ interaction: String? = nil, withEdgeEventType eventType: Mes #### Parameters -- _interaction_ - a custom `String` value to be recorded in the interaction -- _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event +* _interaction_ - a custom `String` value to be recorded in the interaction +* _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event #### Example @@ -124,8 +124,8 @@ public void track(final String interaction, final MessagingEdgeEventType eventTy #### Parameters -- _interaction_ - a custom `String` value to be recorded in the interaction -- _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event +* _interaction_ - a custom `String` value to be recorded in the interaction +* _eventType_ - the [`MessagingEdgeEventType`](./messaging-edge-event-type.md) to be used for the ensuing Edge Event #### Example diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/proposition-item.md b/src/pages/edge/adobe-journey-optimizer/public-classes/proposition-item.md index a09368d019..44df2f95fd 100644 --- a/src/pages/edge/adobe-journey-optimizer/public-classes/proposition-item.md +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/proposition-item.md @@ -22,7 +22,7 @@ The `PropositionItem` class represents the decision proposition item received fr ### contentCardSchemaData -Decodes and returns item data content as an [ContentCardSchemaData](./content-card-schema-data.md) object. +Decodes and returns item data content as an [ContentCardSchemaData](./content-card-schema-data.md) object. Returns `nil` if decoding fails or if the proposition item schema is not `.contentCard`. @@ -40,7 +40,7 @@ var htmlContent: String? ### inappSchemaData -Decodes and returns item data content as an [InAppSchemaData](./inapp-schema-data.md) object. +Decodes and returns item data content as an [InAppSchemaData](./inapp-schema-data.md) object. Returns `nil` if decoding fails or if the proposition item schema is not `.inApp`. From 111fa55bab69e61e14b5fc7d43b11c2f982cb0d6 Mon Sep 17 00:00:00 2001 From: Steve Benedick Date: Tue, 25 Jun 2024 08:14:24 -0600 Subject: [PATCH 3/4] -fix some formatting --- .../edge/adobe-journey-optimizer/public-classes/content-card.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md index 410b137348..58128a42b6 100644 --- a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md @@ -17,7 +17,7 @@ keywords: An object representing the default content card created in the Adobe Journey Optimizer UI. -Content cards must be rendered by the app developer. Tracking a content card is done via calls to the [`track(_:withEdgeEventType:)`](#track_withedgeeventtype) API. +Content cards must be rendered by the app developer. Tracking a content card is done via calls to the [`track(_:withEdgeEventType:)`](#track_withedgeeventtype) API. ## iOS Interface From 1e51d9755db6b8b035ca1ebeedece300320ce774 Mon Sep 17 00:00:00 2001 From: Steve Benedick Date: Tue, 25 Jun 2024 11:05:26 -0600 Subject: [PATCH 4/4] -more feedback from pr and adding ContentType enum --- gatsby-config.js | 4 ++ .../public-classes/content-card.md | 4 +- .../public-classes/content-type.md | 45 +++++++++++++++ .../public-classes/index.md | 1 + .../public-classes/tabs/content-type.md | 57 +++++++++++++++++++ 5 files changed, 109 insertions(+), 2 deletions(-) create mode 100644 src/pages/edge/adobe-journey-optimizer/public-classes/content-type.md create mode 100644 src/pages/edge/adobe-journey-optimizer/public-classes/tabs/content-type.md diff --git a/gatsby-config.js b/gatsby-config.js index 211043c400..da24c2ebbb 100644 --- a/gatsby-config.js +++ b/gatsby-config.js @@ -265,6 +265,10 @@ module.exports = { title: "ContentCardSchemaData", path: "/edge/adobe-journey-optimizer/public-classes/content-card-schema-data" }, + { + title: "ContentType", + path: "/edge/adobe-journey-optimizer/public-classes/content-type" + }, { title: "HtmlContentSchemaData", path: "/edge/adobe-journey-optimizer/public-classes/html-content-schema-data" diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md index 58128a42b6..3c02e3fa25 100644 --- a/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/content-card.md @@ -133,8 +133,8 @@ public void track(final String interaction, final MessagingEdgeEventType eventTy ContentCard contentCard; // tracking a display -contentCardSchemaData.track(null, MessagingEdgeEventType.display); +contentCard.track(null, MessagingEdgeEventType.display); // tracking a user interaction -contentCardSchemaData.track("itemSelected", MessagingEdgeEventType.interact); +contentCard.track("itemSelected", MessagingEdgeEventType.interact); ``` diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/content-type.md b/src/pages/edge/adobe-journey-optimizer/public-classes/content-type.md new file mode 100644 index 0000000000..8f46201274 --- /dev/null +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/content-type.md @@ -0,0 +1,45 @@ +--- +title: ContentType +description: Enum representing the ContentTypes used in schema-based objects. +keywords: +- Adobe Journey Optimizer +- Messaging +- iOS +- Android +- Proposition +- Schema +- ContentType +- Content type +--- + +import Tabs from './tabs/content-type.md' + +# Enum - ContentType + +Enum representing content types found within a schema object. + +## Definition + + + +Android + + + +iOS + + + +## String values + +Below is the table of values returned by calling the `toString` method for each case: + + + +Android + + + +iOS + + diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/index.md b/src/pages/edge/adobe-journey-optimizer/public-classes/index.md index 58d0958473..105e44bc38 100644 --- a/src/pages/edge/adobe-journey-optimizer/public-classes/index.md +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/index.md @@ -31,6 +31,7 @@ This documents lists details about the public classes and enums available in Mes * [Class - Proposition](./proposition.md) * [Class - PropositionItem](./proposition-item.md) * [Class - Surface](./surface.md) +* [Enum - ContentType](./content-type.md) * [Enum - MessagingEdgeEventType](./messaging-edge-event-type.md) * [Schema Class - ContentCardSchemaData](./content-card-schema-data.md) * [Schema Class - HtmlContentSchemaData](./html-content-schema-data.md) diff --git a/src/pages/edge/adobe-journey-optimizer/public-classes/tabs/content-type.md b/src/pages/edge/adobe-journey-optimizer/public-classes/tabs/content-type.md new file mode 100644 index 0000000000..b4d0ce09f5 --- /dev/null +++ b/src/pages/edge/adobe-journey-optimizer/public-classes/tabs/content-type.md @@ -0,0 +1,57 @@ +--- +noIndex: true +--- + + + +#### Java + +```java +public enum ContentType { + APPLICATION_JSON(0), + TEXT_HTML(1), + TEXT_XML(2), + TEXT_PLAIN(3), + UNKNOWN(4); + + @Override + public String toString(); +} +``` + + + +#### Swift + +```swift +@objc(AEPContentType) +public enum ContentType: Int, Codable { + case applicationJson = 0 + case textHtml = 1 + case textXml = 2 + case textPlain = 3 + case unknown = 4 + + public func toString() -> String +} +``` + + + +| Case | String value | +| ---- | ------------ | +| `APPLICATION_JSON` | `application/json` | +| `TEXT_HTML` | `text/html` | +| `TEXT_XML` | `text/xml` | +| `TEXT_PLAIN` | `text/plain` | +| `UNKNOWN` | (empty string) | + + + +| Case | String value | +| ---- | ------------ | +| `.applicationJson` | `application/json` | +| `.testHtml` | `text/html` | +| `.textXml` | `text/xml` | +| `.textPlain` | `text/plain` | +| `.unknown` | (empty string) |