Fixed viewing observations and stats.

This commit is contained in:
neviyn 2018-10-05 12:26:13 +01:00
parent 76e19e9253
commit e6e69b2df9
8 changed files with 397 additions and 324 deletions

View File

@ -66,6 +66,11 @@
<groupId>joda-time</groupId> <groupId>joda-time</groupId>
<artifactId>joda-time</artifactId> <artifactId>joda-time</artifactId>
</dependency> </dependency>
<dependency>
<groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-joda</artifactId>
<version>2.9.5</version>
</dependency>
<dependency> <dependency>
<groupId>org.springframework.boot</groupId> <groupId>org.springframework.boot</groupId>

View File

@ -27,12 +27,14 @@ class Controller {
} }
@GetMapping("/site/{id}/tutors") @GetMapping("/site/{id}/tutors")
fun getTutorsForSite(@PathVariable(value = "id") id: Long): List<NameValue> = fun getTutorsForSite(@PathVariable(value = "id") id: Long): List<NameValue>? {
siteRepository.findById(id).map { site -> val site = siteRepository.findById(id)
site.tutors.map { NameValue(it.name, it.id) } if (site.isPresent)
}.get() return site.map { site1 -> site1.tutors.map { NameValue(it.name, it.id) } }.get()
return null
}
@GetMapping @GetMapping("/tutor")
fun getAllTutors(): List<NameValue> = tutorRepository.findAll().map { NameValue(it.name, it.id) } fun getAllTutors(): List<NameValue> = tutorRepository.findAll().map { NameValue(it.name, it.id) }
@PostMapping("/tutor") @PostMapping("/tutor")
@ -55,11 +57,12 @@ class Controller {
@PostMapping("/observation") @PostMapping("/observation")
fun addObservation(@Valid @RequestBody newObservation: NewObservation): Long { fun addObservation(@Valid @RequestBody newObservation: NewObservation): Long {
println(newObservation)
val site = siteRepository.findById(newObservation.site).get() val site = siteRepository.findById(newObservation.site).get()
val tutors = tutorRepository.findAllById(newObservation.tutors).toSet() val tutors = tutorRepository.findAllById(newObservation.tutors).toSet()
val overallScores = newObservation.entries.asSequence().groupBy { it.type } val overallScores = newObservation.entries.asSequence().groupBy { it.type }
.map { entry -> entry.key to entry.value.asSequence().mapNotNull { it.rating }.average() } .map { entry -> entry.key to entry.value.asSequence().mapNotNull { it.rating }.average() }
.map { it.first to if(it.second > 0) it.second else null }.toList() .map { it.first to if (it.second > 0) it.second else null }.toList()
.toMap() .toMap()
var observation = Observation( var observation = Observation(
site = site, site = site,
@ -80,51 +83,56 @@ class Controller {
it.observations.add(observation) it.observations.add(observation)
tutorRepository.save(it) tutorRepository.save(it)
} }
println(observation)
return observation.id return observation.id
} }
@GetMapping("/observations") @PostMapping("/observations")
fun getObservations(@Valid @RequestBody observationsRequest: ObservationsRequest): List<Observation>? { fun getObservations(@Valid @RequestBody observationsRequest: ObservationsRequest): List<Observation> {
print(observationsRequest)
if (observationsRequest.tutor != null) { if (observationsRequest.tutor != null) {
val tutor = tutorRepository.findById(observationsRequest.tutor).get() return tutorRepository.findById(observationsRequest.tutor).map {
return if (observationsRequest.whom == null) { when {
observationRepository.findByTutorsAndDateBetween(tutor = tutor, (observationsRequest.whom == null || observationsRequest.whom.isEmpty()) -> observationRepository.findByTutorsAndDateBetween(tutor = it,
startDate = observationsRequest.startDate, startDate = observationsRequest.startDate,
endDate = observationsRequest.endDate) endDate = observationsRequest.endDate)
} else { else -> observationRepository.findByTutorsAndWhomAndDateBetween(tutor = it,
observationRepository.findByTutorsAndWhomAndDateBetween(tutor = tutor, whom = observationsRequest.whom,
whom = observationsRequest.whom, startDate = observationsRequest.startDate,
startDate = observationsRequest.startDate, endDate = observationsRequest.endDate)
endDate = observationsRequest.endDate) }
} }.orElse(listOf())
} }
if (observationsRequest.site != null) { if (observationsRequest.site != null) {
val site = siteRepository.findById(observationsRequest.site).get() return siteRepository.findById(observationsRequest.site).map {
return if (observationsRequest.whom == null) { when {
observationRepository.findBySiteAndDateBetween(site = site, (observationsRequest.whom == null || observationsRequest.whom.isEmpty()) -> observationRepository.findBySiteAndDateBetween(site = it,
startDate = observationsRequest.startDate, startDate = observationsRequest.startDate,
endDate = observationsRequest.endDate) endDate = observationsRequest.endDate)
} else { else -> observationRepository.findBySiteAndWhomAndDateBetween(site = it,
observationRepository.findBySiteAndWhomAndDateBetween(site = site, whom = observationsRequest.whom,
whom = observationsRequest.whom, startDate = observationsRequest.startDate,
startDate = observationsRequest.startDate, endDate = observationsRequest.endDate)
endDate = observationsRequest.endDate) }
} }.orElse(listOf())
} }
return null return listOf()
} }
@GetMapping("/observations/chartdata") @PostMapping("/observations/chartdata")
fun getObservationsChartData(@Valid @RequestBody observationsRequest: ObservationsRequest): ChartData? { fun getObservationsChartData(@Valid @RequestBody observationsRequest: ObservationsRequest): ChartData? {
val data = getObservations(observationsRequest) ?: return null val data = getObservations(observationsRequest)
val groupedData = data.asSequence().groupBy { it.date }.map{ entry -> AverageData( if(data.isEmpty()) return ChartData(listOf(), listOf())
entry.value.asSequence().mapNotNull { it.monitoring }.average(), val groupedData = data.asSequence().groupBy { it.date }.map { entry ->
entry.value.asSequence().mapNotNull { it.control }.average(), AverageData(
entry.value.asSequence().mapNotNull { it.conservatism }.average(), entry.value.asSequence().mapNotNull { it.monitoring }.average(),
entry.value.asSequence().mapNotNull { it.teamwork }.average(), entry.value.asSequence().mapNotNull { it.control }.average(),
entry.value.asSequence().mapNotNull { it.knowledge }.average(), entry.value.asSequence().mapNotNull { it.conservatism }.average(),
entry.key entry.value.asSequence().mapNotNull { it.teamwork }.average(),
)}.toList() entry.value.asSequence().mapNotNull { it.knowledge }.average(),
entry.key
)
}.toList()
val dates = groupedData.map { it.date.toString("yyyy-MM-dd") } val dates = groupedData.map { it.date.toString("yyyy-MM-dd") }
return ChartData( return ChartData(
labels = dates, labels = dates,

View File

@ -1,5 +1,6 @@
package uk.co.neviyn.observationdatabase package uk.co.neviyn.observationdatabase
import com.fasterxml.jackson.annotation.JsonIgnore
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
import org.joda.time.LocalDate import org.joda.time.LocalDate
import javax.persistence.* import javax.persistence.*
@ -43,6 +44,7 @@ data class Observation(
@Id @Id
@GeneratedValue(strategy = GenerationType.IDENTITY) @GeneratedValue(strategy = GenerationType.IDENTITY)
val id: Long = 0, val id: Long = 0,
@JsonIgnore
@ManyToOne @ManyToOne
val site: Site, val site: Site,
@Column(nullable = false) @Column(nullable = false)
@ -60,6 +62,7 @@ data class Observation(
val knowledge: Double?, val knowledge: Double?,
@ElementCollection @ElementCollection
val entries: List<Entry>, val entries: List<Entry>,
@JsonIgnore
@ManyToMany(mappedBy = "observations") @ManyToMany(mappedBy = "observations")
val tutors: Set<Tutor> val tutors: Set<Tutor>
) )
@ -72,10 +75,10 @@ data class Entry(
@Column(nullable = false) @Column(nullable = false)
@JsonProperty @JsonProperty
val rating: Int, val rating: Int,
@Column(nullable = false) @Column(nullable = false, columnDefinition = "TEXT")
@JsonProperty @JsonProperty
val strengths: String, val strengths: String,
@Column(nullable = false) @Column(nullable = false, columnDefinition = "TEXT")
@JsonProperty @JsonProperty
val improvements: String val improvements: String
) )

View File

@ -1 +1,3 @@
spring.jpa.properties.jadira.usertype.autoRegisterUserTypes = true spring.jpa.properties.jadira.usertype.autoRegisterUserTypes = true
spring.datasource.url=jdbc:h2:file:./database
spring.jpa.hibernate.ddl-auto=update

View File

@ -1,37 +1,42 @@
<template> <template>
<div id="app"> <div id="app">
<!-- <b-navbar toggleable="md" type="dark" variant="info">
<div id="nav"> <b-navbar-toggle target="nav_collapse"></b-navbar-toggle>
<router-link to="/">Home</router-link> | <b-navbar-brand to="/">Observation Database</b-navbar-brand>
<router-link to="/observation">Observation</router-link> <b-collapse is-nav id="nav_collapse">
<b-navbar-nav>
<b-nav-item to="/">New Observation</b-nav-item>
</b-navbar-nav>
<!-- Right aligned nav items -->
<b-navbar-nav class="ml-auto">
<b-nav-item-dropdown text="Admin" right>
<b-dropdown-item to="/newsite">New Site</b-dropdown-item>
<b-dropdown-item to="/newtutor">New Tutor</b-dropdown-item>
</b-nav-item-dropdown>
</b-navbar-nav>
</b-collapse>
</b-navbar>
<br/>
<transition>
<router-view/>
</transition>
</div> </div>
-->
<b-navbar id="nav" variant="info">
<b-navbar-brand to="/">Training Observations</b-navbar-brand>
<b-navbar-nav class="ml-auto">
<b-nav-item to="/">New Observation</b-nav-item>
</b-navbar-nav>
</b-navbar>
<br />
<transition>
<router-view/>
</transition>
</div>
</template> </template>
<style> <style>
#app { #app {
font-family: "Avenir", Helvetica, Arial, sans-serif; font-family: "Avenir", Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased; -webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale; -moz-osx-font-smoothing: grayscale;
text-align: center; text-align: center;
color: #2c3e50; color: #2c3e50;
} }
#nav {
padding: 10px;
}
#nav a.router-link-exact-active { #nav {
color: #42b983; padding: 10px;
} }
#nav a.router-link-exact-active {
color: #42b983;
}
</style> </style>

