Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
@justeat/f-braze-adapter
Advanced tools
Braze Content Cards Interface.
This package provides an interface for initialising Braze and handling content cards and in-app messages.
Install the module using npm or Yarn:
yarn add @justeat/f-braze-adapter
npm install @justeat/f-braze-adapter
The package can then be imported into your application. You can use with import
or require
syntax:
import initialiseBraze from '@justeat/f-braze-adapter';
const initialiseBraze = require('@justeat/f-braze-adapter');
The package comes with one method for initialising Braze, or retrieving the already initialised module.
This method returns an instance of the BrazeAdapter class, which can also be used for logging interactions with braze elements returned from the API.
All other functionality, such as handling content cards or intercepting in-app messages can be done with callbacks passed through config.
Note that the noCookies
option is passed to
braze SDK as true
if the je-cookieConsent
cookie (as set by @justeat/f-cookie-banner
)
is not "full"
.
import initialise from '@justeat/f-braze-adapter'
const config = {
apiKey: '1234-1234-1234',
userId: 'ABC123',
enableLogging: true,
disableComponent: false,
callbacks: {
handleContentCards: cards => console.log(cards), // Braze content cards data
handleContentCardsGrouped: groupedCards => console.log(groupedCards), // Braze content cards data
interceptInAppMessages: inAppMessage => console.log(inAppMessage) // Braze in app message data
}
};
const brazePromise = initialise(config);
// The below assumes card data is being rendered into elements with class "brazeCard", that they
// have card data as returned by braze attached to a "data-content-card" attribute, and that all
// elements accessible via that css selector are visible
brazePromise.then(brazeAdapter => {
const brazeCards = document.querySelectorAll('.brazeCard');
let brazeCardsData = [];
brazeCards.forEach(brazeCard => {
brazeCardsData.push(brazeCard.dataset.contentCard);
brazeCard.addEventListener('click', clickEvent => {
brazeAdapter.logCardClick(brazeCard.dataset.contentCard);
});
});
brazeAdapter.logCardImpressions(brazeCardsData);
});
When the BrazeAdapter is no longer required, calling the unsubscribe method on the Adapter will remove it from the internal registry of consumers
brazeAdapter.unsubscribe();
config.apiKey
The Braze API key used when invoking calls to the Braze SDK. This can be found in the Braze Dashboard at App Settings->Developer Console->Rest API Keys.
config.brands
Sets the brands that the consumers have an interest in. Is concatenated to the current list of brands held by the Braze adapter.
config.userId
The user ID to retrieve data for.
config.enableLogging
Enable/Disable verbose logging from the Braze SDK used for debugging.
config.disableComponent
Enable/Disable the Braze SDK when running experiments or feature toggling.
config.callbacks.handleContentCards
A callback to be invoked when content cards have been retrieved.
config.callbacks.handleContentCardsGrouped
A callback to be invoked when content cards have been retrieved, grouped by header card title.
config.callbacks.interceptInAppMessages
A callback to be invoked when in-app messages have been retrieved.
Please note: The dispatcher fires callbacks registered for in-app messages before it triggers the messages.
config.callbacks.interceptInAppMessageClickEvents
The callback to be invoked when in-app messages have been clicked.
config.loggerCallbacks
A dictionary of functions that should accept the parameters:
level
String - one of (logInfo
|logWarn
|logError
)message
String - A useful log messagepayload
Object - Any other relevant info for loggingThis will be used to log out any information from the service. In a later version it will also be set up as a log target
for the braze SDK, based on the enableLogging
configuration value.
Version 2 exposes the appboy instance as opposed to content cards as part of the refresh callback, this makes it easier to access properties on the instance such as getUnviewedCardCount
and is a step closer to an isomorphic solution.
Cards are now accessible on myCallbackMethod.cards
.
For example
// v1 implementation
const myCallback = cards => console.log(cards); // [...cards]
appboy.requestImmediateRefresh();
// [...cards]
// v2 implementation
const myCallback = cardsInstance => console.log(cardsInstance); // {cards: [...cards]}
appboy.requestImmediateRefresh();
// { cards: [...cards]}
Name | Description | Link |
---|---|---|
Appboy Technical Documentation | All documentation associated to the Javascript web SDK | https://js.appboycdn.com/web-sdk/2.5/doc/module-appboy.html |
Appboy GitHub Repo | Code repo and issue tracking | https://github.com/Appboy/appboy-web-sdk |
v4.2.0
October 5, 2021
fozzie
package version bump to 6.0.0-beta.5 to include new colour theme and radius vars.FAQs
Fozzie Metadata Service
The npm package @justeat/f-braze-adapter receives a total of 2 weekly downloads. As such, @justeat/f-braze-adapter popularity was classified as not popular.
We found that @justeat/f-braze-adapter demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 29 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.