webguicomp/cards/AstroTimerCard.vue

105 lines
3.5 KiB
Vue

<template>
<q-card flat class="card">
<q-card-section>
<div class="text-h6">ASTRO Scheduler</div>
</q-card-section>
<q-card-section class="q-pt-none">
<div class="row">
<div class="q-pa-md col-6"><q-input v-model="data.astrorecs.lat" label="LAT" /></div>
<div class="q-pa-md col-6"><q-input v-model="data.astrorecs.lon" label="LON" /></div>
</div>
</q-card-section>
<q-card-section class="q-pt-none">
<q-expansion-item flat v-for="astrorec in data.astrorecs.records" :key="astrorec.num"
:label="list_header(astrorec)" v-show="!astrorec.del">
<q-card flat bordered>
<q-card-section class="q-pt-none">
<div><q-toggle v-model="astrorec.enab" :true-value=1 :false-value=0>Task enabled</q-toggle>
</div>
<div><q-toggle v-model="astrorec.rise" :true-value=1 :false-value=0>
{{ (astrorec.rise) ? 'Sunrise' : 'Sunset' }}</q-toggle></div>
<div><q-toggle v-model="astrorec.sensor_enab" :true-value=1 :false-value=0>Light sensor</q-toggle></div>
<div class="row" v-if="astrorec.sensor_enab" style="align-items: center;">
<div class="q-pa-xs col-6"><q-input v-model="astrorec.sensor_angle" label="Sensor Sun angle" /></div>
<div class="q-pa-xs col-6 text-h6">{{ min_to_str(astrorec.sensor_time) }}</div>
</div>
<div class="row" style="align-items: center;">
<div class="q-pa-xs col-6"><q-input v-model="astrorec.main_angle" label="Main Sun angle" /></div>
<div class="q-pa-xs col-6 text-h6">{{ min_to_str(astrorec.main_time) }}</div>
</div>
<q-input v-model="astrorec.name" label="Task name" />
<q-input v-model="astrorec.exec" label="Execute command" />
</q-card-section>
<q-card-actions>
<q-btn class="btn" flat v-on:click="ApplyAstroRecord(astrorec.num)">Save task</q-btn>
<q-btn class="btn" flat v-on:click="DeleteAstroRecord(astrorec.num)">Delete task</q-btn>
</q-card-actions>
</q-card>
</q-expansion-item>
</q-card-section>
<q-card-actions>
<div class="q-pa-md">
<q-btn class="btn" flat v-on:click="AddAstroRecord">Add task</q-btn>
</div>
</q-card-actions>
</q-card>
</template>
<script setup>
import { reactive, computed } from "vue";
import { PostData } from "components/webguicomp/network";
import { ShowDelayDialog } from "components/webguicomp/helpers";
function min_to_str(min) {
return `${Math.floor(min / 60)}h ${min % 60}m`
}
function list_header(rec) {
return `Task ${rec.num} [${rec.name}]`;
}
function initrecs() {
let out = [], rec, i;
for (i = 1; i <= 16; i++) {
rec = {
num: i, del: 1, enab: 1, rise: 1, sensor_enab: 0, sensor_angle: 0,
sensor_time: 0, main_angle: 0, main_time: 0, name: "", exec: "",
}
out.push(rec);
}
return out;
};
const init = {
astrorecs: {
lat: 0,
lon: 0,
records: initrecs()
}
}
function ApplyAstroRecord() {
PostData(data, 1, 1, null);
}
function DeleteAstroRecord(num) {
data.astrorecs.records[num - 1].del = 1;
ApplyAstroRecord(num);
}
function AddAstroRecord() {
for (let i = 0; i < 16; i++) {
if (data.astrorecs.records[i].del == 1) {
data.astrorecs.records[i].del = 0;
data.astrorecs.records[i].enab = 0;
ApplyAstroRecord(i + 1);
break;
}
}
}
const data = reactive(init);
PostData(data, 2, 0, null);
</script>