useInProgressStore.js
2.12 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
import { defineStore } from 'pinia';
import { reactive, ref } from 'vue';
import { useI18n } from 'vue-i18n';
export const useInProgressStore = defineStore('inprogress', () => {
const i18n = useI18n();
const progressEnum = {
position: 0,
edit: 1,
trimPointDefine: 2,
aligner: 3,
waiting: 3
};
const mesh = ref(null);
const marginMesh = ref(null);
const alignerMesh = ref(null);
const isCompleted = ref(false);
const currentProgress = ref('position');
const nextStepButtonText = ref(i18n.t('generateTrimLine'));
const currentProgressStepNumber = ref(progressEnum[currentProgress.value]);
const setCurrentProgress = (val) => {
currentProgress.value = val;
currentProgressStepNumber.value = progressEnum[val];
switch (currentProgress.value) {
case 'position':
nextStepButtonText.value = i18n.t('generateTrimLine');
break;
case 'positionComplete':
nextStepButtonText.value = i18n.t('editTrimLine');
break;
case 'edit':
nextStepButtonText.value = i18n.t('markOnIncisorCusp');
break;
case 'trimPointDefine':
nextStepButtonText.value = i18n.t('generateAligner');
break;
case 'aligner':
nextStepButtonText.value = i18n.t('completed');
break;
case 'waiting':
nextStepButtonText.value = i18n.t('waitingforaligner');
break;
default:
break;
}
};
const setMesh = (val) => {
mesh.value = val;
};
const setMarginMesh = (val) => {
marginMesh.value = val;
};
const setAlignerMesh = (val) => {
alignerMesh.value = val;
};
const setIsCompleted = (val) => {
isCompleted.value = val;
};
return {
currentProgressStepNumber,
currentProgress,
nextStepButtonText,
setMesh,
setMarginMesh,
setAlignerMesh,
setIsCompleted,
setCurrentProgress
};
});