/** FHRSWidget.Core.js: shared functionality for widgets **/
// Namespace definition : All Widget Classes should be created in this namespace //
if (!window.FHRSWidget107572) {
window.FHRSWidget107572 = {};
}
// Widget Core Constructor //
FHRSWidget107572.Core = function () {
// Write out Parent Div where script is placed
// Widget content can then be attached to this div through the DOM
this.parentDivId = 'CoreJsBaseDiv-107572';
document.write('
');
};
// Widget Core Class Definition //
FHRSWidget107572.Core.prototype =
{
// Create any HTML element //
createTag: function (tagName, innerHtml, cssClass) {
var tag = $c_107572(tagName);
if (cssClass) {
this.setCssClass(tag, cssClass);
}
if (innerHtml) {
tag.innerHTML = innerHtml;
}
return tag;
},
// Create Unordered List of Hyperlinks //
createHyperlinkList: function (dataCollection, businessUrl, ratingImageUrl, listId, cssClass) {
this.parentDiv = $g_107572(this.parentDivId);
// Remove existing list with this Id, if exists
// Create list
var list;
list = $c_107572('div');
list.id = listId;
list.name = listId;
if (cssClass !== '') {
this.setCssClass(list, cssClass);
}
// Add items to list
var div;
for (index in dataCollection) {
var item = dataCollection[index];
div = $c_107572('div');
var businessName = item.BusinessName;
var ratingKey = item.RatingKey;
var postCode = item.PostCode;
if (businessName) {
var hyperlink = this.createHyperlink(null, businessName, businessUrl + item.FHRSID, null, 'listhyperlink');
div.appendChild(hyperlink);
var image = this.createTag('div', postCode, null);
div.appendChild(image);
image = this.createTag('div', '', null);
div.appendChild(image);
}
else {
var norating = this.createTag('div', '', null);
div.appendChild(norating);
}
list.appendChild(div);
}
return list;
},
// Create a hyperlink and attach event handlers if needed //
createHyperlink: function (hyperlinkId, text, href, onClickFunction, cssClass, target) {
hyperlink = $c_107572('a');
if (hyperlinkId) {
hyperlink.id = hyperlinkId;
hyperlink.name = hyperlinkId;
}
hyperlink.title = text;
hyperlink.innerHTML = ('' + text + '
'); //text));
if (href) {
hyperlink.href = href;
}
if (cssClass !== null && cssClass !== '') {
this.setCssClass(hyperlink, cssClass);
}
if (target) {
hyperlink.setAttribute("target", target);
}
// Attach onclick event handlers
if (onClickFunction) {
hyperlink.onclick = onClickFunction;
var onClickHandler = new Function(hyperlink.onclick);
if (hyperlink.addEventListener) {
hyperlink.addEventListener('click', onClickHandler, false);
} else if (hyperlink.attachEvent) {
hyperlink.attachEvent('onclick', onClickHandler);
}
}
return hyperlink;
},
// Adds CSS Class to any element //
setCssClass: function (elem, cls) {
elem.setAttribute('class', cls);
elem.setAttribute('className', cls);
},
// Attach a Stylesheet to document //
attachStyleSheet: function (path, linkId) {
var doc = document.getElementsByTagName('head').item(0);
var link = $c_107572('link');
link.rel = 'stylesheet';
link.type = 'text/css';
link.href = path;
link.id = linkId;
doc.appendChild(link);
return false;
},
// Attach a new script, useful for simulating postbacks //
attachScript: function (path, scriptId) {
script = $c_107572('script');
script.src = path;
script.type = 'text/javascript';
script.id = scriptId;
this.parentDiv.appendChild(script);
return false;
}
};
// Shortcut for GetElementsById //
function $g_107572(elem)
{
return document.getElementById(elem);
}
// Shortcut for CreateElement //
function $c_107572(elem)
{
return document.createElement(elem);
}
// Construct a new core object
var core107572 = new FHRSWidget107572.Core();
/** FHRSWidget.Widget.js: renders list of dev events **/
// Widget Constructor //
FHRSWidget107572.Widget = function()
{
// Get reference to main div. All widget content will be children of this div
this.parentDiv = document.getElementById(core107572.parentDivId);
this.businessUrl = "https://ratings.food.gov.uk/business/";
this.ratingImageUrl = "https://api1-ratings.food.gov.uk/images/scores/small/";
this.fhrsEstablishmentData = [{"AddressLine1":"11 Central Arcade","AddressLine2":"Saffron Walden","AddressLine3":"Essex","AddressLine4":"","BusinessName":"Mocha Cafe","BusinessType":"Restaurant\/Cafe\/Canteen","BusinessTypeID":1,"Distance":null,"FHRSID":107572,"Geocode":{"Latitude":52.022934,"Longitude":0.239294},"LocalAuthorityBusinessID":"38041011004","LocalAuthorityCode":"122","LocalAuthorityEmailAddress":"environmentalhealth@uttlesford.gov.uk","LocalAuthorityName":"Uttlesford","LocalAuthorityWebSite":"http:\/\/www.uttlesford.gov.uk","NewRatingPending":false,"PostCode":"CB10 1ER","RatingDate":"23 November 2023","RatingKey":"fhrs_5_en-gb","RatingValue":"5","ReInspectionResult":null,"RightToReply":"","SchemeType":"FHRS","Scores":{"ConfidenceInManagement":0,"Hygiene":0,"Structural":5}}];
}
// Widget : Core Class Definition //
FHRSWidget107572.Widget.prototype =
{
// Main function for Events Widget : Handles rendering the widget to the consuming site //
render: function () {
var child1 = core107572.createHyperlinkList(this.fhrsEstablishmentData, this.businessUrl, this.ratingImageUrl, 'eventList107572', 'widgetcontainer');
var child2 = core107572.createTag('br');
var els = document.getElementsByClassName("107572");
for (var i = 0; i < els.length; i++) {
// Create Border and Shadow and return Content Div
var contentDiv = this.createContentBorder(els[i]);
// Create and Attach Events List
contentDiv.appendChild(child1);
contentDiv.appendChild(child2);
}
},
// Create Border, Shadow, and Content Div //
createContentBorder: function (localParentDiv) {
var outerDiv = core107572.createTag('div', '', 'widget1');
var innerDiv = core107572.createTag('div', '', 'widget2');
var contentDiv = core107572.createTag('div', '', 'widget3');
innerDiv.appendChild(contentDiv);
outerDiv.appendChild(innerDiv);
localParentDiv.appendChild(outerDiv);
return contentDiv;
}
};
// Create Widget Object
var ev_w_107572 = new FHRSWidget107572.Widget();
ev_w_107572.render();