mirror of
https://github.com/netbymatt/ws4kp.git
synced 2026-04-18 17:49:31 -07:00
Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
dc64e4bd7f | ||
|
|
776148fa6b | ||
|
|
69c050eb8f | ||
|
|
a3e142dade | ||
|
|
28917489bb | ||
|
|
2365a4c0f7 | ||
|
|
8afef77ea5 | ||
|
|
8f70ee87c5 |
4
package-lock.json
generated
4
package-lock.json
generated
@@ -1,12 +1,12 @@
|
|||||||
{
|
{
|
||||||
"name": "ws4kp",
|
"name": "ws4kp",
|
||||||
"version": "5.21.10",
|
"version": "5.21.13",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "ws4kp",
|
"name": "ws4kp",
|
||||||
"version": "5.21.10",
|
"version": "5.21.13",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"dotenv": "^16.5.0",
|
"dotenv": "^16.5.0",
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "ws4kp",
|
"name": "ws4kp",
|
||||||
"version": "5.21.10",
|
"version": "5.21.13",
|
||||||
"description": "Welcome to the WeatherStar 4000+ project page!",
|
"description": "Welcome to the WeatherStar 4000+ project page!",
|
||||||
"main": "index.mjs",
|
"main": "index.mjs",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
|
|||||||
BIN
server/images/icons/current-conditions/Smoke.gif
Normal file
BIN
server/images/icons/current-conditions/Smoke.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 4.8 KiB |
@@ -65,6 +65,10 @@ const largeIcon = (link, _isNightTime) => {
|
|||||||
case 'sleet-n':
|
case 'sleet-n':
|
||||||
return addPath('Sleet.gif');
|
return addPath('Sleet.gif');
|
||||||
|
|
||||||
|
case 'smoke':
|
||||||
|
case 'smoke-n':
|
||||||
|
return addPath('Smoke.gif');
|
||||||
|
|
||||||
case 'rain_showers':
|
case 'rain_showers':
|
||||||
case 'rain_showers_high':
|
case 'rain_showers_high':
|
||||||
case 'rain_showers-n':
|
case 'rain_showers-n':
|
||||||
|
|||||||
@@ -44,6 +44,7 @@ const smallIcon = (link, _isNightTime) => {
|
|||||||
case 'sct-n':
|
case 'sct-n':
|
||||||
case 'nsct':
|
case 'nsct':
|
||||||
case 'nsct-n':
|
case 'nsct-n':
|
||||||
|
case 'haze-n':
|
||||||
return addPath('Partly-Cloudy-Night.gif');
|
return addPath('Partly-Cloudy-Night.gif');
|
||||||
|
|
||||||
case 'ovc':
|
case 'ovc':
|
||||||
|
|||||||
@@ -6,15 +6,27 @@ import WeatherDisplay from './weatherdisplay.mjs';
|
|||||||
import { registerDisplay, timeZone } from './navigation.mjs';
|
import { registerDisplay, timeZone } from './navigation.mjs';
|
||||||
import * as utils from './radar-utils.mjs';
|
import * as utils from './radar-utils.mjs';
|
||||||
|
|
||||||
// TEMPORARY fix to disable radar on ios safari
|
// TEMPORARY fix to disable radar on ios safari. The same engine (webkit) is
|
||||||
|
// used for all ios browers (chrome, brave, firefox, etc) so it's safe to skip
|
||||||
|
// any subsequent narrowing of the user-agent.
|
||||||
const isIos = /iP(ad|od|hone)/i.test(window.navigator.userAgent);
|
const isIos = /iP(ad|od|hone)/i.test(window.navigator.userAgent);
|
||||||
const isSafari = !!navigator.userAgent.match(/Version\/[\d.]+.*Safari/);
|
// NOTE: iMessages/Messages preview is provided by an Apple scraper that uses a
|
||||||
const safariIos = isIos && isSafari;
|
// user-agent similar to: `Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_1)
|
||||||
|
// AppleWebKit/601.2.4 (KHTML, like Gecko) Version/9.0.1 Safari/601.2.4
|
||||||
|
// facebookexternalhit/1.1 Facebot Twitterbot/1.0`. There is currently a bug in
|
||||||
|
// Messages macos/ios where a constantly crashing website seems to cause an
|
||||||
|
// entire Messages thread to permanently lockup until the individual website
|
||||||
|
// preview is deleted! Messages ios will judder but allows the message to be
|
||||||
|
// deleted eventually. Messages macos beachballs forever and prevents the
|
||||||
|
// successful deletion. See
|
||||||
|
// https://github.com/netbymatt/ws4kp/issues/74#issuecomment-2921154962 for more
|
||||||
|
// context.
|
||||||
|
const isBot = /twitterbot|Facebot/i.test(window.navigator.userAgent);
|
||||||
|
|
||||||
const RADAR_HOST = 'mesonet.agron.iastate.edu';
|
const RADAR_HOST = 'mesonet.agron.iastate.edu';
|
||||||
class Radar extends WeatherDisplay {
|
class Radar extends WeatherDisplay {
|
||||||
constructor(navId, elemId) {
|
constructor(navId, elemId) {
|
||||||
super(navId, elemId, 'Local Radar', !safariIos);
|
super(navId, elemId, 'Local Radar', !isIos && !isBot);
|
||||||
|
|
||||||
this.okToDrawCurrentConditions = false;
|
this.okToDrawCurrentConditions = false;
|
||||||
this.okToDrawCurrentDateTime = false;
|
this.okToDrawCurrentDateTime = false;
|
||||||
@@ -207,7 +219,7 @@ const radarWorker = () => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// register display
|
// register display
|
||||||
// TEMPORARY: except on safari on IOS
|
// TEMPORARY: except on IOS and bots
|
||||||
if (!safariIos) {
|
if (!isIos && !isBot) {
|
||||||
registerDisplay(new Radar(11, 'radar'));
|
registerDisplay(new Radar(11, 'radar'));
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user