diff --git a/WebContent/html/javascript/lib/fuzzy.js b/WebContent/html/javascript/lib/fuzzy.js
index d2131cb..46fa244 100644
--- a/WebContent/html/javascript/lib/fuzzy.js
+++ b/WebContent/html/javascript/lib/fuzzy.js
@@ -1,143 +1,143 @@
-/*
- * Fuzzy
- * https://github.com/myork/fuzzy
- *
- * Copyright (c) 2012 Matt York
- * Licensed under the MIT license.
- */
-
-(function() {
-
-var root = this;
-
-var fuzzy = {};
-
-// Use in node or in browser
-if (typeof exports !== 'undefined') {
- module.exports = fuzzy;
-} else {
- root.fuzzy = fuzzy;
-}
-
-// Return all elements of `array` that have a fuzzy
-// match against `pattern`.
-fuzzy.simpleFilter = function(pattern, array) {
- return array.filter(function(str) {
- return fuzzy.test(pattern, str);
- });
-};
-
-// Does `pattern` fuzzy match `str`?
-fuzzy.test = function(pattern, str) {
- return fuzzy.match(pattern, str) !== null;
-};
-
-// If `pattern` matches `str`, wrap each matching character
-// in `opts.pre` and `opts.post`. If no match, return null
-fuzzy.match = function(pattern, str, opts) {
- opts = opts || {};
- var patternIdx = 0
- , result = []
- , len = str.length
- , totalScore = 0
- , currScore = 0
- // prefix
- , pre = opts.pre || ''
- // suffix
- , post = opts.post || ''
- // String to compare against. This might be a lowercase version of the
- // raw string
- , compareString = opts.caseSensitive && str || str.toLowerCase()
- , ch;
-
- pattern = opts.caseSensitive && pattern || pattern.toLowerCase();
-
- // For each character in the string, either add it to the result
- // or wrap in template if it's the next string in the pattern
- for(var idx = 0; idx < len; idx++) {
- ch = str[idx];
- if(compareString[idx] === pattern[patternIdx]) {
- ch = pre + ch + post;
- patternIdx += 1;
-
- // consecutive characters should increase the score more than linearly
- currScore += 1 + currScore;
- } else {
- currScore = 0;
- }
- totalScore += currScore;
- result[result.length] = ch;
- }
-
- // return rendered string if we have a match for every char
- if(patternIdx === pattern.length) {
- // if the string is an exact match with pattern, totalScore should be maxed
- totalScore = (compareString === pattern) ? Infinity : totalScore;
- return {rendered: result.join(''), score: totalScore};
- }
-
- return null;
-};
-
-// The normal entry point. Filters `arr` for matches against `pattern`.
-// It returns an array with matching values of the type:
-//
-// [{
-// string: 'lah' // The rendered string
-// , index: 2 // The index of the element in `arr`
-// , original: 'blah' // The original element in `arr`
-// }]
-//
-// `opts` is an optional argument bag. Details:
-//
-// opts = {
-// // string to put before a matching character
-// pre: ''
-//
-// // string to put after matching character
-// , post: ''
-//
-// // Optional function. Input is an entry in the given arr`,
-// // output should be the string to test `pattern` against.
-// // In this example, if `arr = [{crying: 'koala'}]` we would return
-// // 'koala'.
-// , extract: function(arg) { return arg.crying; }
-// }
-fuzzy.filter = function(pattern, arr, opts) {
- if(!arr || arr.length === 0) {
- return [];
- }
- if (typeof pattern !== 'string') {
- return arr;
- }
- opts = opts || {};
- return arr
- .reduce(function(prev, element, idx, arr) {
- var str = element;
- if(opts.extract) {
- str = opts.extract(element);
- }
- var rendered = fuzzy.match(pattern, str, opts);
- if(rendered != null) {
- prev[prev.length] = {
- string: rendered.rendered
- , score: rendered.score
- , index: idx
- , original: element
- };
- }
- return prev;
- }, [])
-
- // Sort by score. Browsers are inconsistent wrt stable/unstable
- // sorting, so force stable by using the index in the case of tie.
- // See http://ofb.net/~sethml/is-sort-stable.html
- .sort(function(a,b) {
- var compare = b.score - a.score;
- if(compare) return compare;
- return a.index - b.index;
- });
-};
-
-
+/*
+ * Fuzzy
+ * https://github.com/myork/fuzzy
+ *
+ * Copyright (c) 2012 Matt York
+ * Licensed under the MIT license.
+ */
+
+(function() {
+
+var root = this;
+
+var fuzzy = {};
+
+// Use in node or in browser
+if (typeof exports !== 'undefined') {
+ module.exports = fuzzy;
+} else {
+ root.fuzzy = fuzzy;
+}
+
+// Return all elements of `array` that have a fuzzy
+// match against `pattern`.
+fuzzy.simpleFilter = function(pattern, array) {
+ return array.filter(function(str) {
+ return fuzzy.test(pattern, str);
+ });
+};
+
+// Does `pattern` fuzzy match `str`?
+fuzzy.test = function(pattern, str) {
+ return fuzzy.match(pattern, str) !== null;
+};
+
+// If `pattern` matches `str`, wrap each matching character
+// in `opts.pre` and `opts.post`. If no match, return null
+fuzzy.match = function(pattern, str, opts) {
+ opts = opts || {};
+ var patternIdx = 0
+ , result = []
+ , len = str.length
+ , totalScore = 0
+ , currScore = 0
+ // prefix
+ , pre = opts.pre || ''
+ // suffix
+ , post = opts.post || ''
+ // String to compare against. This might be a lowercase version of the
+ // raw string
+ , compareString = opts.caseSensitive && str || str.toLowerCase()
+ , ch;
+
+ pattern = opts.caseSensitive && pattern || pattern.toLowerCase();
+
+ // For each character in the string, either add it to the result
+ // or wrap in template if it's the next string in the pattern
+ for(var idx = 0; idx < len; idx++) {
+ ch = str[idx];
+ if(compareString[idx] === pattern[patternIdx]) {
+ ch = pre + ch + post;
+ patternIdx += 1;
+
+ // consecutive characters should increase the score more than linearly
+ currScore += 1 + currScore;
+ } else {
+ currScore = 0;
+ }
+ totalScore += currScore;
+ result[result.length] = ch;
+ }
+
+ // return rendered string if we have a match for every char
+ if(patternIdx === pattern.length) {
+ // if the string is an exact match with pattern, totalScore should be maxed
+ totalScore = (compareString === pattern) ? Infinity : totalScore;
+ return {rendered: result.join(''), score: totalScore};
+ }
+
+ return null;
+};
+
+// The normal entry point. Filters `arr` for matches against `pattern`.
+// It returns an array with matching values of the type:
+//
+// [{
+// string: 'lah' // The rendered string
+// , index: 2 // The index of the element in `arr`
+// , original: 'blah' // The original element in `arr`
+// }]
+//
+// `opts` is an optional argument bag. Details:
+//
+// opts = {
+// // string to put before a matching character
+// pre: ''
+//
+// // string to put after matching character
+// , post: ''
+//
+// // Optional function. Input is an entry in the given arr`,
+// // output should be the string to test `pattern` against.
+// // In this example, if `arr = [{crying: 'koala'}]` we would return
+// // 'koala'.
+// , extract: function(arg) { return arg.crying; }
+// }
+fuzzy.filter = function(pattern, arr, opts) {
+ if(!arr || arr.length === 0) {
+ return [];
+ }
+ if (typeof pattern !== 'string') {
+ return arr;
+ }
+ opts = opts || {};
+ return arr
+ .reduce(function(prev, element, idx, arr) {
+ var str = element;
+ if(opts.extract) {
+ str = opts.extract(element);
+ }
+ var rendered = fuzzy.match(pattern, str, opts);
+ if(rendered != null) {
+ prev[prev.length] = {
+ string: rendered.rendered
+ , score: rendered.score
+ , index: idx
+ , original: element
+ };
+ }
+ return prev;
+ }, [])
+
+ // Sort by score. Browsers are inconsistent wrt stable/unstable
+ // sorting, so force stable by using the index in the case of tie.
+ // See http://ofb.net/~sethml/is-sort-stable.html
+ .sort(function(a,b) {
+ var compare = b.score - a.score;
+ if(compare) return compare;
+ return a.index - b.index;
+ });
+};
+
+
}());
\ No newline at end of file
diff --git a/WebContent/html/javascript/statistics.jsp b/WebContent/html/javascript/statistics.jsp
new file mode 100644
index 0000000..ff97eab
--- /dev/null
+++ b/WebContent/html/javascript/statistics.jsp
@@ -0,0 +1,108 @@
+<%@ page import="database.*,entities.Statistics"%>
+<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
+ pageEncoding="ISO-8859-1"%>
+
+
+
+
+
Just curious to see what devices we have to offer? You've come to the right place.
- + diff --git a/WebContent/html/webpages/map.jsp b/WebContent/html/webpages/statisticsPage.jsp similarity index 76% rename from WebContent/html/webpages/map.jsp rename to WebContent/html/webpages/statisticsPage.jsp index ac0a458..8444c67 100644 --- a/WebContent/html/webpages/map.jsp +++ b/WebContent/html/webpages/statisticsPage.jsp @@ -30,6 +30,28 @@ text-align: center; padding-bottom: 10px; } + + div.infoContainer{ + border: solid; + border-width: thin; + padding: 15px; + background-color: #E9EAEB; + display: inline-block; + margin-bottom: 30px; + margin-top: 25px; + text-align: left; + } + + div.imgContainer{ + display: inline-block; + text-align: center; + } + + div.statDescription{ + display: inline-block; + width: 200px; + text-align: center; + } @@ -40,7 +62,7 @@ <%@ include file="navbar.jsp"%> -