/** FHRSWidget.Core.js: shared functionality for widgets **/ // Namespace definition : All Widget Classes should be created in this namespace // if (!window.FHRSWidget290824) { window.FHRSWidget290824 = {}; } // Widget Core Constructor // FHRSWidget290824.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-290824'; document.write('
'); }; // Widget Core Class Definition // FHRSWidget290824.Core.prototype = { // Create any HTML element // createTag: function (tagName, innerHtml, cssClass) { var tag = $c_290824(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_290824(this.parentDivId); // Remove existing list with this Id, if exists // Create list var list; list = $c_290824('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_290824('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_290824('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_290824('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_290824('script'); script.src = path; script.type = 'text/javascript'; script.id = scriptId; this.parentDiv.appendChild(script); return false; } }; // Shortcut for GetElementsById // function $g_290824(elem) { return document.getElementById(elem); } // Shortcut for CreateElement // function $c_290824(elem) { return document.createElement(elem); } // Construct a new core object var core290824 = new FHRSWidget290824.Core(); /** FHRSWidget.Widget.js: renders list of dev events **/ // Widget Constructor // FHRSWidget290824.Widget = function() { // Get reference to main div. All widget content will be children of this div this.parentDiv = document.getElementById(core290824.parentDivId); this.businessUrl = "https://ratings.food.gov.uk/business/"; this.ratingImageUrl = "https://api1-ratings.food.gov.uk/images/scores/small/"; this.fhrsEstablishmentData = [{"AddressLine1":"Barton Service Station Barton Road","AddressLine2":"Barton","AddressLine3":"Chester","AddressLine4":"Cheshire","BusinessName":"Hughes Ron And Son","BusinessType":"Retailers - other","BusinessTypeID":4613,"Distance":null,"FHRSID":290824,"Geocode":{"Latitude":53.081955,"Longitude":-2.83937716},"LocalAuthorityBusinessID":"X\/05\/00039\/MIXED","LocalAuthorityCode":"704","LocalAuthorityEmailAddress":"foodsafety@cheshirewestandchester.gov.uk","LocalAuthorityName":"Cheshire West and Chester","LocalAuthorityWebSite":"http:\/\/www.cheshirewestandchester.gov.uk","NewRatingPending":false,"PostCode":"SY14 7HT","RatingDate":"27 April 2016","RatingKey":"fhrs_5_cy-gb","RatingValue":"5","ReInspectionResult":null,"RightToReply":"","SchemeType":"FHRS","Scores":{"ConfidenceInManagement":5,"Hygiene":5,"Structural":5}}]; } // Widget : Core Class Definition // FHRSWidget290824.Widget.prototype = { // Main function for Events Widget : Handles rendering the widget to the consuming site // render: function () { var child1 = core290824.createHyperlinkList(this.fhrsEstablishmentData, this.businessUrl, this.ratingImageUrl, 'eventList290824', 'widgetcontainer'); var child2 = core290824.createTag('br'); var els = document.getElementsByClassName("290824"); 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 = core290824.createTag('div', '', 'widget1'); var innerDiv = core290824.createTag('div', '', 'widget2'); var contentDiv = core290824.createTag('div', '', 'widget3'); innerDiv.appendChild(contentDiv); outerDiv.appendChild(innerDiv); localParentDiv.appendChild(outerDiv); return contentDiv; } }; // Create Widget Object var ev_w_290824 = new FHRSWidget290824.Widget(); ev_w_290824.render();