View File

@ -1,145 +1,154 @@
<template> <template>
<b-container class="home" align-h="center"> <b-container class="home" align-h="center">
<b-modal ref="errorModal" class="text-center" centered hide-header hide-footer> <b-modal ref="errorModal" class="text-center" centered hide-header hide-footer>
<div class="modal-header"> <div class="modal-header">
<h3 class="modal-title w-100">{{ errorStatus }}</h3> <h3 class="modal-title w-100">{{ errorStatus }}</h3>
</div> </div>
<div class="d-block"> <div class="d-block">
<br /> <br/>
<span style="font-size:20px;" v-html="errorMessage" /> <span style="font-size:20px;" v-html="errorMessage"/>
<button class="btn btn-warning" @click="$refs.errorModal.hide()"> <button class="btn btn-warning" @click="$refs.errorModal.hide()">
<v-icon name="exclamation-circle" /> Dismiss</button> <v-icon name="exclamation-circle"/>
</div> Dismiss
</b-modal> </button>
<b-container v-if="errorMessage"> </div>
<b-alert variant="danger" show>An error occurred, refresh and try again.</b-alert> </b-modal>
<b-container v-if="errorMessage">
<b-alert variant="danger" show>An error occurred, refresh and try again.</b-alert>
</b-container>
<b-container v-if="!loaded && !errorMessage">
<v-icon name="spinner" spin scale="2"/>
<br/><br/>
<p>Loading Site Data</p>
</b-container>
<b-container v-if="loaded">
<b-form @submit="onSubmit" id="submission-form" novalidate>
<b-row align-h="center">
<b-col>
<b-form-group label="Site">
<b-form-select :value="site" @input="setSite" :options="siteOptions"
style="text-align:center;" required></b-form-select>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-form-group label="Who">
<b-form-input :value="whom" @input="setWhom" type="text"
style="text-align:center;" required></b-form-input>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-form-group label="Description">
<b-form-input :value="description" @input="setDescription" type="text"
style="text-align:center;" required></b-form-input>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-form-group label="Type">
<b-form-select :value="type" @input="setType" style="text-align:center;"
required>
<option :value=null>Select a training type</option>
<option value="INITIAL">INITIAL</option>
<option value="CONTINUING">CONTINUING</option>
</b-form-select>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-form-group label="Tutor(s)">
<p v-if="site == null">Select a site first.</p>
<v-icon name="spinner" spin v-if="loadingTutors"/>
<b-form-checkbox-group :value="tutors" @input="setTutors"
:options="tutorOptions"
required></b-form-checkbox-group>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-button type="submit" size="lg" variant="primary">Start</b-button>
</b-col>
</b-row>
</b-form>
</b-container>
</b-container> </b-container>
<b-container v-if="!loaded && !errorMessage">
<v-icon name="spinner" spin scale="2" />
<br /><br />
<p>Loading Site Data</p>
</b-container>
<b-container v-if="loaded">
<b-form @submit="onSubmit" id="submission-form" novalidate>
<b-row align-h="center">
<b-col>
<b-form-group label="Site">
<b-form-select :value="site" @input="setSite" :options="siteOptions" style="text-align:center;"></b-form-select>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-form-group label="Who">
<b-form-input :value="whom" @input="setWhom" type="text" style="text-align:center;"></b-form-input>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-form-group label="Description">
<b-form-input :value="description" @input="setDescription" type="text" style="text-align:center;"></b-form-input>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-form-group label="Type">
<b-form-select :value="type" @input="setType" style="text-align:center;">
<option :value=null>Select a training type</option>
<option value="INITIAL">INITIAL</option>
<option value="CONTINUING">CONTINUING</option>
</b-form-select>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-form-group label="Tutor(s)">
<p v-if="site == null">Select a site first.</p>
<v-icon name="spinner" spin v-if="loadingTutors" />
<b-form-checkbox-group :value="tutors" @input="setTutors" :options="tutorOptions"></b-form-checkbox-group>
</b-form-group>
</b-col>
</b-row>
<b-row align-h="center">
<b-col>
<b-button type="submit" size="lg" variant="primary">Start</b-button>
</b-col>
</b-row>
</b-form>
</b-container>
</b-container>
</template> </template>
<script> <script>
import Vue from "vue"; import Vue from "vue";
import "vue-awesome/icons/spinner"; import "vue-awesome/icons/spinner";
import "vue-awesome/icons/exclamation-circle"; import "vue-awesome/icons/exclamation-circle";
import { mapState, mapMutations } from "vuex"; import {mapState, mapMutations} from "vuex";
export default {
name: "home", export default {
data() { name: "home",
return { data() {
siteOptions: [], return {
tutorOptions: [], siteOptions: [],
loadingTutors: false, tutorOptions: [],
loaded: false, loadingTutors: false,
errorMessage: null, loaded: false,
errorStatus: null errorMessage: null,
errorStatus: null
};
},
mounted() {
this.resetStore();
Vue.axios
.get("/site")
.then(response => {
this.siteOptions = response.data;
this.loaded = true;
})
.catch(error => {
this.errorStatus = error.response.status;
this.errorMessage = error.response.data;
this.$refs.errorModal.show();
});
},
computed: {
...mapState(["site", "description", "type", "tutors", "whom"])
},
watch: {
site: function () {
this.loadingTutors = true;
this.tutorOptions = [];
this.tutors = [];
this.getTutors();
}
},
methods: {
...mapMutations([
"setSite",
"setDescription",
"setType",
"setTutors",
"setWhom",
"resetStore"
]),
getTutors: function () {
if (this.site != null) {
Vue.axios.get("/site/" + this.site + "/tutors").then(response => {
this.tutorOptions = response.data;
this.loadingTutors = false;
});
}
},
onSubmit: function (e) {
console.log("submit");
e.preventDefault();
e.stopPropagation();
var form = document.getElementById("submission-form");
if (form.checkValidity()) {
this.$router.push("/observation");
}
}
}
}; };
},
mounted() {
this.resetStore();
Vue.axios
.get("/site")
.then(response => {
this.siteOptions = response.data;
this.loaded = true;
})
.catch(error => {
this.errorStatus = error.response.status;
this.errorMessage = error.response.data;
this.$refs.errorModal.show();
});
},
computed: {
...mapState(["site", "description", "type", "tutors", "whom"])
},
watch: {
site: function() {
this.loadingTutors = true;
this.tutorOptions = [];
this.tutors = [];
this.getTutors();
}
},
methods: {
...mapMutations([
"setSite",
"setDescription",
"setType",
"setTutors",
"setWhom",
"resetStore"
]),
getTutors: function() {
if (this.site != null) {
Vue.axios.get("/site/" + this.site + "/tutors").then(response => {
this.tutorOptions = response.data;
this.loadingTutors = false;
});
}
},
onSubmit: function(e) {
console.log("submit");
e.preventDefault();
e.stopPropagation();
var form = document.getElementById("submission-form");
if (form.checkValidity()) {
this.$router.push("/observation");
}
}
}
};
</script> </script>

