Skip to content

Instantly share code, notes, and snippets.

@KepanoEgg
Created August 9, 2018 14:52
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save KepanoEgg/d297007e8bb85afa2c65c59febedce67 to your computer and use it in GitHub Desktop.
Save KepanoEgg/d297007e8bb85afa2c65c59febedce67 to your computer and use it in GitHub Desktop.
RByjov
<html>
<head>
<meta charset=utf-8>
<meta name=viewport content="width=320">
<meta name=apple-mobile-web-app-capable content=yes>
<title>Store EOD Report</title>
<script src=https://cdnjs.cloudflare.com/ajax/libs/d3/4.11.0/d3.min.js></script>
<link rel=stylesheet href="https://fonts.googleapis.com/css?family=Open+Sans:400,400i,700">
</head>
<body>
<div id=report></div>
</body>
</html>
function getGoalColor(n) {
return n ? goalAchievedColor : goalNotAchievedColor
}
function deg2rad(n) {
return n * Math.PI / 180
}
function getEmoji(n) {
return n.goalExceeded ? [":D", "Goal exceeded!"] : n.goalAchieved ? [":)", chartData.props.type === "eod" ? "Goal met!" : "Goal on track!"] : [":|", "Goal not met."]
}
function onDocumentReady() {
chartData.data.map(function (n, t) {
var i = gauge(null, t);
i.render(n.count)
})
};
var chartData = {
"props": {
"type": "eod",
"timestamp": {
"text": "Apr 23, 2018 4:46 PM (CDT)",
"color": null
},
"store": {
"text": "TestStore",
"color": null
}
},
"data": [
{
"alignments": 7,
"tires": 0,
"batteries": 0,
"brakes": 0,
"dtcs": 0,
"name": "Quick Check",
"type": "QC",
"count": 8,
"goal": 5,
"goalAchieved": true,
"goalExceeded": true
},
{
"conversionRate": 29,
"openOpportunities": 5,
"name": "Alignments",
"type": "AL",
"count": 3,
"goal": 5,
"goalAchieved": false,
"goalExceeded": false
},
{
"roadForced": 0,
"comebacksSaved": 0,
"smartWeight": 0,
"name": "Balancing",
"type": "BA",
"count": -1,
"goal": 5,
"goalAchieved": false,
"goalExceeded": false
}
]
},
goalAchievedColor = "#01aa33",
goalNotAchievedColor = "#19e200",
arcBackgroundColor = "#e6e6e6",
config = {
size: 140,
clipWidth: 150,
clipHeight: 150,
ringInset: 20,
ringWidth: 25,
pointerWidth: 4,
pointerTailLength: 5,
pointerHeadLengthPercent: .8,
endCapMarginPercent: .2,
minValue: 0,
maxValue: 0,
minAngle: -120,
maxAngle: 90,
transitionMs: 750,
majorTicks: 5,
labelFormat: d3.format("d"),
labelInset: 10,
arcColorFn: d3.interpolateHsl(d3.rgb("#e8e2ca"), d3.rgb("#3e6c0a"))
},
svg = d3.select("#report").append("svg:svg").attr("class", "report").attr("width", 500).attr("height", 1e3),
hunter_logo = svg.append("defs").append("g").attr("id", "hunterlogo"), header, gauge;
hunter_logo.append("svg:image").attr("width", 180).attr("height", 50).attr("xlink:href", "data:image/svg+xml;base64,<?xml version="1.0" encoding="utf-8"?><svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 720 144" style="enable-background:new 0 0 720 144;" xml:space="preserve"><style type="text/css">.st0{fill:none;}.st1{fill:#FFFFFF;}.st2{fill:#ED1C24;}</style><g><path class="st0" d="M691.1,42.1H690l-0.4,1.8h1.6c0.7,0,1.2-0.2,1.3-1C692.7,42.2,691.7,42.1,691.1,42.1z"/><path class="st0" d="M605.9,64.7c-5.9,0-9.9,3.4-10.8,8.7h18.1C614,68.8,610.6,64.7,605.9,64.7z"/><path class="st0" d="M419.6,64.7c-5.9,0-9.9,3.4-10.8,8.7h18.1C427.7,68.8,424.3,64.7,419.6,64.7z"/><path class="st0" d="M691.8,39.3c-2.8,0-5.6,2.1-6.3,5.4c-0.7,3.3,1.2,5.4,4,5.4c2.8,0,5.6-2.1,6.3-5.4C696.5,41.4,694.6,39.3,691.8,39.3z M694.5,43.1c-0.3,1.6-1.4,2.2-2.7,2.3l1.3,3.4h-2.1l-1.2-3.2h-0.4l-0.7,3.2h-1.9l1.7-8.2h3.1C693.7,40.6,694.9,41.1,694.5,43.1z"/><path class="st1" d="M80.7,24.1c-26.5,0-47.9,21.4-47.9,47.9c0,26.4,21.4,47.9,47.9,47.9c26.4,0,47.9-21.4,47.9-47.9C128.6,45.5,107.1,24.1,80.7,24.1z M118.3,53.5c2.3,4.7,3.8,9.9,4.2,15.4c-0.5,3-2.7,5.7-6.1,8.1c0.2-1.4,0.2-2.8,0.2-4.2c0-4.5-0.8-8.7-2.1-12.7c2.4-1.9,3.8-4,3.8-6.3C118.3,53.7,118.3,53.6,118.3,53.5z M103.3,36.7c4.7,3,8.8,7,12,11.6c0,0,0,0,0,0c0,2.2-1.1,4.4-3,6.3c-2.1-4.3-4.8-8.1-7.8-11.3c2.3,3.8,4.4,8.1,6,12.9c-3.4,2.6-8.6,4.7-14.7,6.1c-0.7-5.8-1.8-11.2-3.2-15.9c6.7-1.2,11.4-4.1,11.4-7.3C104.1,38.2,103.8,37.4,103.3,36.7z M96.3,66.5c6.4-0.9,11.9-2.6,15.8-4.8c0.9,3.9,1.5,8,1.5,12.2c0,1.7-0.1,3.3-0.3,5C108.8,81.2,103,83,96.4,84c0.2-2.5,0.2-5.1,0.2-7.7C96.7,73,96.5,69.7,96.3,66.5z M86.3,67.1c2.4,0,4.6-0.1,6.8-0.3c0.1,3.5,0.2,7.2,0.2,10.9c0,2.3,0,4.6-0.1,6.8c-3.3,0.4-6.8,0.6-10.4,0.6c-5.9,0-11.6-0.6-16.6-1.6c-0.3-3.9-0.3-8,0.1-12.2c0.2-2.3,0.5-4.6,0.9-6.8C72.6,66.1,79.2,67.1,86.3,67.1z M67.5,62.9c1.3-6.4,3.4-12.3,6-17.3c3.2,1,7.1,1.5,11.3,1.5c2.3,0,4.4-0.2,6.5-0.5c0.8,5,1.3,10.4,1.6,16.3c-4,0.7-8.3,1.1-12.8,1.1C75.7,63.9,71.5,63.5,67.5,62.9z M80.8,113.9c-23.1,0-41.9-18.7-41.9-41.9c0-23.1,18.7-41.9,41.9-41.9c5.4,0,10.6,1,15.3,2.9c2.2,1.2,3.4,2.8,3.4,4.4c0,2.5-3,4.8-7.7,6.2c-0.6-1.9-1.4-3.6-2.1-5.2c0.4,1.7,0.8,3.6,1.2,5.5c-3,0.8-6.5,1.2-10.3,1.2c-2.3,0-4.5-0.2-6.5-0.5c0.6-1.1,1.2-2.1,1.8-3.1c-0.9,0.9-1.8,1.9-2.6,3c-1.7-0.3-3.2-0.7-4.6-1.1c1.1,0.7,2.5,1.4,4,1.9c-3.5,4.7-6.2,10.5-7.8,17.1c-2.1-0.4-4-1-5.8-1.6c1.5,1,3.4,2,5.6,2.8c-0.4,2.1-0.8,4.2-1,6.4c-0.4,4.5-0.2,8.9,0.5,13.1c-1.8-0.4-3.5-0.9-5.2-1.5c1.5,1,3.4,2,5.4,2.8c0.8,4.4,2.2,8.4,4.1,12c-1-3.5-1.7-7.3-2.1-11.2c6.3,2.2,14.5,3.6,23.4,3.6c1.1,0,2.3,0,3.4-0.1c-0.2,5.4-0.5,10.6-1.1,15.4c-0.9,0-1.8,0.1-2.7,0.1c-6.2,0-12-0.9-16.6-2.5c4.1,2.7,11,4.6,19,4.9c-0.2,1.1-0.3,2.1-0.5,3.1c0.4-1,0.8-2,1.2-3.1c0.6,0,1.2,0,1.7,0c4.3,0,8.3-0.4,11.8-1.2C99,110.7,90.2,113.9,80.8,113.9z M115,96.1c-4.5,4.7-11.6,7.3-21.7,7.9c1.3-4.6,2.3-9.9,2.8-15.5c6-0.4,11.4-1.5,16-3c-1.1,4.7-2.8,9.2-4.6,13.2c2.9-4.1,5.6-8.9,7.3-14.2c2.8-1.1,5.1-2.4,7-3.8C120.5,86.4,118.2,91.6,115,96.1z"/><path class="st2" d="M80.7,19.8c-28.9,0-52.2,23.4-52.2,52.2c0,28.9,23.4,52.2,52.2,52.2c28.8,0,52.2-23.4,52.2-52.2C132.9,43.2,109.5,19.8,80.7,19.8z M80.7,119.9c-26.5,0-47.9-21.4-47.9-47.9c0-26.5,21.4-47.9,47.9-47.9c26.4,0,47.9,21.4,47.9,47.9C128.6,98.5,107.1,119.9,80.7,119.9z"/><path d="M92.7,46.4c1.4,4.7,2.5,10.1,3.2,15.9c6.1-1.4,11.3-3.5,14.7-6.1c-1.6-4.7-3.7-9.1-6-12.9c3,3.2,5.7,7,7.8,11.3c1.9-1.9,3-4,3-6.3c0,0,0,0,0,0c-3.2-4.6-7.3-8.6-12-11.6c0.5,0.7,0.8,1.5,0.8,2.3C104.1,42.3,99.4,45.1,92.7,46.4z"/><path d="M113.3,78.8c0.2-1.6,0.3-3.3,0.3-5c0-4.2-0.5-8.3-1.5-12.2c-3.9,2.2-9.4,3.9-15.8,4.8c0.3,3.2,0.4,6.5,0.4,9.9c0,2.6-0.1,5.2-0.2,7.7C103,83,108.8,81.2,113.3,78.8z"/><path d="M114.5,60.1c1.3,4,2.1,8.3,2.1,12.7c0,1.4-0.1,2.8-0.2,4.2c3.4-2.4,5.6-5.1,6.1-8.1c-0.4-5.5-1.9-10.7-4.2-15.4c0,0.1,0,0.2,0,0.3C118.3,56,117,58.2,114.5,60.1z"/><path d="M66.3,71.2c-0.4,4.2-0.4,8.3-0.1,12.2c5.1,1,10.7,1.6,16.6,1.6c3.6,0,7.1-0.2,10.4-0.6c0-2.2,0.1-4.5,0.1-6.8c0-3.7-0.1-7.4-0.2-10.9c-2.2,0.2-4.5,0.3-6.8,0.3c-7.2,0-13.8-1-19.1-2.6C66.8,66.7,66.5,68.9,66.3,71.2z"/><path d="M92.4,106.6c-0.4,1.1-0.8,2.1-1.2,3.1c0.2-1,0.4-2.1,0.5-3.1c-8-0.3-14.9-2.2-19-4.9c4.6,1.5,10.4,2.5,16.6,2.5c0.9,0,1.8,0,2.7-0.1c0.6-4.8,0.9-10,1.1-15.4c-1.1,0-2.2,0.1-3.4,0.1c-8.9,0-17.1-1.3-23.4-3.6c0.4,4,1.1,7.7,2.1,11.2c-1.8-3.6-3.2-7.6-4.1-12c-2.1-0.8-3.9-1.8-5.4-2.8c1.6,0.5,3.4,1,5.2,1.5c-0.7-4.1-0.9-8.5-0.5-13.1c0.2-2.2,0.5-4.3,1-6.4c-2.1-0.8-4-1.8-5.6-2.8c1.8,0.6,3.8,1.1,5.8,1.6c1.5-6.6,4.3-12.4,7.8-17.1c-1.6-0.5-2.9-1.2-4-1.9c1.4,0.5,3,0.8,4.6,1.1c0.8-1,1.7-2,2.6-3c-0.6,1-1.2,2-1.8,3.1c2,0.3,4.2,0.5,6.5,0.5c3.8,0,7.3-0.5,10.3-1.2c-0.3-1.9-0.7-3.7-1.2-5.5c0.7,1.6,1.5,3.3,2.1,5.2c4.7-1.4,7.7-3.6,7.7-6.2c0-1.6-1.3-3.1-3.4-4.4c-4.7-1.9-9.9-2.9-15.3-2.9c-23.1,0-41.9,18.8-41.9,41.9c0,23.1,18.7,41.9,41.9,41.9c9.5,0,18.2-3.2,25.3-8.5c-3.5,0.8-7.6,1.2-11.8,1.2C93.6,106.6,93,106.6,92.4,106.6z"/><path d="M107.5,98.7c1.8-4,3.5-8.5,4.6-13.2c-4.6,1.5-10,2.5-16,3c-0.5,5.7-1.5,11-2.8,15.5c10.1-0.5,17.2-3.2,21.7-7.9c3.2-4.5,5.5-9.7,6.7-15.4c-1.8,1.4-4.2,2.7-7,3.8C113.1,89.9,110.4,94.7,107.5,98.7z"/><path d="M91.3,46.6c-2,0.3-4.2,0.5-6.5,0.5c-4.2,0-8.1-0.6-11.3-1.5c-2.6,5-4.7,10.9-6,17.3c3.9,0.7,8.2,1.1,12.7,1.1c4.5,0,8.8-0.4,12.8-1.1C92.6,57,92.1,51.6,91.3,46.6z"/><polygon points="188.9,58.5 167.5,58.5 171.6,35.2 149,35.2 136.9,104.2 159.5,104.2 164.2,77.5 185.6,77.5 180.8,104.2 203.5,104.2 215.6,35.2 193,35.2 "/><path d="M254,78.1c-1.4,7.8-3.9,12.1-9.7,12.1c-4.8,0-6.8-2.2-5.6-9.1l4.8-27.1h-19.9l-5.4,30.6c-2.5,14.4,3.4,21.1,14.3,21.1c8.2,0,13.5-1.9,19.7-8.8l-1.3,7.4h18.5l8.9-50.2h-19.9L254,78.1z"/><path d="M322.9,52.6c-7.6,0-13,3.3-18.6,9.3l1.4-7.9h-18.2l-8.9,50.2h19.9l4.5-25.6c1.1-6.4,3.5-10.3,9.6-10.3c5.7,0,6.2,4.4,5.3,9.4l-4.7,26.5h19.9l5.3-30.1C341,60.3,336.1,52.6,322.9,52.6z"/><path d="M377.9,38.4h-19.6L355.5,54h-7.4l-2,11.5h7.1l-3.7,21c-3.1,17.3-0.2,19.2,26.2,17.7l2.5-14.3H375c-5.6,0-5.9-1.6-5.1-6.2l3.2-18.2h9.6l2-11.5h-9.6L377.9,38.4z"/><path d="M421,52.6c-16.1,0-30.3,10.5-33.2,27c-3,16.9,7.9,26.1,24,26.1c11.7,0,25.1-4.1,30.7-16.6h-19.1c-2,3-5.1,4.4-8.2,4.4c-5.3,0-9.2-3.9-8.1-9.9h38C448.5,65.4,439.6,52.6,421,52.6z M426.9,73.4h-18.1c0.9-5.4,4.9-8.7,10.8-8.7C424.3,64.7,427.7,68.8,426.9,73.4z"/><path d="M492.2,52.6c-7.8,0-13.3,3.7-17.5,11.6h-0.2l1.8-10.2h-18.1l-8.8,50.2h19.9l3.1-17.3c1.9-10.8,6.7-14.7,14.8-14.7c1.3,0,2.7,0.4,4,0.6l3.5-19.9C493.9,52.7,493.1,52.6,492.2,52.6z"/><polygon class="st2" points="546.8,57.2 544.9,72.9 526.9,35.2 505.7,35.2 493.5,104.2 515.2,104.2 519.1,82.4 521,66.6 539,104.2 560.1,104.2 572.3,35.2 550.6,35.2 "/><path class="st2" d="M607.3,52.6c-16.1,0-30.3,10.5-33.2,27c-3,16.9,7.9,26.1,24,26.1c11.7,0,25.1-4.1,30.7-16.6h-19.1c-2,3-5.1,4.4-8.3,4.4c-5.3,0-9.2-3.9-8.1-9.9h38C634.8,65.4,625.9,52.6,607.3,52.6z M613.2,73.4h-18.1c0.9-5.4,4.9-8.7,10.8-8.7C610.6,64.7,614,68.8,613.2,73.4z"/><path class="st2" d="M670.6,38.4H651L648.2,54h-7.4l-2,11.5h7.1l-3.7,21c-3.1,17.3-0.2,19.2,26.2,17.7l2.5-14.3h-3.2c-5.6,0-5.9-1.6-5.1-6.2l3.2-18.2h9.6l2-11.5h-9.6L670.6,38.4z"/><path class="st2" d="M692.3,37c-4.2,0-8.4,3.4-9.3,7.6c-0.9,4.2,1.8,7.6,6,7.6c4.2,0,8.4-3.4,9.3-7.6C699.2,40.5,696.5,37,692.3,37z M695.8,44.7c-0.7,3.3-3.4,5.4-6.3,5.4c-2.8,0-4.7-2.1-4-5.4c0.7-3.3,3.4-5.4,6.3-5.4C694.6,39.3,696.5,41.4,695.8,44.7z"/><path class="st2" d="M691.5,40.6h-3.1l-1.7,8.2h1.9l0.7-3.2h0.4l1.2,3.2h2.1l-1.3-3.4c1.4-0.1,2.4-0.6,2.7-2.3C694.9,41.1,693.7,40.6,691.5,40.6z M692.5,42.9c-0.2,0.8-0.6,1-1.3,1h-1.6l0.4-1.8h1.1C691.7,42.1,692.7,42.2,692.5,42.9z"/></g></svg>");
var emoji_no_smile = svg.append("defs").append("g").attr("id", ":|"),
emoji_regular_smile = svg.append("defs").append("g").attr("id", ":)"),
emoji_big_smile = svg.append("defs").append("g").attr("id", ":D");
emoji_no_smile.append("svg:image").attr("width", 22).attr("height", 22).attr("xlink:href", "data:image/svg+xml;base64,PHN2ZyBpZD0iTGF5ZXJfMSIgZGF0YS1uYW1lPSJMYXllciAxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgMjAgMjAiPjxkZWZzPjxzdHlsZT4uY2xzLTF7ZmlsbDp1cmwoI3JhZGlhbC1ncmFkaWVudCk7fS5jbHMtMntmaWxsOnVybCgjbGluZWFyLWdyYWRpZW50KTt9LmNscy0ze2ZpbGw6IzQyMjEwYjt9PC9zdHlsZT48cmFkaWFsR3JhZGllbnQgaWQ9InJhZGlhbC1ncmFkaWVudCIgY3g9IjYuOTQiIGN5PSI3LjMxIiByPSIxNC4wMSIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiPjxzdG9wIG9mZnNldD0iMC43NSIgc3RvcC1jb2xvcj0iI2ZmYzgwMCIvPjxzdG9wIG9mZnNldD0iMSIgc3RvcC1jb2xvcj0ib3JhbmdlIi8+PC9yYWRpYWxHcmFkaWVudD48bGluZWFyR3JhZGllbnQgaWQ9ImxpbmVhci1ncmFkaWVudCIgeDE9IjMuODEiIHkxPSIzLjgxIiB4Mj0iMTIuNTYiIHkyPSIxMi41NiIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiPjxzdG9wIG9mZnNldD0iMC4wNSIgc3RvcC1jb2xvcj0iI2ZmZWJhZiIvPjxzdG9wIG9mZnNldD0iMC4zMyIgc3RvcC1jb2xvcj0iI2ZmZWIzMiIvPjxzdG9wIG9mZnNldD0iMSIgc3RvcC1jb2xvcj0iI2ZmYzgwMCIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjx0aXRsZT5BcnRib2FyZCAxPC90aXRsZT48Y2lyY2xlIGNsYXNzPSJjbHMtMSIgY3g9IjEwIiBjeT0iMTAiIHI9IjEwIi8+PHBhdGggY2xhc3M9ImNscy0yIiBkPSJNMTYuMTksMy44MWMxLjc0LDEuNzQtLjYyLDUuODEtMy44LDguOTJzLTYuOSw1LjEzLTguNTcsMy40NUE4Ljc1LDguNzUsMCwwLDEsMTYuMTksMy44MVoiLz48cGF0aCBjbGFzcz0iY2xzLTMiIGQ9Ik0xMy4yNSwxNEg2Ljc1YS41LjUsMCwxLDEsMC0xaDYuNWEuNS41LDAsMSwxLDAsMVoiLz48Y2lyY2xlIGNsYXNzPSJjbHMtMyIgY3g9IjEzIiBjeT0iOC4zNSIgcj0iMS41Ii8+PGNpcmNsZSBjbGFzcz0iY2xzLTMiIGN4PSI3LjEzIiBjeT0iOC4zNSIgcj0iMS41Ii8+PC9zdmc+");
emoji_regular_smile.append("svg:image").attr("width", 22).attr("height", 22).attr("xlink:href", "data:image/svg+xml;base64,PHN2ZyBpZD0iTGF5ZXJfMSIgZGF0YS1uYW1lPSJMYXllciAxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgMjAgMjAiPjxkZWZzPjxzdHlsZT4uY2xzLTF7ZmlsbDp1cmwoI3JhZGlhbC1ncmFkaWVudCk7fS5jbHMtMntmaWxsOnVybCgjbGluZWFyLWdyYWRpZW50KTt9LmNscy0zLC5jbHMtNXtmaWxsOiM0MjIxMGI7fS5jbHMtM3tzdHJva2U6IzQyMjEwYjtzdHJva2UtbWl0ZXJsaW1pdDoxMDtzdHJva2Utd2lkdGg6MS41cHg7fS5jbHMtNHtmaWxsOnVybCgjbGluZWFyLWdyYWRpZW50LTIpO308L3N0eWxlPjxyYWRpYWxHcmFkaWVudCBpZD0icmFkaWFsLWdyYWRpZW50IiBjeD0iNi45NCIgY3k9IjcuMzEiIHI9IjE0LjAxIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+PHN0b3Agb2Zmc2V0PSIwLjc1IiBzdG9wLWNvbG9yPSIjZmZjODAwIi8+PHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSJvcmFuZ2UiLz48L3JhZGlhbEdyYWRpZW50PjxsaW5lYXJHcmFkaWVudCBpZD0ibGluZWFyLWdyYWRpZW50IiB4MT0iMy44MSIgeTE9IjMuODEiIHgyPSIxMi41NiIgeTI9IjEyLjU2IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+PHN0b3Agb2Zmc2V0PSIwLjA1IiBzdG9wLWNvbG9yPSIjZmZlYmFmIi8+PHN0b3Agb2Zmc2V0PSIwLjMzIiBzdG9wLWNvbG9yPSIjZmZlYjMyIi8+PHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSIjZmZjODAwIi8+PC9saW5lYXJHcmFkaWVudD48bGluZWFyR3JhZGllbnQgaWQ9ImxpbmVhci1ncmFkaWVudC0yIiB4MT0iNC42OSIgeTE9IjEzLjMiIHgyPSIxNS4zMSIgeTI9IjEzLjMiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj48c3RvcCBvZmZzZXQ9IjAiIHN0b3AtY29sb3I9IiNlMWUxZTEiLz48c3RvcCBvZmZzZXQ9IjAuMjUiIHN0b3AtY29sb3I9IiNmZmYiLz48c3RvcCBvZmZzZXQ9IjAuNzUiIHN0b3AtY29sb3I9IiNmZmYiLz48c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiNlMWUxZTEiLz48L2xpbmVhckdyYWRpZW50PjwvZGVmcz48dGl0bGU+QXJ0Ym9hcmQgMjwvdGl0bGU+PGNpcmNsZSBjbGFzcz0iY2xzLTEiIGN4PSIxMCIgY3k9IjEwIiByPSIxMCIvPjxwYXRoIGNsYXNzPSJjbHMtMiIgZD0iTTE2LjE5LDMuODFjMS43NCwxLjc0LS42Miw1LjgxLTMuOCw4Ljkycy02LjksNS4xMy04LjU3LDMuNDVBOC43NSw4Ljc1LDAsMCwxLDE2LjE5LDMuODFaIi8+PHBhdGggY2xhc3M9ImNscy0zIiBkPSJNNC43LDEyLjcyYS40NC40NCwwLDAsMSwuNi0uNDgsMTMsMTMsMCwwLDAsNC43Ljg0LDEyLjc0LDEyLjc0LDAsMCwwLDQuNjgtLjgzLjQ1LjQ1LDAsMCwxLC42Mi40OGMtLjUsMi4xMS0yLjksMy41NS01LjMsMy41NVM1LjIxLDE0LjgzLDQuNywxMi43MloiLz48cGF0aCBjbGFzcz0iY2xzLTQiIGQ9Ik0xNSwxMy41M2EzLjYzLDMuNjMsMCwwLDAsLjMtLjc5LjQ1LjQ1LDAsMCwwLS42Mi0uNDgsMTIuNzUsMTIuNzUsMCwwLDEtNC42OC44MywxMywxMywwLDAsMS00LjctLjg0LjQ0LjQ0LDAsMCwwLS42LjQ4LDMuNTcsMy41NywwLDAsMCwuMzEuODEsMTQuMjMsMTQuMjMsMCwwLDAsNSwuODdBMTQsMTQsMCwwLDAsMTUsMTMuNTNaIi8+PGVsbGlwc2UgY2xhc3M9ImNscy01IiBjeD0iMTMiIGN5PSI4LjAxIiByeD0iMS4zOCIgcnk9IjEuNzUiLz48ZWxsaXBzZSBjbGFzcz0iY2xzLTUiIGN4PSI3LjEzIiBjeT0iOC4wMSIgcng9IjEuMzgiIHJ5PSIxLjc1Ii8+PC9zdmc+");
emoji_big_smile.append("svg:image").attr("width", 22).attr("height", 22).attr("xlink:href", "data:image/svg+xml;base64,PHN2ZyBpZD0iTGF5ZXJfMSIgZGF0YS1uYW1lPSJMYXllciAxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgMjAgMjAiPjxkZWZzPjxzdHlsZT4uY2xzLTF7ZmlsbDp1cmwoI3JhZGlhbC1ncmFkaWVudCk7fS5jbHMtMntmaWxsOnVybCgjbGluZWFyLWdyYWRpZW50KTt9LmNscy0zLC5jbHMtNHtmaWxsOiM0MjIxMGI7fS5jbHMtNCwuY2xzLTZ7c3Ryb2tlOiM0MjIxMGI7c3Ryb2tlLW1pdGVybGltaXQ6MTA7fS5jbHMtNHtzdHJva2Utd2lkdGg6MS41cHg7fS5jbHMtNXtmaWxsOnVybCgjbGluZWFyLWdyYWRpZW50LTIpO30uY2xzLTZ7ZmlsbDpub25lO3N0cm9rZS13aWR0aDowLjI1cHg7fTwvc3R5bGU+PHJhZGlhbEdyYWRpZW50IGlkPSJyYWRpYWwtZ3JhZGllbnQiIGN4PSI2Ljk0IiBjeT0iNy4zMSIgcj0iMTQuMDEiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj48c3RvcCBvZmZzZXQ9IjAuNzUiIHN0b3AtY29sb3I9IiNmZmM4MDAiLz48c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9Im9yYW5nZSIvPjwvcmFkaWFsR3JhZGllbnQ+PGxpbmVhckdyYWRpZW50IGlkPSJsaW5lYXItZ3JhZGllbnQiIHgxPSIzLjgxIiB5MT0iMy44MSIgeDI9IjEyLjU2IiB5Mj0iMTIuNTYiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj48c3RvcCBvZmZzZXQ9IjAuMDUiIHN0b3AtY29sb3I9IiNmZmViYWYiLz48c3RvcCBvZmZzZXQ9IjAuMzMiIHN0b3AtY29sb3I9IiNmZmViMzIiLz48c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiNmZmM4MDAiLz48L2xpbmVhckdyYWRpZW50PjxsaW5lYXJHcmFkaWVudCBpZD0ibGluZWFyLWdyYWRpZW50LTIiIHgxPSI0LjAxIiB5MT0iMTQuMDEiIHgyPSIxNiIgeTI9IjE0LjAxIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+PHN0b3Agb2Zmc2V0PSIwIiBzdG9wLWNvbG9yPSIjZTFlMWUxIi8+PHN0b3Agb2Zmc2V0PSIwLjI1IiBzdG9wLWNvbG9yPSIjZmZmIi8+PHN0b3Agb2Zmc2V0PSIwLjc1IiBzdG9wLWNvbG9yPSIjZmZmIi8+PHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSIjZTFlMWUxIi8+PC9saW5lYXJHcmFkaWVudD48L2RlZnM+PHRpdGxlPkFydGJvYXJkIDM8L3RpdGxlPjxjaXJjbGUgY2xhc3M9ImNscy0xIiBjeD0iMTAiIGN5PSIxMCIgcj0iMTAiLz48cGF0aCBjbGFzcz0iY2xzLTIiIGQ9Ik0xNi4xOSwzLjgxYzEuNzQsMS43NC0uNjIsNS44MS0zLjgsOC45MnMtNi45LDUuMTMtOC41NywzLjQ1QTguNzUsOC43NSwwLDAsMSwxNi4xOSwzLjgxWiIvPjxwYXRoIGNsYXNzPSJjbHMtMyIgZD0iTTEzLDguMzVhMS40MywxLjQzLDAsMCwxLDEuMjEuNzdBMi4xOCwyLjE4LDAsMCwwLDE0LjUsOCwxLjcyLDEuNzIsMCwwLDAsMTMsNi4xNCwxLjcyLDEuNzIsMCwwLDAsMTEuNSw4YTIuMTgsMi4xOCwwLDAsMCwuMjksMS4xQTEuNDMsMS40MywwLDAsMSwxMyw4LjM1WiIvPjxwYXRoIGNsYXNzPSJjbHMtMyIgZD0iTTcuMTMsOC4zNWExLjQzLDEuNDMsMCwwLDEsMS4yMS43N0EyLjE4LDIuMTgsMCwwLDAsOC42Myw4YTEuNzIsMS43MiwwLDAsMC0xLjUtMS44N0ExLjcyLDEuNzIsMCwwLDAsNS42Myw4YTIuMTgsMi4xOCwwLDAsMCwuMjksMS4xQTEuNDMsMS40MywwLDAsMSw3LjEzLDguMzVaIi8+PHBhdGggY2xhc3M9ImNscy0zIiBkPSJNNC4zNywxMi4yMUEuNDguNDgsMCwwLDEsNSwxMS42NWExMi42MywxMi42MywwLDAsMCw1LDEsMTIuNDIsMTIuNDIsMCwwLDAsNS0xLC40OS40OSwwLDAsMSwuNjYuNTdBNS43Miw1LjcyLDAsMCwxLDEwLDE2LjQsNS44Myw1LjgzLDAsMCwxLDQuMzcsMTIuMjFaIi8+PHBhdGggY2xhc3M9ImNscy00IiBkPSJNNCwxMi4wNWEuNTIuNTIsMCwwLDEsLjY4LS42MUExMy4xNSwxMy4xNSwwLDAsMCwxMCwxMi41MmExMi45MywxMi45MywwLDAsMCw1LjI4LTEuMDYuNTIuNTIsMCwwLDEsLjcuNjIsNi4xLDYuMSwwLDAsMS02LDQuNTRBNi4yMSw2LjIxLDAsMCwxLDQsMTIuMDVaIi8+PHBhdGggY2xhc3M9ImNscy01IiBkPSJNNCwxMi4wNWEuNTIuNTIsMCwwLDEsLjY4LS42MUExMy4xNSwxMy4xNSwwLDAsMCwxMCwxMi41MmExMi45MywxMi45MywwLDAsMCw1LjI4LTEuMDYuNTIuNTIsMCwwLDEsLjcuNjIsNi4xLDYuMSwwLDAsMS02LDQuNTRBNi4yMSw2LjIxLDAsMCwxLDQsMTIuMDVaIi8+PHBhdGggY2xhc3M9ImNscy02IiBkPSJNMTUuODQsMTMuMzJBMTEuNzYsMTEuNzYsMCwwLDEsMTAsMTQuNjhhMTEuOTEsMTEuOTEsMCwwLDEtNS44My0xLjM4Ii8+PHBhdGggY2xhc3M9ImNscy0zIiBkPSJNMTYuMiwxMy42NGE5LjUxLDkuNTEsMCwwLDEtMy4wNy45MywxNS40NywxNS40NywwLDAsMS0zLjEzLjEzLDE1LjI4LDE1LjI4LDAsMCwwLDMuMDUtLjVBOSw5LDAsMCwwLDE1LjgsMTNaIi8+PHBhdGggY2xhc3M9ImNscy0zIiBkPSJNMTAsMTQuNzFhMTUuMDUsMTUuMDUsMCwwLDEtMy4xMy0uMTUsOS43Niw5Ljc2LDAsMCwxLTMuMDYtLjk0TDQuMjEsMTNBOS4yMyw5LjIzLDAsMCwwLDcsMTQuMiwxNC44NywxNC44NywwLDAsMCwxMCwxNC43MVoiLz48L3N2Zz4=");
header = svg.selectAll().data([0]).enter().append("g");
header.append("text").attr("class", "mainheader").attr("text-anchor", "left").attr("x", 0).attr("y", 0).attr("dominant-baseline", "hanging").text(chartData.props.store.text);
header.append("text").attr("class", "timestamp").attr("x", 370).attr("y", 2).attr("text-anchor", "end").attr("dominant-baseline", "hanging").text(chartData.props.timestamp.text);
header.append("g").attr("transform", "translate(100, 490)").append("use").attr("xlink:href", "#hunterlogo");
gauge = function (n, t) {
function e(n) {
var t = undefined;
for (t in n) config[t] = n[t];
u = config.maxAngle - config.minAngle;
i = config.size / 2;
c = Math.round(i * config.pointerHeadLengthPercent);
f = d3.scaleLinear().range([0, 1]).domain([config.minValue, config.maxValue]);
l = f.ticks(config.majorTicks);
a = d3.range(config.majorTicks).map(function () {
return 1 / config.majorTicks
});
o = d3.arc().innerRadius(i - config.ringWidth - config.ringInset).outerRadius(i - config.ringInset).startAngle(function (n, t) {
var i = n * t;
return deg2rad(config.minAngle + i * u)
}).endAngle(function (n, t) {
var r = n * (t + 1),
i = config.minAngle + r * u;
return i = i > 120 ? 120 : i, deg2rad(i)
})
}
function v() {
return "translate(" + (10 + i) + "," + (40 + i) + ")"
}
function y() {
return svg !== undefined
}
function p(n) {
var a = v(),
f = svg.append("g").attr("transform", "translate(0, " + (config.clipHeight + 10) * t + ")").attr("class", "itemcontainer" ),
u = f.append("g").attr("class", "gaugecontainer").attr("transform", a),
e, c, y, l, i, r;
if (chartData.data[t].count == -1) { f.attr("opacity", .5); chartData.data[t].count = null}
u.append("text").attr("class", "equipheader").attr("text-anchor", "middle").attr("x", 0).attr("y", -(config.clipHeight / 2) + 15).text(chartData.data[t].name);
e = d3.arc().innerRadius(config.size / 2 - config.ringWidth - config.ringInset).outerRadius(config.size / 2 - config.ringInset).startAngle(function () {
return deg2rad(-120)
}).endAngle(function () {
return deg2rad(120)
});
u.selectAll("g").data([1]).enter().append("path").attr("fill", arcBackgroundColor).attr("d", e);
u.selectAll("g").data([chartData.data[t].count / chartData.data[t].goal]).enter().append("path").attr("fill", getGoalColor(chartData.data[t].goalAchieved)).attr("d", o);
u.append("line").attr("stroke", "#000").style("stroke-dasharray", "5, 5").attr("stroke-width", 1).attr("x1", 20).attr("x2", 55).attr("y1", 0).attr("y2", 0);
c = u.append("g").attr("transform", "translate(0, 40)");
c.append("text").attr("text-anchor", "middle").append("tspan").attr("class", chartData.data[t].goalAchieved ? "goalachieved" : "goalnotachieved").text(function () {
return chartData.data[t].count
}).append("tspan").attr("class", "grey").text(function () {
return " / " + chartData.data[t].goal
});
f.append("line").style("shape-rendering", "crispEdges").attr("stroke-width", 1).attr("stroke", "#ddd").attr("x1", 0).attr("y1", config.clipHeight + 20).attr("x2", 375).attr("y2", config.clipHeight + 20);
y = d3.line().curve(d3.curveLinear);
l = u.append("g").attr("class", "pointer");
s = l.append("path").attr("d", "M8,59.5c-1.2-9-2-18.11-2.52-26.18L5.46,1a1,1,0,1,0-2,0l0,32.32C3,41.39,2.19,50.54,1,59.5,0,67,9,67,8,59.5Z");
h(n === undefined ? 0 : n);
i = f.append("g").attr("class", "equipdetails").attr("transform", "translate(" + (config.clipWidth + 20) + ", 50)");
r = chartData.data[t];
r.type === "QC" ? (i.attr('opacity','.5'), i.append("text").text("Opportunities"), i.append("line").style("shape-rendering", "crispEdges").attr("stroke-width", 1).attr("stroke", "#ddd").attr("x1", 0).attr("y1", 8).attr("x2", 190).attr("y2", 8), i.append("text").attr("class", "boldit").attr("transform", "translate(0, 25)").text(r.alignments), i.append("text").attr("transform", "translate(30, 25)").text("Alignments"), i.append("text").attr("class", "boldit").attr("transform", "translate(0, 45)").text(r.tires), i.append("text").attr("transform", "translate(30, 45)").text("Tires"), i.append("text").attr("class", "boldit").attr("transform", "translate(0, 65)").text(r.batteries), i.append("text").attr("transform", "translate(30, 65)").text("Batteries"), i.append("text").attr("class", "boldit").attr("transform", "translate(125, 45)").text(r.brakes), i.append("text").attr("transform", "translate(150, 45)").text("Brakes"), i.append("text").attr("class", "boldit").attr("transform", "translate(125, 65)").text(r.dtcs), i.append("text").attr("transform", "translate(150, 65)").text("DTCs"), i.append("g").attr("transform", "translate(-3, 82)").append("use").attr("xlink:href", "#" + getEmoji(r)[0]), i.append("text").attr("transform", "translate(30, 100)").attr("class", "italicit").text(function () {
return getEmoji(r)[1]
})) : r.type === "AL" ? (i.append("text").attr("class", "boldit").attr("transform", "translate(0, 25)").text(function () {
return r.conversionRate + "%"
}), i.append("text").attr("transform", "translate(45, 25)").text("Conversion Rate"), i.append("text").attr("class", "boldit").attr("transform", "translate(0, 45)").text(r.openOpportunities), i.append("text").attr("transform", "translate(45, 45)").text("Open Opportunities"), i.append("g").attr("transform", "translate(-3, 58)").append("use").attr("xlink:href", "#" + getEmoji(r)[0]), i.append("text").attr("transform", "translate(35, 75)").attr("class", "italicit").text(function () {
return getEmoji(r)[1]
})) : r.type === "BA" && (i.append("text").attr("class", "boldit").attr("transform", "translate(0, 10)").text(function () {
return r.roadForced + "%"
}), i.append("text").attr("transform", "translate(45, 10)").text("Road Forced"), i.append("text").attr("class", "boldit").attr("transform", "translate(0, 30)").text(r.comebacksSaved), i.append("text").attr("transform", "translate(45, 30)").text("Comebacks Saved"), i.append("text").attr("class", "boldit").attr("transform", "translate(0, 50)").text(function () {
return r.smartWeight + "%"
}), i.append("text").attr("transform", "translate(45, 50)").text("SmartWeight"), i.append("g").attr("transform", "translate(-3, 63)").append("use").attr("xlink:href", "#" + getEmoji(r)[0]), i.append("text").attr("transform", "translate(35, 80)").attr("class", "italicit").text(function () {
return getEmoji(r)[1]
}))
}
function h(n, t) {
t !== undefined && e(t);
var r = f(n),
i = config.minAngle + r * u;
i = i > 120 ? 120 : i;
s.attr("transform", "scale(0.9) rotate(" + (i + 360) + ") translate(-5, -62)")
}
var r = {},
u = undefined,
i = undefined,
c = undefined,
o = undefined,
f = undefined,
l = undefined,
a = undefined,
s = undefined,
w = d3.pie();
return config.maxValue = chartData.data[t].goal, r.configure = e, r.isRendered = y, r.render = p, r.update = h, e(n), r
};
window.isLoaded ? onDocumentReady() : window.addEventListener("load", function () {
onDocumentReady()
}, !1);
* {
speak: none;
font-family: 'Open Sans',serif;
font-style: normal;
font-weight: normal;
font-variant: normal;
text-transform: none;
line-height: 1;
background-color: #fff;
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility
}
.goalachieved {
fill: #01aa33;
stroke: none;
font-weight: bold;
font-size: 18px
}
.goalnotachieved {
fill: #19e200;
stroke: none;
font-weight: bold;
font-size: 18px
}
.grey {
fill: #ddd;
stroke: none;
font-weight: bold;
font-size: 18px
}
.timestamp {
font-size: 14px;
font-style: italic;
fill: #cacaca
}
.mainheader {
font-weight: bold;
font-size: 16px
}
.equipheader {
font-weight: bold;
font-size: 20px
}
.equipdetails {
font-size: 14px
}
.boldit {
font-weight: bold
}
.italicit {
font-style: italic
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment