Add support for UPS/USPS/FedEx tracking queries
Introduces a new javascript "utils" file, which includes a check for matching the query against a set of tracking number regexes on page load. If a match is found, the script prepends a link to the (presumably) appropriate tracking page. Referenced in #98main
parent
6e7ec9918a
commit
2bbc649903
|
@ -53,3 +53,10 @@ header {
|
||||||
-webkit-tap-highlight-color: rgba(0,0,0,0);
|
-webkit-tap-highlight-color: rgba(0,0,0,0);
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.tracking-link {
|
||||||
|
font-size: large;
|
||||||
|
text-align: center;
|
||||||
|
margin: 15px;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,60 @@
|
||||||
|
const checkForTracking = () => {
|
||||||
|
const mainDiv = document.getElementById("main");
|
||||||
|
const query = document.getElementById("search-bar").value.replace(/\s+/g, '');
|
||||||
|
|
||||||
|
// Note: regex functions for checking for tracking queries were derived
|
||||||
|
// from here -- https://stackoverflow.com/questions/619977
|
||||||
|
const matchTracking = {
|
||||||
|
"ups": {
|
||||||
|
"link": `https://www.ups.com/track?tracknum=${query}`,
|
||||||
|
"expr": [
|
||||||
|
/\b(1Z ?[0-9A-Z]{3} ?[0-9A-Z]{3} ?[0-9A-Z]{2} ?[0-9A-Z]{4} ?[0-9A-Z]{3} ?[0-9A-Z]|[\dT]\d\d\d ?\d\d\d\d ?\d\d\d)\b/
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"usps": {
|
||||||
|
"link": `https://tools.usps.com/go/TrackConfirmAction?tLabels=${query}`,
|
||||||
|
"expr": [
|
||||||
|
/(\b\d{30}\b)|(\b91\d+\b)|(\b\d{20}\b)/,
|
||||||
|
/^E\D{1}\d{9}\D{2}$|^9\d{15,21}$/,
|
||||||
|
/^91[0-9]+$/,
|
||||||
|
/^[A-Za-z]{2}[0-9]+US$/
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"fedex": {
|
||||||
|
"link": `https://www.fedex.com/apps/fedextrack/?tracknumbers=${query}`,
|
||||||
|
"expr": [
|
||||||
|
/(\b96\d{20}\b)|(\b\d{15}\b)|(\b\d{12}\b)/,
|
||||||
|
/\b((98\d\d\d\d\d?\d\d\d\d|98\d\d) ?\d\d\d\d ?\d\d\d\d( ?\d\d\d)?)\b/,
|
||||||
|
/^[0-9]{15}$/
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Creates a link to a UPS/USPS/FedEx tracking page
|
||||||
|
const createTrackingLink = href => {
|
||||||
|
let link = document.createElement("a");
|
||||||
|
link.className = "tracking-link";
|
||||||
|
link.innerHTML = "View Tracking Info";
|
||||||
|
link.href = href;
|
||||||
|
mainDiv.prepend(link);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Compares the query against a set of regex patterns
|
||||||
|
// for tracking numbers
|
||||||
|
const compareQuery = provider => {
|
||||||
|
provider.expr.some(regex => {
|
||||||
|
if (query.match(regex)) {
|
||||||
|
createTrackingLink(provider.link);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
for (const key of Object.keys(matchTracking)) {
|
||||||
|
compareQuery(matchTracking[key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
document.addEventListener("DOMContentLoaded", function() {
|
||||||
|
checkForTracking();
|
||||||
|
});
|
|
@ -6,6 +6,7 @@
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<meta name="referrer" content="no-referrer">
|
<meta name="referrer" content="no-referrer">
|
||||||
<script type="text/javascript" src="static/js/autocomplete.js"></script>
|
<script type="text/javascript" src="static/js/autocomplete.js"></script>
|
||||||
|
<script type="text/javascript" src="static/js/utils.js"></script>
|
||||||
<link rel="stylesheet" href="static/css/{{ 'search-dark' if dark_mode else 'search' }}.css">
|
<link rel="stylesheet" href="static/css/{{ 'search-dark' if dark_mode else 'search' }}.css">
|
||||||
<link rel="stylesheet" href="static/css/header.css">
|
<link rel="stylesheet" href="static/css/header.css">
|
||||||
{% if dark_mode %}
|
{% if dark_mode %}
|
||||||
|
|
Loading…
Reference in New Issue