tilfluktsrom/pwa/node_modules/safe-push-apply
Ole-Morten Duesund e8428de775 Add progressive web app companion for cross-platform access
Vite + TypeScript PWA that mirrors the Android app's core features:
- Pre-processed shelter data (build-time UTM33N→WGS84 conversion)
- Leaflet map with shelter markers, user location, and offline tiles
- Canvas compass arrow (ported from DirectionArrowView.kt)
- IndexedDB shelter cache with 7-day staleness check
- Service worker with CacheFirst tiles and precached app shell
- i18n for en, nb, nn (ported from Android strings.xml)
- iOS/Android compass handling with low-pass filter
- Respects user map interaction (no auto-snap on pan/zoom)
- Build revision cache-breaker for reliable SW updates

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-08 17:41:38 +01:00
..
.github Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
test Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
.eslintrc Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
.nycrc Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
CHANGELOG.md Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
index.d.ts Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
index.js Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
LICENSE Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
package.json Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
README.md Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00
tsconfig.json Add progressive web app companion for cross-platform access 2026-03-08 17:41:38 +01:00

safe-push-apply Version Badge

github actions coverage License Downloads

npm badge

Push an array of items into an array, while being robust against prototype modification.

Getting started

npm install --save safe-push-apply

Usage/Examples

var safePushApply = require('safe-push-apply');
var assert = require('assert');

var arr = [1, 2, 3];

var orig = Array.prototype[Symbol.iterator];
delete Array.prototype[Symbol.iterator];
assert.throws(() => {
    try {
        arr.push(...[3, 4, 5]);
    } finally {
        Array.prototype[Symbol.iterator] = orig;
    }
}, 'array is not iterable anymore');

delete Array.prototype.push;
safePushApply(arr, [3, 4, 5]);

assert.deepEqual(arr, [1, 2, 3, 3, 4, 5]);

Tests

Simply clone the repo, npm install, and run npm test