View File

@ -14,12 +14,17 @@
<b-row> <b-row>
<b-col> <b-col>
<b-form-group label="Site"> <b-form-group label="Site">
<b-form-select v-model="siteSelection" :options="siteOptions" style="text-align:center;" /> <b-form-select class="text-center" v-model="siteSelection" :options="siteOptions" />
</b-form-group>
</b-col>
<b-col>
<b-form-group label="Tutor">
<b-form-select class="text-center" v-model="tutorSelection" :options="tutorOptions" />
</b-form-group> </b-form-group>
</b-col> </b-col>
<b-col> <b-col>
<b-form-group label="Who"> <b-form-group label="Who">
<b-form-input v-model="whom" type="text" style="text-align:center;"></b-form-input> <b-form-input class="text-center" v-model="whom" type="text"></b-form-input>
</b-form-group> </b-form-group>
</b-col> </b-col>
<b-col> <b-col>
@ -103,12 +108,12 @@ export default {
methods: { methods: {
getFilteredAverage: function() { getFilteredAverage: function() {
Vue.axios Vue.axios
.get("/observations/chartdata", { .post("/observations/chartdata", {
site: this.siteSelection, 'site': this.siteSelection,
tutor: this.tutorSelection, 'tutor': this.tutorSelection,
startDate: moment(this.startDate).format("YYYY-MM-DD"), 'startDate': moment(this.startDate).format("YYYY-MM-DD"),
endDate: moment(this.endDate).format("YYYY-MM-DD"), 'endDate': moment(this.endDate).format("YYYY-MM-DD"),
whom: this.whom 'whom': this.whom
}) })
.then(response => { .then(response => {
this.chartData = response.data; this.chartData = response.data;
@ -137,7 +142,7 @@ export default {
}, },
watch: { watch: {
siteSelection: function() { siteSelection: function() {
this.tutorOptions = null; this.tutorOptions = [];
this.tutorSelection = null; this.tutorSelection = null;
this.getTutors(); this.getTutors();
} }
@ -145,7 +150,7 @@ export default {
mounted() { mounted() {
this.getFilteredAverage(); this.getFilteredAverage();
Vue.axios Vue.axios
.get("/site/all") .get("/site")
.then(response => { .then(response => {
this.siteOptions = response.data; this.siteOptions = response.data;
}) })

View File

@ -1,114 +1,150 @@
<template> <template>
<b-container> <b-container fluid>
<b-row> <b-modal ref="errorModal" class="text-center" centered hide-header hide-footer>
<b-col> <div class="modal-header">
<b-form-group label="Site"> <h3 class="modal-title w-100">{{ errorStatus }}</h3>
<b-form-select v-model="siteSelection" :options="siteOptions" style="text-align:center;" /> </div>
</b-form-group> <div class="d-block">
</b-col> <br/>
<b-col> <span style="font-size:20px;" v-html="errorMessage"/>
<b-form-group label="Who"> <button class="btn btn-warning" @click="$refs.errorModal.hide()">
<b-form-input v-model="whom" type="text" style="text-align:center;"></b-form-input> <v-icon name="exclamation-circle"/>
</b-form-group> Dismiss
</b-col> </button>
<b-col> </div>
<b-form-group label="From"> </b-modal>
<date-picker v-model="startDate" @dp-change="changeStartDate" value="startDate" :config="dateOptions" />
</b-form-group>
</b-col>
<b-col>
<b-form-group label="To">
<date-picker v-model="endDate" @dp-change="changeEndDate" value="endDate" :config="dateOptions" />
</b-form-group>
</b-col>
<b-col>
<b-button v-on:click="getFiltered()">Refresh</b-button>
</b-col>
</b-row>
<b-container v-if="observationData != null">
<b-container v-for="(observation, index) in observationData" v-bind:key="index">
<b-row> <b-row>
<b-col> <b-col>
<p>{{ observation.date }}-{{ observation.type }}/{{ observation.observed }}-{{ obsevation.whom }}</p> <b-form-group label="Site">
</b-col> <b-form-select class="text-center" v-model="siteSelection"
</b-row> :options="siteOptions"/>
<b-row v-for="(entry, index) in observation.observations" v-bind:key="index"> </b-form-group>
<b-row>
<b-col cols="3">
<p>{{ entry.type }}</p>
<p>{{ entry.rating }}</p>
</b-col> </b-col>
<b-col> <b-col>
<b-form-group label="Strengths"> <b-form-group label="Tutor">
<b-form-textarea :value="entry.strengths" readonly> <b-form-select class="text-center" v-model="tutorSelection"
</b-form-textarea> :options="tutorOptions"/>
</b-form-group> </b-form-group>
<b-form-group label="Areas of Improvement"> </b-col>
<b-form-textarea :value="entry.improvements" readonly> <b-col>
</b-form-textarea> <b-form-group label="Who">
</b-form-group> <b-form-input v-model="whom" type="text" class="text-center"></b-form-input>
</b-form-group>
</b-col>
<b-col>
<b-form-group label="From">
<date-picker v-model="startDate" @dp-change="changeStartDate" value="startDate"
:config="dateOptions"/>
</b-form-group>
</b-col>
<b-col>
<b-form-group label="To">
<date-picker v-model="endDate" @dp-change="changeEndDate" value="endDate"
:config="dateOptions"/>
</b-form-group>
</b-col>
<b-col>
<b-button v-on:click="getFiltered()">Refresh</b-button>
</b-col> </b-col>
</b-row>
</b-row> </b-row>
</b-container> <b-container v-if="observationData != null" fluid>
<b-card no-body>
<b-tabs pills card vertical>
<b-tab v-for="(observation, index) in observationData" v-bind:key="index">
<p slot="title">{{ observation.date }}<br/>{{ observation.whom }} {{ observation.type }}<br/>{{ observation.observed }}</p>
<div v-for="(entry, index2) in observation.entries" v-bind:key="index2">
<p>{{ entry.type }} - {{ entry.rating }}</p>
<b-form-group label="Strengths">
<b-form-textarea :value="entry.strengths" readonly>
</b-form-textarea>
</b-form-group>
<b-form-group label="Areas of Improvement">
<b-form-textarea :value="entry.improvements" readonly>
</b-form-textarea>
</b-form-group>
</div>
</b-tab>
</b-tabs>
</b-card>
</b-container>
</b-container> </b-container>
</b-container>
</template> </template>
<script> <script>
export default { import Vue from "vue";
name: "viewobservations",
data: function() { var moment = require("moment");
return { export default {
startDate: moment().subtract(7, "days"), name: "viewobservations",
endDate: moment(), data: function () {
dateOptions: { return {
format: "DD/MM/YYYY", startDate: moment().subtract(7, "days"),
useCurrent: false endDate: moment(),
}, dateOptions: {
siteSelection: null, format: "DD/MM/YYYY",
siteOptions: [], useCurrent: false
tutorSelection: null, },
tutorOptions: null, siteSelection: null,
whom: null, siteOptions: [],
observationData: null tutorSelection: null,
tutorOptions: [],
whom: null,
observationData: null,
errorStatus: null,
errorMessage: null
};
},
mounted() {
Vue.axios
.get("/site")
.then(response => {
this.siteOptions = response.data;
})
.catch(error => {
console.log(error);
});
},
methods: {
getFiltered: function () {
Vue.axios
.post("/observations", {
site: this.siteSelection,
tutor: this.tutorSelection,
startDate: moment(this.startDate).format("YYYY-MM-DD"),
endDate: moment(this.endDate).format("YYYY-MM-DD"),
whom: this.whom
})
.then(response => {
this.observationData = response.data;
})
.catch(error => {
this.errorStatus = error.response.status;
this.errorMessage = error.response.data;
this.$refs.errorModal.show();
});
},
changeStartDate: function (e) {
this.startDate = e.date;
},
changeEndDate: function (e) {
this.endDate = e.date;
},
getTutors: function () {
if (this.siteSelection != null) {
Vue.axios
.get("/site/" + this.siteSelection + "/tutors")
.then(response => {
this.tutorOptions = response.data;
});
}
}
},
watch: {
siteSelection: function () {
this.tutorOptions = [];
this.tutorSelection = null;
this.getTutors();
}
}
}; };
},
mounted() {
Vue.axios
.get("/site/all")
.then(response => {
this.siteOptions = response.data;
})
.catch(error => {
console.log(error);
});
},
methods: {
getFiltered: function() {
Vue.axios
.get("/observations", {
site: this.siteSelection,
tutor: this.tutorSelection,
startDate: moment(this.startDate).format("YYYY-MM-DD"),
endDate: moment(this.endDate).format("YYYY-MM-DD"),
whom: this.whom
})
.then(response => {
this.chartData = response.data;
})
.catch(error => {
this.errorStatus = error.response.status;
this.errorMessage = error.response.data;
this.$refs.errorModal.show();
});
},
changeStartDate: function(e) {
this.startDate = e.date;
},
changeEndDate: function(e) {
this.endDate = e.date;
}
}
};
</script> </script>