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>
27 lines
876 B
JavaScript
27 lines
876 B
JavaScript
'use strict';
|
|
|
|
var $TypeError = require('es-errors/type');
|
|
|
|
var StringPad = require('./StringPad');
|
|
var ToLength = require('./ToLength');
|
|
var ToString = require('./ToString');
|
|
|
|
// https://262.ecma-international.org/15.0/#sec-stringpaddingbuiltinsimpl
|
|
|
|
module.exports = function StringPaddingBuiltinsImpl(O, maxLength, fillString, placement) {
|
|
if (placement !== 'start' && placement !== 'end' && placement !== 'START' && placement !== 'END') {
|
|
throw new $TypeError('Assertion failed: `placement` must be ~START~ or ~END~');
|
|
}
|
|
|
|
var S = ToString(O); // step 1
|
|
|
|
var intMaxLength = ToLength(maxLength); // step 2
|
|
|
|
var stringLength = S.length; // step 3
|
|
|
|
if (intMaxLength <= stringLength) { return S; } // step 4
|
|
|
|
var filler = typeof fillString === 'undefined' ? ' ' : ToString(fillString); // steps 5-6
|
|
|
|
return StringPad(S, intMaxLength, filler, placement); // step 7
|
|
};
|