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:
Ole-Morten Duesund 2026-03-08 17:41:38 +01:00
commit e8428de775
12051 changed files with 1799735 additions and 0 deletions

1
pwa/node_modules/is-module/.npmignore generated vendored Normal file
View file

@ -0,0 +1 @@
test

41
pwa/node_modules/is-module/README.md generated vendored Normal file
View file

@ -0,0 +1,41 @@
# Is Module
Check whether a source string looks like an ES6 module.
This doesn't actually execute the code,
and doesn't check other module types.
So source strings without any module loaders returns `false`.
This is just what I need from https://github.com/yahoo/js-module-formats, which actually executes the sauce string in a subcontext.
## API
```js
var isES6Module = require('is-module');
console.log(isES6Module('import * from "emitter";')) // => true
```
## License
(The MIT License)
Copyright (c) 2014 segmentio &lt;team@segment.io&gt;
Permission is hereby granted, free of charge, to any person obtaining
a copy of this software and associated documentation files (the
'Software'), to deal in the Software without restriction, including
without limitation the rights to use, copy, modify, merge, publish,
distribute, sublicense, and/or sell copies of the Software, and to
permit persons to whom the Software is furnished to do so, subject to
the following conditions:
The above copyright notice and this permission notice shall be
included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

11
pwa/node_modules/is-module/component.json generated vendored Normal file
View file

@ -0,0 +1,11 @@
{
"name": "is-module",
"description": "check if a source string is an es6 module",
"keywords": ["es6", "module", "modules"],
"version": "1.0.0",
"license": "MIT",
"repo": "component/is-module",
"scripts": [
"index.js"
]
}

11
pwa/node_modules/is-module/index.js generated vendored Normal file
View file

@ -0,0 +1,11 @@
// no idea what these regular expressions do,
// but i extracted it from https://github.com/yahoo/js-module-formats/blob/master/index.js#L18
var ES6ImportExportRegExp = /(?:^\s*|[}{\(\);,\n]\s*)(import\s+['"]|(import|module)\s+[^"'\(\)\n;]+\s+from\s+['"]|export\s+(\*|\{|default|function|var|const|let|[_$a-zA-Z\xA0-\uFFFF][_$a-zA-Z0-9\xA0-\uFFFF]*))/;
var ES6AliasRegExp = /(?:^\s*|[}{\(\);,\n]\s*)(export\s*\*\s*from\s*(?:'([^']+)'|"([^"]+)"))/;
module.exports = function (sauce) {
return ES6ImportExportRegExp.test(sauce)
|| ES6AliasRegExp.test(sauce);
};

20
pwa/node_modules/is-module/package.json generated vendored Normal file
View file

@ -0,0 +1,20 @@
{
"name": "is-module",
"description": "check if a source string is an es6 module",
"keywords": ["es6", "module", "modules"],
"version": "1.0.0",
"author": {
"name": "Jonathan Ong",
"email": "me@jongleberry.com",
"url": "http://jongleberry.com",
"twitter": "https://twitter.com/jongleberry"
},
"license": "MIT",
"repository": "component/is-module",
"devDependencies": {
"mocha": "*"
},
"scripts": {
"test": "mocha --reporter spec --bail"
}
}