Skip to content

Commit

Permalink
Fix tutorial not showing
Browse files Browse the repository at this point in the history
  • Loading branch information
thomashbrnrd committed Jan 24, 2024
1 parent 268dc04 commit df6290d
Show file tree
Hide file tree
Showing 5 changed files with 105 additions and 186 deletions.
138 changes: 0 additions & 138 deletions frontend/src/components/UploadButton.vue

This file was deleted.

26 changes: 1 addition & 25 deletions frontend/src/stores/result.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,29 +13,7 @@ export const useResultStore = defineStore('result', () => {
const img = useLocalStorage<string>('img', null, { serializer })
const imgUrl = useLocalStorage<string>('imgUrl', null, { serializer })
const resultText = useLocalStorage<string>('resultText', null, { serializer })
const securingTutorial = useLocalStorage<boolean>('securingTutorial', false, { serializer })

type FirearmIdentificationResult = {
typology?: TypologyKey
confidence?: number
confidenceLevel?: string
img?: string
imgUrl?: string
resultText?: string
}

const setResult = (result: FirearmIdentificationResult) => {
typology.value = result.typology
confidence.value = result.confidence
confidenceLevel.value = result.confidenceLevel
img.value = result.img
imgUrl.value = result.imgUrl
resultText.value = result.resultText
}

const setSecuringTutorial = (newValue: boolean) => {
securingTutorial.value = newValue
}
const securingTutorial = ref(false)

const updateTypology = (selectedOptionStep: TypologyKey) => {
const extra = (selectedOptionStep === 'revolver_black_powder' ? '_black_powder' : '')
Expand All @@ -51,7 +29,5 @@ export const useResultStore = defineStore('result', () => {
imgUrl,
resultText,
securingTutorial,
setResult,
setSecuringTutorial,
}
})
4 changes: 2 additions & 2 deletions frontend/src/utils/storage-utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ export const serializer = {

export const clearLocalStorage: NavigationGuardWithThis<undefined> = (to, from, next) => {
const { setAmmo, setOptionStep, setCurrentStep } = useStepsStore()
const { setResult } = useResultStore()
const resultStore = useResultStore()

useStepsStore.isModalTransparentAmmoOpened = undefined
setAmmo(undefined)
Expand All @@ -19,7 +19,7 @@ export const clearLocalStorage: NavigationGuardWithThis<undefined> = (to, from,
setOptionStep(3, undefined)
setCurrentStep(0)

setResult({
resultStore.$patch({
typology: undefined,
confidence: undefined,
confidenceLevel: undefined,
Expand Down
110 changes: 100 additions & 10 deletions frontend/src/views/InstructionsPage.vue
Original file line number Diff line number Diff line change
@@ -1,13 +1,99 @@
<script lang="ts" setup>
import UploadButton from '@/components/UploadButton.vue'
import GoodExamplePhoto from '@/assets/good-photo-example.jpg'
import BadExamplePhoto from '@/assets/bad-photo-example.jpg'
const uploadMessage = ref('')
import { ref } from 'vue'
import axios from 'axios'
import { useRouter } from 'vue-router'
import { useResultStore } from '@/stores/result'
import { getNextRouteAfterResult } from '@/utils/firearms-utils/get-next-route-after-result'
const loading = ref(false)
const fileInput = ref<HTMLInputElement | null>(null)
function readInstruction () {
fileInput.value?.click()
const resultStore = useResultStore()
const router = useRouter()
const handledImageTypes = 'image/jpeg, image/png, image/tiff, image/webp, image/bmp, image/gif'
async function uploadImage (base64: string, fileName: string) {
const file = await srcToFile(base64, fileName, 'image/jpeg')
const fd = new FormData()
fd.append('image', file, file.name)
fd.append('date', '' + (Date.now() / 1000)) // date.now gives in milliseconds, convert to seconds
try {
const { data } = await axios.post('/upload', fd)
resultStore.$patch({
typology: data.label,
confidence: data.confidence,
confidenceLevel: data.confidence_level,
resultText: "Type d'arme : " + data.label + ' ' + data.confidence + '%',
img: base64,
imgUrl: data.path,
})
const nextRoute = getNextRouteAfterResult({
securingTutorial: resultStore.securingTutorial,
confidenceLevel: resultStore.confidenceLevel,
typology: resultStore.typology,
})
router.push(nextRoute)
} catch (error) {
console.log(error)
router.push({ name: 'ErrorPage' })
}
}
function resizeImage (uploadedFile: File) {
const MAX_SIZE = 600
const reader = new FileReader()
const image = new Image()
const canvas = document.createElement('canvas')
reader.readAsDataURL(uploadedFile)
reader.onload = (event: ProgressEvent<FileReader>) => {
image.src = event.target?.result as string
}
return new Promise<string>((resolve, reject) => {
image.onload = (e) => {
let width = image.width
let height = image.height
if (width > height) {
if (width > MAX_SIZE) {
height *= MAX_SIZE / width
width = MAX_SIZE
}
} else {
if (height > MAX_SIZE) {
width *= MAX_SIZE / height
height = MAX_SIZE
}
}
canvas.width = width
canvas.height = height
const ctx = canvas.getContext('2d')
ctx?.drawImage(e.target as CanvasImageSource, 0, 0, width, height)
resolve(ctx?.canvas.toDataURL('image/jpeg') as string)
}
image.onerror = (err) => reject(err)
})
}
async function srcToFile (src: string, fileName: string, mimeType: string) {
const res = await fetch(src)
const buf = await res.arrayBuffer()
return new File([buf], fileName, { type: mimeType })
}
function onFileSelected (event: InputEvent & { target: InputEvent['target'] & { files: File[] } }) {
loading.value = true
const uploadedFile = event.target?.files[0]
resizeImage(uploadedFile).then((resizedBase64Image) => (
uploadImage(resizedBase64Image, uploadedFile.name)
))
}
</script>

Expand Down Expand Up @@ -45,23 +131,27 @@ function readInstruction () {
<div class="big-blank" />
<div class="footer">
<div
v-if="!uploadMessage"
v-if="!loading"
class="btn-read-instruction text-center"
>
<div
class="fr-col-11 fr-col-lg-6 mx-auto"
>
<UploadButton
<input
ref="fileInput"
@file-selected="uploadMessage = 'Analyse en cours'"
/>
data-testid="select-file"
type="file"
style="width: 0; height: 1px"
:accept="handledImageTypes"
@change="onFileSelected($event)"
>
<DsfrButton
class="flex justify-center"
data-testid="take-a-picture"
label="Prendre la photo"
icon="ri-camera-fill"
:icon-right="true"
@click="readInstruction()"
@click="$refs.fileInput.click()"
/>
</div>
</div>
Expand All @@ -70,7 +160,7 @@ function readInstruction () {
class="text-center bold"
>
<p class="loading font-bold">
{{ uploadMessage }}
Analyse en cours
</p>
</div>
</div>
Expand Down
13 changes: 2 additions & 11 deletions frontend/src/views/StartPage.vue
Original file line number Diff line number Diff line change
@@ -1,18 +1,9 @@
<script lang="ts" setup>
import { computed } from 'vue'
import { useResultStore } from '@/stores/result'
const resultStore = useResultStore()
const securingTutorial = computed({
get () {
return resultStore.securingTutorial
},
set (value) {
resultStore.setSecuringTutorial(value)
},
})
</script>

<template>
Expand All @@ -37,7 +28,7 @@ const securingTutorial = computed({
data-testid="secure-firearm"
label="Je veux mettre en sécurité mon arme"
size="small"
@click="navigate(); securingTutorial = true"
@click="navigate(); resultStore.$patch({ securingTutorial: true})"
/>
</router-link>
<router-link
Expand All @@ -49,7 +40,7 @@ const securingTutorial = computed({
data-testid="identification"
label="J’ai déjà mis mon arme en sécurité, je veux l’identifier"
size="small"
@click="navigate(); securingTutorial = false"
@click="navigate(); resultStore.$patch({ securingTutorial: false})"
/>
</router-link>
</div>
Expand Down

0 comments on commit df6290d

Please sign in to comment.