All notable changes to the SDK will be documented in this file.
- Remove the promo messaging restriction for requests above $17,500
- Bug fixes
- Bug fixes
- Bug fixes
- Update version
- Bug fixes
- Bug fixes
- Bug fixes
- Bug fixes
- Bug fixes
- Bug fixes
- Bug fixes
- Bug fixes
- Bug fixes
- Added tests
- Bug fixes
- Updated the Affirm logo
- Bug fixes
- Updated Swift Package Manager Support
- Bug fixes
- Added Swift Package Manager Support
- Bug fix for promotional modal
- Enhancement for VCN checkout flow
- Add support for specifying Virtual Card Auth windows
- Enhanced Promo Messaging
- Hot fix to correct missing checkout token
- Bug fix and compatibility support
- Added CaaS support
- Added alternate checkout flow
- Added SKU based Financing Support
- Added parameters to product modal
- Added an example of product modal
- Bug-fix
- Added SDK size
- Added HTML support for AffirmDataHandler
- Update metadata
- Bug-fix
- Add webhook session ID
- Update logos
- Add support for CA currency
- Change promo endpoint
- Remove promoId dependency from ala messaging call
- Add iOS Callback callback
- Update iOS SDK to accept total amount
- Bug-fixes
- VCN Support null data
- Support for Blue and Black logo in text
- Bug Fixes
- Added navigation parameter for modal
- Contracts load in webview
- Version in metadata is inline with release
- Support type face, text size, and text color for promo messaging
- Support local fonts
- Handle empty ALA messages
- Shipping/Billing consistent with direct API requirements
- Add reason codes for VCN checkout cancellation
- Cannot exit checkout in Sandbox testing
- Minor Bug Fixes
- Updated modal configuration
- Custom CSS support in ALA messaging
- ALA messaging webviews
- ALA messaging logo and color support
- Updated sample controller implementation
- Button should be removed if ALA message is blank
- Added order_id
- HTML support in messaging
- Added page type
- Added session cookie
- Added method to remove cookies
-
Refactor code
- HTTP Networking
- Debug logging
- Event tracker
- SDK configuration and init
- Prequalify Flow
- Checkout Flow (direct + vcn)
- Exceptional Flows
- Activity indicator
- Track order confirmed
-
AffirmConfiguration
can be setup with simplified method. Current implementation is as follows:
[[AffirmConfiguration sharedInstance] configureWithPublicKey:@"PUBLIC_API_KEY" environment:AffirmEnvironmentSandbox];
AffirmCheckoutType
was deprecated, no need to pass this paramter when start checkout. Activity indicator was built into the webview controller, automatically show/hidden according to the loading progress. Current implementation is as follows:
AffirmCheckoutViewController *checkoutVC = [AffirmCheckoutViewController startCheckout:checkout delegate:self];
AffirmErrorModal
was deprecated. Developer can handle callback flexibly when checkout creation was failed.
- (void)checkout:(AffirmCheckoutViewController *)checkoutViewController didFailWithError:(NSError *)error;
-
AffirmAsLowAsButton
is modified toAffirmPromotionalButton
. Current implementation is as follows:AffirmPromotionalButton *button = [[AffirmPromotionalButton alloc] initWithPromoID:@"promoID" showCTA:showCTA pageType:@"pageType" presentingViewController:viewController frame:frame];
AffirmPromotionalButton
now suppports Interface builder.presentingViewController
must implementAffirmPrequalDelegate
. -
AffirmAsLowAsData
was deprecated. Promotional information is modified fromAffirmPromoRequest
, the processing of attribute text is encapsulated inAffirmPromotionalButton
. -
AffirmPrequalDelegate
provides a callback when prequalify flow fails. -
totalAmount
was renamed topayoutAmount
andtotal
was renamed tototalAmount
inAffirmCheckout
Class. -
AffirmOrderTrackerViewController
shows how to track an order confirmed, it requiresAffirmOrder
and a list ofAffirmProduct
.
- Updated VCN checkout
- Bug fixes
- VCN checkout
- Updated promo attributes
- Bug Fixes
- BUg fix for nil check for Tax and Shipping
- Updated the demo application
- Added total amount as an input parameter
- Added total amount tests
- Fixed ALA test and updated CDN endpoints
- Promo end point updated
- Prequal support added
- Affirm logos updated
- Fixed a crash when pricingTemplate was NSNull
- Added platform_type to metadata
- Fixed Carthage issue
- Removed CFBundleExecutable key from Info.plist
- Fixed AsLowAs lowest_apr parsing
- Internal bug fix
- Internal changes to ALA
- Added ALA tests
- Minor internal updates to checkout and error modal
- Fixed tracker domain
- Minor internal updates
- Fixed unit tests
- Minor fixes to logger
- Added Travis config
- Minor updates to SDK demo
- Added Carthage support for SDK installation
- UI Tests on SDK demo
- Calls to start the checkout process now require passing an
AffirmCheckoutType
(either Automatic or Manual) to specify whether the SDK should display a loading spinner and handle error notifications or that the developer will manually handle these states. The call to start the checkout process is now
[AffirmCheckoutViewController startCheckout:checkout checkoutType:AffirmCheckoutType delegate:self];
- Added AffirmAsLowAsButton that encapsulates the AffirmAsLowAs functionality in a button that handles all states and only requires the developer to add to their view and configure to implement. Tapping on the button automatically opens the appropriate promo modal
- Added AffirmErrorModal that displays error notifications in the checkout flow if the Automatic checkout type is selected
- Developers no longer need to configure AffirmAsLowAs text onto their label manually. The ALA functionality has been wrapped into a custom AffirmAsLowAsButton that handles all states and can be implemented as follows
AffirmAsLowAsButton *alaButton = [AffirmAsLowAsButton createButtonWithPromoID:@"promo_id" presentingViewController:self frame:frame];
[self.view addSubview:alaButton];
[alaButton configureWithAmount:amount affirmLogoType:AffirmLogoTypeName affirmColor:AffirmColorTypeBlue maxFontSize:18 callback:^(BOOL alaEnabled, NSError *error) {
//alaEnabled specifies whether ALA text or a default message is being displayed
}];
- Tapping on the ALA button automatically opens a product/site modal depending on whether ALA is enabled on the button
- The AffirmProductModal and AffirmSiteModal classes have now been merged into the AffirmPromoModal class. This modal can still be created and shown manually outside of tapping on the AffirmALAButton as follows
AffirmPromoModalViewController *promoVC = [AffirmPromoModalViewController promoModalControllerWithModalId:@"promo_id" amount:amount];
[self presentViewController:promoVC animated:YES completion:nil];
- AffirmAsLowAs has been broken into its own class and has been refactored to use a new endpoint internally
- The SDK now uses WKWebView internally to display all web content
- Fixed bug where the checkout VC would not close after the second open
- Delegate method that notifies when checkout ready to present
- Developer environment enums that must be specified when intializing a configuration
- Activity indicator that is automatically added/dismissed to denote loading state when presenting checkout or modal VCs
- Alternate checkout flow where the checkout VC is presented only when the checkoutReadyToPresent delegate method is fired. Helps avoid weird behavior where checkout VC pops up and immediately dismisses from screen in the case where checkout creation fails
- Descriptive error messages passed to an error's localizedDescription property
- AffirmConfiguration now only needs to be set once with a preset developer environment. As a result, all SDK methods no longer require passing a configuration object. Current implementation is as follows:
AffirmConfiguration *config = [AffirmConfiguration configurationWithPublicAPIKey:@"YOUR_API_KEY" environment:AffirmEnvironmentSandbox];
[AffirmConfiguration setSharedConfiguration:config];
- AffirmAsLowAs now returns the asLowAs text and an appropriately scaled logo image instead of modifying the attributed text on a passed label.
A helper method
appendLogo:(UIImage *)logo toText:(NSString *)text
has been provided to generate an attributed string that inserts the logo in the asLowAs text so it can be set to your label. - AffirmContact and AffirmAddress classes have been merged into the AffirmShippingDetail class
- Method that starts checkout process has been renamed to
[AffirmCheckoutViewController startCheckout:checkout withDelegate:self]
- AffirmItem object no longer requires passing an imageURL parameter
- AffirmDisplayType enum in the AffirmAsLowAs class has been renamed to AffirmLogoType