You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

50 lines
1.3 KiB

import _ from 'lodash'
import { reactive, useContext } from '@nuxtjs/composition-api'
import { ExampleDTO } from '@/services/application/example/exampleData'
export const useExampleItem = () => {
const state = reactive({
example: {} as ExampleDTO,
totalExample: 0,
progress: {}
})
const { app } = useContext()
const exampleService = app.$services.example
const getExample = async(
projectId: string,
{ page, q, isChecked }: { page: string, q: string, isChecked: string}
) => {
const examples = await exampleService.fetchOne(projectId, page, q, isChecked)
state.totalExample = examples.count
if (!_.isEmpty(examples) && examples.items.length !== 0) {
state.example = examples.items[0]
}
}
const getExampleById = async(
projectId: string
) => {
state.example = await exampleService.findById(projectId, state.example.id)
}
const updateProgress = async(projectId: string) => {
state.progress = await app.$services.metrics.fetchMyProgress(projectId)
}
const confirm = async(
projectId: string,
) => {
await exampleService.confirm(projectId, state.example.id)
await getExampleById(projectId)
updateProgress(projectId)
}
return {
state,
confirm,
getExample,
updateProgress
}
}