\r\n \r\nAs a foundation of the partnership, Punchh and Olo have developed full integrations between their respective platforms. This combination now tightly couples Olo’s digital ordering with Punchh’s CRM and Mobile Engagement Suite (loyalty, offers, and more) for restaurant brands that choose both platforms. \r\n \r\nIn the first of several forthcoming projects featuring native Olo ordering integration, Punchh has launched the new MOOYAH Burgers, Fries, & Shakes mobile application for iOS and Android. The new apps provide customers with a seamless user experience for loyalty and ordering, enabling guests to earn and redeem rewards in-store or via digital ordering - functionality made possible by Punchh’s Single Sign On (SSO) and Loyalty API technology. \r\n \r\nThe launch of this combination now provides restaurants using Olo & Punchh with a comprehensive set of offer capabilities at their disposal to drive online orders, including %-off, $-off and SKU-level promotions."}]}};
const country = "US";
const language = "en-US,en;q=0.5";
const SITE_LANGUAGE = "en";
const siteName = "Hospitality Technology";
const userRoles = ["anonymous"];
const userUid = 0;
const indexName = "HT";
window.dataLayer = window.dataLayer || [];
const data = {};
data.entityTaxonomy = {};
const contentTypes = [
"article",
"blog",
"bulletin",
"embed_page",
"landing_page",
"event",
"image",
"page",
"product",
"whitepaper",
"video",
"tags",
];
if (
routeInfo &&
"bundle" in routeInfo &&
contentTypes.includes(routeInfo["bundle"])
) {
data.entityBundle = routeInfo.bundle;
data.entityTitle = `${routeInfo.title} | ${siteName}`;
data.entityId = routeInfo.id;
data.entityName = routeInfo.author?.uname;
data.entityCreated = routeInfo.created;
data.sponsored = routeInfo.sponsored;
data.sponsor = routeInfo.sponsoringCompany;
data.entityType = "node";
data.entityLangcode = SITE_LANGUAGE;
data.siteName = siteName;
data.drupalLanguage = language;
data.drupalCountry = country;
data.userRoles = userRoles;
data.userUid = userUid;
data.entityTaxonomyKeys = {};
data.entityTaxonomyHierarchies = {};
data.parentNaicsCode = {};
data.isPro = false;
data.algoliaIndexName = indexName;
// Add toxonomy data
const taxonomies = {
businessTopic: "business_topic",
contentType: "content_type",
company: "company",
marketSegment: "market_segment",
};
const getHierarchy = (term, terms = []) => {
terms.push({ id: term.id, name: term.name });
if (term.parentTerm != null) {
getHierarchy(term.parentTerm, terms);
}
return terms;
};
const getTerms = (term, useApiId = false) => {
return { id: useApiId ? term.apiId : term.id, name: term.name };
};
const getKeys = (term) => {
return { id: term.id, name: term.apiId };
};
Object.entries(taxonomies).forEach(([key, item]) => {
terms = routeInfo[key];
if (terms && terms.length > 0) {
data["entityTaxonomy"][item] = terms.map((term) =>
getTerms(term, key === "company")
);
if (key !== "company") {
data["entityTaxonomyKeys"][item] = terms.map(getKeys);
termGroups = [];
terms.forEach((term, termInd) => {
termGroups[termInd] = getHierarchy(term);
});
data["entityTaxonomyHierarchies"][item] = termGroups;
}
}
});
data["entityTaxonomy"]["tags"] = routeInfo["topics"] || [];
// Primary Topic is either the business topic or the top tag.
if (routeInfo["businessTopic"]?.length > 0) {
data["entityPrimaryTopic"] = routeInfo["businessTopic"][0]["name"];
} else {
if (routeInfo["topics"]?.length > 0) {
data["entityPrimaryTopic"] = routeInfo["topics"][0]["name"];
}
}
// Primary and secondary entityNaicsCodes come from the MarketSegment
if (routeInfo.marketSegment?.length > 0) {
data.entityNaicsCode = {};
data["entityNaicsCode"]["id"] = routeInfo["marketSegment"][0]["id"];
data["entityNaicsCode"]["name"] =
routeInfo["marketSegment"][0]["naicsCode"];
if (routeInfo["marketSegment"][0]["parentTerm"] != null) {
data["parentNaicsCode"]["id"] =
routeInfo["marketSegment"][0]["parentTerm"]["id"];
data["parentNaicsCode"]["name"] =
routeInfo["marketSegment"][0]["parentTerm"]["naicsCode"];
}
} else {
data.entityNaicsCode = [];
}
if (routeInfo.taggedPro) {
data.isPro = routeInfo.taggedPro;
}
window.dataLayer.push(data);
} else if (routeInfo && "vid" in routeInfo) {
data.entityBundle = "tags";
data.entityTitle = routeInfo.name;
data.entityId = routeInfo.id;
data.entityName = routeInfo.author?.uname;
data.entityCreated = routeInfo.created;
data.entityType = "taxonomy_term";
data.entityLangcode = SITE_LANGUAGE;
data.siteName = siteName;
data.sponsored = routeInfo.sponsored;
data.sponsor = routeInfo.sponsoringCompany;
data.drupalLanguage = language;
data.drupalCountry = country;
data.userRoles = userRoles;
data.userUid = userUid;
data.algoliaIndexName = indexName;
data["entityTaxonomy"]["tags"] = {
id: routeInfo["id"],
name: routeInfo["name"],
};
window.dataLayer.push(data);
}
})();
Punchh and Olo Announce Partnership
Punchh and Olo Announce Partnership Punchh , the restaurant industry’s Mobile Engagement & Insights Platform, announced today an official partnership with
Olo , the digital ordering provider for 150+ restaurant brands across the nation.
As a foundation of the partnership, Punchh and Olo have developed full integrations between their respective platforms. This combination now tightly couples Olo’s digital ordering with Punchh’s CRM and Mobile Engagement Suite (loyalty, offers, and more) for restaurant brands that choose both platforms.
In the first of several forthcoming projects featuring native Olo ordering integration, Punchh has launched the new
MOOYAH Burgers, Fries, & Shakes mobile application for iOS and Android. The new apps provide customers with a seamless user experience for loyalty and ordering, enabling guests to earn and redeem rewards in-store or via digital ordering - functionality made possible by Punchh’s Single Sign On (SSO) and Loyalty API technology.
The launch of this combination now provides restaurants using Olo & Punchh with a comprehensive set of offer capabilities at their disposal to drive online orders, including %-off, $-off and SKU-level promotions.
X
This ad will auto-close in 10 seconds