@mods: ik had het in het Themaforum (Coronavirus) geplaatst als ik daar toegang tot had.
Hoi Tweakers,
Ik zit normaal op Hacker News en dacht ik doe een Show HN maar dan in Nederland, dus via Tweakers
In mijn omgeving kwam ik en vrienden wat mensen tegen die moeite hadden met het digitaal invullen van de avondklokverklaring (dit is de uitleg). Hopelijk zal dat wat makkelijker gaan met de web app. Dat is de intentie in ieder geval.
De avondklok zit er alweer voor de helft op, en ik hoop dat het 9 feb voorbij is, maar mocht er iemand nog een digitale verklaring in willen vullen
Hoe goed bedoeld ook, spam, reclame voor eigen producten, is hier niet toegestaan.
Nu door naar het leukste gedeelte van de post!
De tech:
Alles wordt client-side gegenereerd, en dat vond ik wel een leuke uitdaging om het puur client-side te houden. Ik vermoed dat het wat makkelijker geweest was om via een client-server model te werken, vooral voor het genereren van PDFs, maar dit is schaalbaarder?
Wat ik heb gebruikt:
* ReactJS
* Local Storage (voor state, Redux was teveel toeters en bellen voor dit project)
* IndexedDB (om PDF op te slaan)
* Nginx
* Docker (waarom daemonizen via systemd als het ook via Docker kan?
)
* Digital Ocean
Wat leuke libraries:
* pdf-lib (voor PDF generatie)
* react-pdf (voor PDF weergave op mobiel)
Meest obscure technische challenge: het dealen met PDFs!
Zo is het bijvoorbeeld onmogelijk om cross-mobile/browser een werkende download knop te hebben voor de gegenereerde PDF. Chrome op iOS vertikt het. Hetzelfde geldt voor het weergeven van PDFs, met react-pdf was het enigszins te doen maar iframes, objects en embeds hadden allemaal hun eigen cross-mobile/browser kwalen.
Maar de leukste challenge is het volgende stuk code!
De browser negeert de orientatie van hoe de mobiel een foto neemt. Het gevolg: elke foto wordt in landscape mode opgeslagen! Dit stuk code zorgt ervoor dat het de orientatie vindt en de juiste lineaire algebra gebruikt om op de juiste manier naar de portrait mode te roteren. Dit is de tweede keer dat ik dit soort wiskunde moest gebruiken in een front-end project. Heb ik toch nog iets aan mijn wiskunde vakken van vroeger ;-)
Feedback is welkom!
Hoi Tweakers,
Ik zit normaal op Hacker News en dacht ik doe een Show HN maar dan in Nederland, dus via Tweakers

In mijn omgeving kwam ik en vrienden wat mensen tegen die moeite hadden met het digitaal invullen van de avondklokverklaring (dit is de uitleg). Hopelijk zal dat wat makkelijker gaan met de web app. Dat is de intentie in ieder geval.
De avondklok zit er alweer voor de helft op, en ik hoop dat het 9 feb voorbij is, maar mocht er iemand nog een digitale verklaring in willen vullen
Hoe goed bedoeld ook, spam, reclame voor eigen producten, is hier niet toegestaan.
Nu door naar het leukste gedeelte van de post!
De tech:
Alles wordt client-side gegenereerd, en dat vond ik wel een leuke uitdaging om het puur client-side te houden. Ik vermoed dat het wat makkelijker geweest was om via een client-server model te werken, vooral voor het genereren van PDFs, maar dit is schaalbaarder?

Wat ik heb gebruikt:
* ReactJS
* Local Storage (voor state, Redux was teveel toeters en bellen voor dit project)
* IndexedDB (om PDF op te slaan)
* Nginx
* Docker (waarom daemonizen via systemd als het ook via Docker kan?

* Digital Ocean
Wat leuke libraries:
* pdf-lib (voor PDF generatie)
* react-pdf (voor PDF weergave op mobiel)
Meest obscure technische challenge: het dealen met PDFs!
Zo is het bijvoorbeeld onmogelijk om cross-mobile/browser een werkende download knop te hebben voor de gegenereerde PDF. Chrome op iOS vertikt het. Hetzelfde geldt voor het weergeven van PDFs, met react-pdf was het enigszins te doen maar iframes, objects en embeds hadden allemaal hun eigen cross-mobile/browser kwalen.
Maar de leukste challenge is het volgende stuk code!
code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
| const orientation = await getOrientationJpgPromise(fileStringBase64); const orientationOptions = getOrientationOptions(orientation); const originX = page.getWidth() / 2; const originY = page.getHeight() / 2; page.pushOperators( pushGraphicsState(), concatTransformationMatrix(1, 0, 0, 1, originX, originY), //translate concatTransformationMatrix( Math.cos(orientationOptions.rotateCW), //rotate -Math.sin(orientationOptions.rotateCW), Math.sin(orientationOptions.rotateCW), Math.cos(orientationOptions.rotateCW), 0, 0 ), concatTransformationMatrix(1, 0, 0, 1, -1 * originX, -1 * originY) //put back ); page.drawImage(jpgImage, { x: originX - jpgDims.width / 2, y: originY - jpgDims.height / 2, width: jpgDims.width, height: jpgDims.height, }); |
De browser negeert de orientatie van hoe de mobiel een foto neemt. Het gevolg: elke foto wordt in landscape mode opgeslagen! Dit stuk code zorgt ervoor dat het de orientatie vindt en de juiste lineaire algebra gebruikt om op de juiste manier naar de portrait mode te roteren. Dit is de tweede keer dat ik dit soort wiskunde moest gebruiken in een front-end project. Heb ik toch nog iets aan mijn wiskunde vakken van vroeger ;-)
Feedback is welkom!
[Voor 10% gewijzigd door Ardana op 28-01-2021 16:01]