Skip to content

Commit

Permalink
Merge pull request #435 from alercebroker/revert-434-revert-433-develop
Browse files Browse the repository at this point in the history
Revert "Revert "Apis refactor""
  • Loading branch information
Demurest authored Nov 11, 2024
2 parents 4c8b02e + feea5bc commit 1496cdd
Show file tree
Hide file tree
Showing 12 changed files with 321 additions and 316 deletions.
3 changes: 2 additions & 1 deletion .github/workflows/deploy_dev.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@ jobs:
GOOGLE_REDIRECT_URI: ${{ secrets.GOOGLE_REDIRECT_URI }}
TNS_API_BASE_URL: ${{ secrets.TNS_API_BASE_URL }}
USERS_API_BASE_URL: ${{ secrets.USERS_API_BASE_URL }}
ZTF_API_BASE_URL: ${{ secrets.ZTF_API_BASE_URL }}
ALERCE_API_BASE_URL: ${{ secrets.ALERCE_API_BASE_URL }}
ALERCE_API_BASE_URL_OLD: ${{ secrets.ALERCE_API_BASE_URL_OLD }}
ZTF_DR_API_BASE_URL: ${{ secrets.ZTF_DR_API_BASE_URL }}
steps:
- name: Configure AWS credentials
Expand Down
3 changes: 2 additions & 1 deletion .github/workflows/deploy_prod.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@ jobs:
GOOGLE_TAG_ID: ${{ secrets.GOOGLE_TAG_ID }}
TNS_API_BASE_URL: ${{ secrets.TNS_API_BASE_URL }}
USERS_API_BASE_URL: ${{ secrets.USERS_API_BASE_URL }}
ZTF_API_BASE_URL: ${{ secrets.ZTF_API_BASE_URL }}
ALERCE_API_BASE_URL: ${{ secrets.ALERCE_API_BASE_URL }}
ALERCE_API_BASE_URL_OLD: ${{ secrets.ALERCE_API_BASE_URL_OLD }}
ZTF_DR_API_BASE_URL: ${{ secrets.ZTF_DR_API_BASE_URL }}
steps:
- name: Configure AWS credentials
Expand Down
134 changes: 70 additions & 64 deletions components/cardBasicInformation.vue
Original file line number Diff line number Diff line change
@@ -1,55 +1,36 @@
<template>
<v-col :cols="cols" :lg="lg" :md="md" :sm="sm">
<v-card :class="cardClass">
<v-card-text v-if="isLoading">
<v-progress-circular
indeterminate
color="primary"
></v-progress-circular>
Fetching data for object {{ $route.params.oid }} ...
</v-card-text>
<v-card-text v-else-if="error">
<v-alert text prominent type="error" icon="mdi-cloud-alert">
{{ error }}
</v-alert>
</v-card-text>
<v-card-text class="pa-1" v-else>
<tables-basic-information :information="information" />
<v-row justify="center" wrap>
<v-col cols="6">
<buttons-finding-chart-button
:oid="information.oid"
:candid="candid"
:useIcon="false"
/>
</v-col>
<v-col cols="6">
<buttons-catalogs-buttons
:ra="information.meanra"
:dec="information.meandec"
title="Other archives"
/>
</v-col>
</v-row>

<tables-tns-information
:loading="tns.loading"
:type="tns.type"
:name="tns.name"
:redshift="tns.redshift"
:discoverer="tns.discoverer"
:reporter="tns.reporter"
:instrument="tns.instrument"
/>
</v-card-text>
<v-card v-if="isLoading || error">
<v-card-text v-if="isLoading">
<v-progress-circular
indeterminate
color="primary"
></v-progress-circular>
Fetching data for object {{ objectId }} ...
</v-card-text>
<v-card-text v-if="error">
<v-alert text prominent type="error" icon="mdi-cloud-alert">
{{ error }}
</v-alert>
</v-card-text>
</v-card>
<v-card
id="basicObject-app"
width="100%"
:height="height"
hx-trigger="update-basic-object from:body"
>
</v-card>
</v-card>
</v-col>
</template>

