Fixed viewing observations and stats.
This commit is contained in:
parent
76e19e9253
commit
e6e69b2df9
@ -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>
|
||||||
|
@ -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,
|
||||||
|
@ -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
|
||||||
)
|
)
|
@ -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
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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;
|
||||||
})
|
})
|
||||||
|
@ -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>
|
||||||
|
Loading…
Reference in New Issue
Block a user