Skip to content
Snippets Groups Projects
Commit 6f9d97c6 authored by Remi  PLANEL's avatar Remi PLANEL
Browse files

add structure to refactor

parent b2f82613
No related branches found
No related tags found
2 merge requests!203Foldseek pages,!186Refactor facet autocomplete
Pipeline #120032 passed with stages
in 6 minutes and 17 seconds
...@@ -36,37 +36,6 @@ const facetDistribution: Ref<Record<string, Record<string, number>> | undefined> ...@@ -36,37 +36,6 @@ const facetDistribution: Ref<Record<string, Record<string, number>> | undefined>
// facetDistribution.value = toValue(data)?.facetDistribution // facetDistribution.value = toValue(data)?.facetDistribution
// }) // })
onUpdated(async () => {
console.log("dans le mounted refseq")
const { data } = await useAsyncMeiliSearch({
index: toValue(dbName), query: "", params: {
facets: ["*"],
filter: [],
page: 1,
hitsPerPage: 25,
}
})
console.log(toValue(data))
facetDistribution.value = toValue(data)?.facetDistribution
})
onMounted(async () => {
console.log("dans le mounted refseq")
const { data } = await useAsyncMeiliSearch({
index: toValue(dbName), query: "", params: {
facets: ["*"],
filter: [],
page: 1,
hitsPerPage: 25,
}
})
console.log(toValue(data))
facetDistribution.value = toValue(data)?.facetDistribution
})
onBeforeMount(async () => { onBeforeMount(async () => {
console.log("dans le mounted refseq") console.log("dans le mounted refseq")
...@@ -80,7 +49,6 @@ onBeforeMount(async () => { ...@@ -80,7 +49,6 @@ onBeforeMount(async () => {
}) })
console.log(toValue(data)) console.log(toValue(data))
facetDistribution.value = toValue(data)?.facetDistribution facetDistribution.value = toValue(data)?.facetDistribution
}) })
const { serialize } = useSerialize() const { serialize } = useSerialize()
......
...@@ -3,12 +3,50 @@ import * as Plot from "@observablehq/plot"; ...@@ -3,12 +3,50 @@ import * as Plot from "@observablehq/plot";
import PlotFigure from "~/components/PlotFigure"; import PlotFigure from "~/components/PlotFigure";
import type { SortItem } from "@/components/ServerDbTable.vue" import type { SortItem } from "@/components/ServerDbTable.vue"
import { useNumericalFilter } from "@/composables/useNumericalfilter" import { useNumericalFilter } from "@/composables/useNumericalfilter"
import type { FacetInputItem } from '@/components/AutocompleteMeiliFacets.vue'
import { ServerDbTable } from "#components"
import { ServerDbTable } from "#components"
const sortBy: Ref<SortItem[]> = ref([{ key: 'System', order: "asc" }]) const sortBy: Ref<SortItem[]> = ref([{ key: 'System', order: "asc" }])
const itemValue = ref("id"); const itemValue = ref("id");
const facets: Ref<string[]> = ref(["System", "subtype", "gene_name", "completed", "prediction_type",]) const dbName = ref("structure")
const facetDistribution: Ref<Record<string, Record<string, number>> | undefined> = ref(undefined)
onBeforeMount(async () => {
console.log("dans le mounted refseq")
const { data } = await useAsyncMeiliSearch({
index: toValue(dbName), query: "", params: {
facets: ["*"],
filter: [],
page: 1,
hitsPerPage: 25,
}
})
console.log(toValue(data))
facetDistribution.value = toValue(data)?.facetDistribution
})
const facets = ref<FacetInputItem[]>([
{ title: "Defense System", type: "subheader" },
{ title: "System", value: "System", type: "facet", icon: "mdi-virus-outline", },
{ title: "Subsystem", value: "subtype", type: "facet", icon: "mdi-virus-outline" },
{ type: "divider" },
{ title: "Gene name", value: "gene_name", type: "facet", icon: "mdi-dna" },
{ title: "Completed", value: "completed", type: "facet", icon: "md:done" },
{ title: "Prediction type", value: "prediction_type", type: "facet", icon: "mdi-molecule" },
])
const computedFacets = computed(() => {
const toValFacetDistribution = toValue(facetDistribution)
console.log(toValFacetDistribution)
return toValue(facets).map(facet => {
const count = toValFacetDistribution?.[facet.value] ? Object.keys(toValFacetDistribution[facet.value]).length : undefined
return count ? { ...facet, count } : { ...facet }
})
})
const headers: Ref<Object[]> = ref([ const headers: Ref<Object[]> = ref([
{ title: 'Structure', key: 'structure', sortable: false, removable: false }, { title: 'Structure', key: 'structure', sortable: false, removable: false },
{ title: "System", key: "System", removable: false }, { title: "System", key: "System", removable: false },
...@@ -30,7 +68,7 @@ const headers: Ref<Object[]> = ref([ ...@@ -30,7 +68,7 @@ const headers: Ref<Object[]> = ref([
]) ])
const { search: msSearch, result: msResult } = useMeiliSearch('structure') const { search: msSearch, result: msResult } = useMeiliSearch(toValue(dbName))
const { range: plddtsRange, stringifyFilter: plddtsFilter, reset: plddtsReset } = useNumericalFilter("plddts", 0, 100) const { range: plddtsRange, stringifyFilter: plddtsFilter, reset: plddtsReset } = useNumericalFilter("plddts", 0, 100)
const { range: iptmRange, stringifyFilter: iptmFilter, reset: iptmReset } = useNumericalFilter("iptm+ptm", 0, 1) const { range: iptmRange, stringifyFilter: iptmFilter, reset: iptmReset } = useNumericalFilter("iptm+ptm", 0, 1)
const { range: pdockqRange, stringifyFilter: pdockqFilter, reset: pdockqReset } = useNumericalFilter("pDockQ", 0, 1) const { range: pdockqRange, stringifyFilter: pdockqFilter, reset: pdockqReset } = useNumericalFilter("pDockQ", 0, 1)
...@@ -90,8 +128,9 @@ const plddtDistribution = computed(() => { ...@@ -90,8 +128,9 @@ const plddtDistribution = computed(() => {
</script> </script>
<template> <template>
<ServerDbTable title="Predicted Structures" db="structure" :sortBy="sortBy" :facets="facets" <ServerDbTable title="Predicted Structures" :db="dbName" :sortBy="sortBy" :facets="computedFacets"
:data-table-server-props="dataTableServerProps" :numerical-filters="numericalFilters"> :data-table-server-props="dataTableServerProps" :facet-distribution="facetDistribution"
:numerical-filters="numericalFilters">
......
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment