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>
This commit is contained in:
parent
46365b713b
commit
e8428de775
12051 changed files with 1799735 additions and 0 deletions
41
pwa/node_modules/es-abstract/2022/StringPad.js
generated
vendored
Normal file
41
pwa/node_modules/es-abstract/2022/StringPad.js
generated
vendored
Normal file
|
|
@ -0,0 +1,41 @@
|
|||
'use strict';
|
||||
|
||||
var $TypeError = require('es-errors/type');
|
||||
|
||||
var callBound = require('call-bound');
|
||||
|
||||
var ToLength = require('./ToLength');
|
||||
var ToString = require('./ToString');
|
||||
|
||||
var $strSlice = callBound('String.prototype.slice');
|
||||
|
||||
// https://262.ecma-international.org/11.0/#sec-stringpad
|
||||
|
||||
module.exports = function StringPad(O, maxLength, fillString, placement) {
|
||||
if (placement !== 'start' && placement !== 'end') {
|
||||
throw new $TypeError('Assertion failed: `placement` must be "start" or "end"');
|
||||
}
|
||||
var S = ToString(O);
|
||||
var intMaxLength = ToLength(maxLength);
|
||||
var stringLength = S.length;
|
||||
if (intMaxLength <= stringLength) {
|
||||
return S;
|
||||
}
|
||||
var filler = typeof fillString === 'undefined' ? ' ' : ToString(fillString);
|
||||
if (filler === '') {
|
||||
return S;
|
||||
}
|
||||
var fillLen = intMaxLength - stringLength;
|
||||
|
||||
// the String value consisting of repeated concatenations of filler truncated to length fillLen.
|
||||
var truncatedStringFiller = '';
|
||||
while (truncatedStringFiller.length < fillLen) {
|
||||
truncatedStringFiller += filler;
|
||||
}
|
||||
truncatedStringFiller = $strSlice(truncatedStringFiller, 0, fillLen);
|
||||
|
||||
if (placement === 'start') {
|
||||
return truncatedStringFiller + S;
|
||||
}
|
||||
return S + truncatedStringFiller;
|
||||
};
|
||||
Loading…
Add table
Add a link
Reference in a new issue