FreeDATA/gui/src/components/settings_modem.vue

234 lines
7.4 KiB
Vue
Raw Normal View History

2023-09-06 10:23:20 +00:00
<script setup lang="ts">
2023-11-18 15:59:19 +00:00
import { settingsStore as settings, onChange } from "../store/settingsStore.js";
2023-10-03 13:15:17 +00:00
import pinia from "../store/index";
import { useStateStore } from "../store/stateStore.js";
const state = useStateStore(pinia);
import { startModem, stopModem } from "../js/api.js";
import { audioInputOptions, audioOutputOptions } from "../js/deviceFormHelper";
2023-09-06 10:23:20 +00:00
</script>
<template>
<div>
<button
2023-11-03 14:40:01 +00:00
type="button"
id="startModem"
class="btn btn-sm btn-outline-success"
data-bs-toggle="tooltip"
data-bs-trigger="hover"
data-bs-html="false"
title="Start the Modem. Please set your audio and radio settings first!"
2023-11-09 21:11:53 +00:00
@click="startModem"
2023-11-13 16:40:21 +00:00
v-bind:class="{ disabled: state.is_modem_running === true }"
2023-11-03 14:40:01 +00:00
>
<i class="bi bi-play-fill"></i>
<span class="ms-2">start modem</span>
</button>
<button
type="button"
id="stopModem"
class="btn btn-sm btn-outline-danger"
data-bs-toggle="tooltip"
data-bs-trigger="hover"
data-bs-html="false"
title="Stop the Modem."
2023-11-09 21:11:53 +00:00
@click="stopModem"
2023-11-13 16:40:21 +00:00
v-bind:class="{ disabled: state.is_modem_running === false }"
2023-11-03 14:40:01 +00:00
>
<i class="bi bi-stop-fill"></i>
<span class="ms-2">stop modem</span>
</button>
</div>
2023-10-03 13:15:17 +00:00
<div class="input-group input-group-sm mb-1">
<span class="input-group-text" style="width: 180px">Modem port</span>
2023-10-03 13:15:17 +00:00
<input
type="number"
2023-10-03 13:15:17 +00:00
class="form-control"
2023-10-20 12:29:24 +00:00
placeholder="modem port"
id="modem_port"
2023-10-03 13:15:17 +00:00
maxlength="5"
max="65534"
min="1025"
2023-11-18 15:56:39 +00:00
v-model.number="settings.local.port"
2023-10-03 13:15:17 +00:00
/>
</div>
2023-09-06 10:23:20 +00:00
2023-10-03 13:15:17 +00:00
<div class="input-group input-group-sm mb-1">
<span class="input-group-text" style="width: 180px">Modem host</span>
2023-10-03 13:15:17 +00:00
<input
type="text"
class="form-control"
2023-10-20 12:29:24 +00:00
placeholder="modem host"
id="modem_port"
2023-11-18 15:56:39 +00:00
v-model="settings.local.host"
2023-10-03 13:15:17 +00:00
/>
</div>
2023-09-06 10:23:20 +00:00
<!-- Audio Input Device -->
<div class="input-group input-group-sm mb-1">
<label class="input-group-text w-50">Audio Input device</label>
<select
2023-11-03 14:40:01 +00:00
class="form-select form-select-sm"
aria-label=".form-select-sm"
2023-11-18 15:59:19 +00:00
@change="onChange"
v-model="settings.remote.AUDIO.input_device"
>
<option v-for="option in audioInputOptions()" v-bind:value="option.id">
2023-12-19 01:55:21 +00:00
{{ option.name }} [{{ option.api }}]
</option>
</select>
</div>
<!-- Audio Output Device -->
<div class="input-group input-group-sm mb-1">
<label class="input-group-text w-50">Audio Output device</label>
<select
2023-11-03 14:40:01 +00:00
class="form-select form-select-sm"
aria-label=".form-select-sm"
2023-11-18 15:59:19 +00:00
@change="onChange"
v-model="settings.remote.AUDIO.output_device"
>
<option v-for="option in audioOutputOptions()" v-bind:value="option.id">
2023-12-19 01:55:21 +00:00
{{ option.name }} [{{ option.api }}]
</option>
</select>
</div>
2023-10-03 13:15:17 +00:00
<div class="input-group input-group-sm mb-1">
<label class="input-group-text w-50">TX delay in ms</label>
<select
class="form-select form-select-sm"
id="tx_delay"
2023-11-18 15:59:19 +00:00
@change="onChange"
v-model.number="settings.remote.MODEM.tx_delay"
2023-10-03 13:15:17 +00:00
>
<option value="0">0</option>
<option value="50">50</option>
<option value="100">100</option>
<option value="150">150</option>
<option value="200">200</option>
<option value="250">250</option>
<option value="300">300</option>
<option value="350">350</option>
<option value="400">400</option>
<option value="450">450</option>
<option value="500">500</option>
<option value="550">550</option>
<option value="600">600</option>
<option value="650">650</option>
<option value="700">700</option>
<option value="750">750</option>
<option value="800">800</option>
<option value="850">850</option>
<option value="900">900</option>
<option value="950">950</option>
<option value="1000">1000</option>
</select>
</div>
2023-09-06 10:23:20 +00:00
2023-10-03 13:15:17 +00:00
<div class="input-group input-group-sm mb-1">
<label class="input-group-text w-25">Tuning range</label>
<label class="input-group-text">fmin</label>
<select
class="form-select form-select-sm"
id="tuning_range_fmin"
2023-11-18 15:59:19 +00:00
@change="onChange"
v-model.number="settings.remote.MODEM.tuning_range_fmin"
2023-10-03 13:15:17 +00:00
>
<option value="-50">-50</option>
<option value="-100">-100</option>
<option value="-150">-150</option>
<option value="-200">-200</option>
<option value="-250">-250</option>
2023-10-03 13:15:17 +00:00
</select>
<label class="input-group-text">fmax</label>
<select
class="form-select form-select-sm"
id="tuning_range_fmax"
2023-11-18 15:59:19 +00:00
@change="onChange"
v-model.number="settings.remote.MODEM.tuning_range_fmax"
2023-10-03 13:15:17 +00:00
>
<option value="50">50</option>
<option value="100">100</option>
<option value="150">150</option>
<option value="200">200</option>
<option value="250">250</option>
2023-10-03 13:15:17 +00:00
</select>
</div>
<div class="input-group input-group-sm mb-1">
<span class="input-group-text w-50">Beacon interval</span>
<select
class="form-select form-select-sm"
aria-label=".form-select-sm"
id="beaconInterval"
style="width: 6rem"
2023-11-18 15:59:19 +00:00
@change="onChange"
v-model.number="settings.remote.MODEM.beacon_interval"
2023-10-03 13:15:17 +00:00
>
<option value="60">60 secs</option>
<option value="90">90 secs</option>
<option value="120">2 mins</option>
<option selected value="300">5 mins</option>
<option value="600">10 mins</option>
<option value="900">15 mins</option>
<option value="1800">30 mins</option>
<option value="3600">60 mins</option>
</select>
</div>
2024-01-05 22:20:21 +00:00
2023-10-03 13:15:17 +00:00
<div class="input-group input-group-sm mb-1">
2023-10-15 05:37:15 +00:00
<label class="input-group-text w-50">Enable 250Hz bandwidth mode</label>
2023-10-03 13:15:17 +00:00
<label class="input-group-text w-50">
<div class="form-check form-switch form-check-inline">
<input
class="form-check-input"
type="checkbox"
id="250HzModeSwitch"
2023-11-18 15:59:19 +00:00
v-model="settings.remote.MODEM.enable_low_bandwidth_mode"
@change="onChange"
2023-10-03 13:15:17 +00:00
/>
<label class="form-check-label" for="250HzModeSwitch">250Hz</label>
</div>
</label>
</div>
<div class="input-group input-group-sm mb-1">
<label class="input-group-text w-50">Respond to CQ</label>
<label class="input-group-text w-50">
<div class="form-check form-switch form-check-inline">
<input
class="form-check-input"
type="checkbox"
id="respondCQSwitch"
2023-11-18 15:59:19 +00:00
v-model="settings.remote.MODEM.respond_to_cq"
@change="onChange"
2023-10-03 13:15:17 +00:00
/>
<label class="form-check-label" for="respondCQSwitch">QRV</label>
</div>
</label>
</div>
<div class="input-group input-group-sm mb-1">
<label class="input-group-text w-50">RX buffer size</label>
<label class="input-group-text w-50">
2023-09-06 10:23:20 +00:00
<select
class="form-select form-select-sm"
2023-10-03 13:15:17 +00:00
id="rx_buffer_size"
2023-11-18 15:59:19 +00:00
@change="onChange"
v-model.number="settings.remote.MODEM.rx_buffer_size"
2023-09-06 10:23:20 +00:00
>
2023-10-03 13:15:17 +00:00
<option value="1">1</option>
<option value="2">2</option>
<option value="4">4</option>
<option value="8">8</option>
<option value="16">16</option>
<option value="32">32</option>
<option value="64">64</option>
<option value="128">128</option>
<option value="256">256</option>
<option value="512">512</option>
<option value="1024">1024</option>
2023-09-06 10:23:20 +00:00
</select>
2023-10-03 13:15:17 +00:00
</label>
</div>
2023-09-06 10:23:20 +00:00
</template>