<script>
import { Vue, Component, Prop } from 'nuxt-property-decorator'
@Component()
export default class CardBasicInformation extends Vue {
import { Vue, Component, Prop, Watch } from 'nuxt-property-decorator'
@Component
export default class CardMagStats extends Vue {
@Prop({ type: Number | String, default: 12 }) cols
@Prop({ type: Number | String, default: 12 }) lg
Expand All @@ -62,35 +43,60 @@ export default class CardBasicInformation extends Vue {
@Prop({ type: String }) cardClass
@Prop({ type: String }) object
isLoading = true
error = ''
height = '0vh'
get isLoading() {
return this.$store.state.object.loading
get objectId() {
return this.$store.state.object.objectId
}
get error() {
const error = this.$store.state.object.error
return error
get isDark() {
return this.$vuetify.theme.isDark
}
get information() {
const nonDetections = this.$store.state.lightcurve.nonDetections
const info = this.$store.state.object.object
? this.$store.state.object.object
: {}
info['Non Detections'] = nonDetections ? nonDetections.length : null
return info
mounted() {
const _oid = this.objectId || this.$route.params.oid
this._loadHtmx(_oid)
this.$el.addEventListener('htmx:responseError', (event) => {
this.error = event.detail.error
this.isLoading = false
})
this.$el.addEventListener('htmx:afterRequest', (event) => {
if (event.detail.successful) {
this.error = ''
this.isLoading = false
this.width = '100%'
this.height = '100%'
this.onIsDarkChange(this.isDark)
}
})
}
get tns() {
return this.$store.state.tns
_loadHtmx(objectId) {
const url = new URL(
`/v2/object_details/htmx/object/${objectId}`,
this.$config.alerceApiBaseUrl
)
const myDiv = document.getElementById('basicObject-app')
if (myDiv) {
myDiv.setAttribute('hx-get', url)
window.htmx.process(myDiv)
document.body.dispatchEvent(new Event('update-basic-object'))
}
}
get candid() {
const detection = this.$store.state.lightcurve.detections.find(
(x) => x.has_stamp
)
return detection ? detection.candid : null
@Watch('isDark', { immediate: true })
onIsDarkChange(newIsDark) {
const container = document.getElementById('basicObject-app')
if (container) {
if (newIsDark) {
container.classList.add('tw-dark')
} else {
container.classList.remove('tw-dark')
}
}
}
}
</script>
181 changes: 67 additions & 114 deletions components/cardClassifiers.vue
Original file line number Diff line number Diff line change
@@ -1,53 +1,36 @@
<template>
<v-col :cols="cols" :lg="lg" :md="md" :sm="sm">
<v-card v-if="isLoading || error" :class="cardClass">
<v-card-text v-if="isLoading">
<v-progress-circular
indeterminate
color="primary"
></v-progress-circular>
Fetching data for object {{ $route.params.oid }} ...
</v-card-text>
<v-card-text v-else-if="error">
<v-alert text prominent type="error" icon="mdi-cloud-alert">{{
error
}}</v-alert>
</v-card-text>
</v-card>
<v-card v-else :class="cardClass">
<v-card-text v-if="plotData" style="height: 100%">
<v-select
v-model="selected"
:items="classifiers_"
item-value="index"
item-text="name"
prepend-icon="mdi-robot"
class="py-0 my-0"
/>
<plots-radar-plot :data="plotData" />
</v-card-text>
<v-card-text v-else class="fill-height">
<v-row align="center" justify="center" class="fill-height" no-gutters>
<v-col align-self="center">
<v-alert icon="mdi-alert" border="left" outlined>
<p class="ma-0">
The object
<b>{{ objectId }}</b> has not been classified yet.
</p>
</v-alert>
</v-col>
</v-row>
</v-card-text>
<v-card :class="cardClass">
<v-card v-if="isLoading || error">
<v-card-text v-if="isLoading">
<v-progress-circular
indeterminate
color="primary"
></v-progress-circular>
Fetching data for object {{ objectId }} ...
</v-card-text>
<v-card-text v-if="error">
<v-alert text prominent type="error" icon="mdi-cloud-alert">
{{ error }}
</v-alert>
</v-card-text>
</v-card>
<v-card
id="probabilities-app"
width="100%"
:height="height"
hx-trigger="update-probabilities from:body"
>
</v-card>
</v-card>
</v-col>
</template>

<script>
import { Vue, Component, Prop } from 'nuxt-property-decorator'
import { filterSortClassifiers } from '../utils/classifier_sort'
import { Vue, Component, Prop, Watch } from 'nuxt-property-decorator'
@Component
export default class CardClassifiers extends Vue {
export default class CardMagStats extends Vue {
@Prop({ type: Number | String, default: 12 }) cols
@Prop({ type: Number | String, default: 12 }) lg
Expand All @@ -56,94 +39,64 @@ export default class CardClassifiers extends Vue {
@Prop({ type: Number | String, default: 12 }) sm
@Prop({ type: String }) cardClass
selected = 0
@Prop({ type: Boolean, default: true }) show
/*
Format probabilities of API to array of objects: { name: class_name, value: prob_of_class}
*/
formatProbs(probs, version = null) {
if (version) {
probs = probs.filter((prob) => {
return prob.classifier_version === version
})
}
return probs.map((k) => {
return {
name: k.class_name,
value: k.probability,
}
})
}
@Prop({ type: String }) cardClass
formatClassifierName(name) {
name = name.replace(/[$-/:-?{-~!"^_`]/g, (c) => ' ')
return name.replace(/\b\w/g, (c) => c.toUpperCase())
}
isLoading = true
error = ''
height = '0vh'
groupBy(data, prop) {
return data.reduce((groups, item) => {
const val = item[prop]
groups[val] = groups[val] || []
groups[val].push(item)
return groups
}, {})
get objectId() {
return this.$store.state.object.objectId
}
get plotData() {
return this.classifiers_.length > 0
? this.classifiers_[this.selected].probs
: null
get isDark() {
return this.$vuetify.theme.isDark
}
get classifiers_() {
const grouped = this.groupBy(this.classifiers, 'classifier_name')
const keys = Object.keys(grouped)
let res = []
keys.forEach((k) => {
const latestVersion = this.getLatestVersion(grouped[k])
res.push({
name: k,
probs: this.formatProbs(grouped[k], latestVersion),
})
mounted() {
const _oid = this.objectId || this.$route.params.oid
this._loadHtmx(_oid)
this.$el.addEventListener('htmx:responseError', (event) => {
this.error = event.detail.error
this.isLoading = false
})
res = filterSortClassifiers(res)
res.map((r, idx) => {
r.name = this.formatClassifierName(r.name)
r.index = idx
this.$el.addEventListener('htmx:afterRequest', (event) => {
if (event.detail.successful) {
this.error = ''
this.isLoading = false
this.width = '100%'
this.height = '100%'
this.onIsDarkChange(this.isDark)
}
})
return res
}
getLatestVersion(classes) {
const uniqueVersions = Array.from(
new Set(classes.map((item) => item.classifier_version))
_loadHtmx(objectId) {
const url = new URL(
`/v2/probability/htmx/probabilities/${objectId}`,
this.$config.alerceApiBaseUrl
)
uniqueVersions.sort()
return uniqueVersions.slice(-1)[0]
}
get classifiers() {
return this.$store.state.probabilities.probabilities
}
get isLoading() {
return this.$store.state.probabilities.loading
}
get error() {
return this.$store.state.probabilities.error
const myDiv = document.getElementById('probabilities-app')
if (myDiv) {
myDiv.setAttribute('hx-get', url)
window.htmx.process(myDiv)
document.body.dispatchEvent(new Event('update-probabilities'))
}
}
get objectId() {
return this.$store.state.object.objectId
@Watch('isDark', { immediate: true })
onIsDarkChange(newIsDark) {
const container = document.getElementById('probabilities-app')
if (container) {
if (newIsDark) {
container.classList.add('tw-dark')
} else {
container.classList.remove('tw-dark')
}
}
}
}
</script>

<style scoped>
.v-input__slot {
margin-bottom: 0;
}
</style>
Loading

0 comments on commit 1496cdd

Please sign in to comment.