Koordinattransformation er en Vue.js applikation der gør det let at transformere koordinater mellem forskellige referencesystemer. Projektet er scaffolded med [Vite]{https://vitejs.dev/} og kørt igennem NPM Projektet er scaffolded med [Vite]{https://vitejs.dev/} og kørt igennem NPM
For at udvikle og bygge projektet skal man have følgende For at udvikle og bygge projektet skal man have følgende
- node.js version: >=17.6.0 link til download
- npm version: >=8.5.2, dette gøres igennem node.js installeren.
For at kunne køre projektet, er der nogle miljøvariable, der skal føres ind i root directory i projeket.
.env.development
til development miljøet og
.env.production
til produktionsmiljøet.
Et eksempel på en miljøfil er:
module.export = {
VITE_NODE_ENV = development
VITE_VUE_APP_SHOW_UNPUBLISHED = true
VITE_NODE_OPTIONS = --openssl-legacy-provider
VITE_TOKEN = <token>
VITE_DAF_TOKEN_A = <datafordeler tjenestebruger brugernavn>
VITE_DAF_TOKEN_B = <datafordeler tjenestebruger password>
VITE_API_BASE_URL = https://api.dataforsyningen.dk/rest/webproj_test
}
VITE_TOKEN
er en adgangstoken, som kan oprettes på https://dataforsyningen.dk/
VITE_DAF_TOKEN_A
og VITE_DAF_TOKEN_B
er hhv. brugernavn/password for en Datafordeler-tjenestebruger.
En tjenestebruger kan oprettes her: https://datafordeler.dk/konto/dine-tjenestebrugere/
Kopier disse filer fra config repoet ind i root directory af projektet.
disse refereres efterfølgende med import.meta.env.[field]
læs mere om Vite og miljøvariable her
Diagrammet ligger som en redigerbar drawio fil sammen med en .png i root directory. Download vs code extention her
Husk at opdatere diagrammet og exporter nyt billede, hvis programmet opdateres
-
Naviger til projektet i terminalen
-
Installer dependencies igennem npm
npm install
dependencies er senere at finde i ./node_modules
Herfra har man tre muligheder:
Kør projektet i localhost. (portnummeret vil blive vist i terminalvinduet):
npm run dev
Compile og minify projektet til produktion:
npm run build
Lint med eslint:
npm run lint
Selve transformationerne sker igennem WEBPROJ
dokumentation til WEBPROJ findes her
Koderne fra WEBPROJ bliver derefter store'et i en VUEX store. Under runtime, kan denne ses i developer tools i browseren med Vue extention til henholdsvis Chrome, firefox Edge
Koordinater | Antal decimaler |
---|---|
Meter | 4 decimaler |
Grader | 8 decimaler |
Grader og minutter | 0, 6 decimaler |
Grader, minutter og sekunder | 0, 0, 4 decimaler |
Koordinater | Antal decimaler |
---|---|
Meter | 4 decimaler |
Grader | 8 decimaler |
Grader og minutter | 0, 6 decimaler |
Grader, minutter og sekunder | 0, 0, 4 decimaler |
Nogle gode generelle ting at vide:
- CRS (Coordinate Reference System) er en fællesbetegnelse for forskellige typer geografiske koordinatsystemer. Typisk tildeles CRS'er en unik kode, fx en EPSG-kode, der gør det let at give geospatial data en entydig geografisk reference.
- EPSG er en database over CRS'er varetaget af 'International Association of Oil and Gas Producers'
- En transformation, hvor et to-dimensionelt system indgår, enten som in- eller output, skal ikke have en højdeparameter på outputtet, selvom man umiddelbart har lyst. I en geodætisk sammenhæng er det meningsløst og i sidste ende misvisende at tage højdeparameteren med.
Nogle gode generelle ting at vide:
- CRS (Coordinate Reference System) er en fællesbetegnelse for forskellige typer geografiske koordinatsystemer. Typisk tildeles CRS'er en unik kode, fx en EPSG-kode, der gør det let at give geospatial data en entydig geografisk reference.
- EPSG er en database over CRS'er varetaget af 'International Association of Oil and Gas Producers'
- En transformation, hvor et to-dimensionelt system indgår, enten som in- eller output, skal ikke have en højdeparameter på outputtet, selvom man umiddelbart har lyst. I en geodætisk sammenhæng er det meningsløst og i sidste ende misvisende at tage højdeparameteren med.
Vue bliver hele tiden opdateret, og der er mange forskellige måder at gøre de samme ting på.
Denne applikation kører på Vue 3 igennem composition API'en med script setup syntax. Dette giver mindre boilerplate og exposer variable og functioner direkte til template'en uden explicit skulle expose dem.
Vær opmærksom, når du finder referencer og tutorials rundt omkring på nettet, at der bliver snakket om den rigtige version.
- Vuex til state management
- Vite som det underliggende build-step
- Sass til nemmere styling
- Vue Router til... ja... routing
Vue bliver hele tiden opdateret, og der er mange forskellige måder at gøre de samme ting på.
Denne applikation kører på Vue 3 igennem composition API'en med script setup syntax. Dette giver mindre boilerplate og exposer variable og functioner direkte til template'en uden explicit skulle expose dem.
Vær opmærksom, når du finder referencer og tutorials rundt omkring på nettet, at der bliver snakket om den rigtige version.
- Vuex til state management
- Vite som det underliggende build-step
- Sass til nemmere styling
- Vue Router til... ja... routing
Det er ikke helt let at holde styr på hvad input og output er i de forskellige sammenhænge.
eksempelvis har OutputCard
et output field, som har både inputkoordinater og outputKoordinater.
Disse inputkoordinater skal ikke forvirres med koordinaterne i InputCard
. Vær opmærksom på, hvor ting kommer fra og skal hen.
Alt styling så vidt muligt (nogle ting er specifikke for Koordinattransformation) følger KDS' design system. Også at finde på Github.
Der er to måder hvorpå man kan bruge variabler fra @dataforsyningen:
<style>
tag må ikke være scoped- inline css
inline CSS er ikke muligt på pseudo elementer og heller ikke på conditional classes (:class={someClass: booleanValue}
)
Derfor giver det mening slet ikke at bruge <style scoped>
for at holde koden strømlinet og ensformig.
Alle ikoner kommer fra design-system-icons
Findes også på Github. Disse bliver i øjeblikket implementeret som separate Vue components i components/shared/icons
, da farverne ikke kan tilpasses, hvis man hiver dem fra npm. Nogle ikoner som ArrowIcon.vue
er implementeret med et par props til at vende den korrekt.
Danmarkskortet kommer fra Dataforsyningen's API, mens grønlandskortet er en OMS integration. Vi har indtil nu ikke haft en intern WMTS over grønland, men der ligger nu en WMS version på dataforsyningen