frequi_origin/src/components/ftbot/TimeframeSelect.vue

57 lines
1.1 KiB
Vue
Raw Normal View History

2021-05-23 14:54:38 +00:00
<template>
<b-form-select
v-model="selectedTimeframe"
placeholder="Use strategy default"
:options="availableTimeframes"
@change="emitSelectedTimeframe"
></b-form-select>
2021-05-23 14:54:38 +00:00
</template>
2023-05-09 17:55:12 +00:00
<script setup lang="ts">
import { computed, ref } from 'vue';
2021-05-23 14:54:38 +00:00
2023-05-09 17:55:12 +00:00
const props = defineProps({
value: { default: '', type: String },
belowTimeframe: { required: false, default: '', type: String },
});
const emit = defineEmits(['input']);
const selectedTimeframe = ref('');
// The below list must always remain sorted correctly!
const availableTimeframesBase = [
// Placeholder value
{ value: '', text: 'Use strategy default' },
'1m',
'3m',
'5m',
'15m',
'30m',
'1h',
'2h',
'4h',
'6h',
'8h',
'12h',
'1d',
'3d',
'1w',
'2w',
'1M',
'1y',
];
2023-05-09 17:55:12 +00:00
const availableTimeframes = computed(() => {
if (!props.belowTimeframe) {
return availableTimeframesBase;
}
const idx = availableTimeframesBase.findIndex((v) => v === props.belowTimeframe);
2021-05-23 14:54:38 +00:00
2023-05-09 17:55:12 +00:00
return [...availableTimeframesBase].splice(0, idx);
});
2023-05-09 17:55:12 +00:00
const emitSelectedTimeframe = () => {
emit('input', selectedTimeframe.value);
};
2021-05-23 14:54:38 +00:00
</script>
<style scoped></style>