2021-06-29 09:42:10 +00:00
|
|
|
<template>
|
|
|
|
<div class="col-sm-4 col-xs-12">
|
2023-05-17 11:46:54 +00:00
|
|
|
<q-input
|
|
|
|
v-model.number="amount"
|
|
|
|
ref="refAmount"
|
|
|
|
type="number"
|
|
|
|
filled
|
|
|
|
label="Betrag"
|
|
|
|
step="0.1"
|
|
|
|
min="0"
|
|
|
|
suffix="€"
|
|
|
|
:rules="[check_cent_step]"
|
|
|
|
/>
|
2021-06-29 09:42:10 +00:00
|
|
|
</div>
|
|
|
|
<div class="col-sm-4 col-xs-6">
|
|
|
|
<UserSelector v-model="receiver" label="Empfänger" />
|
|
|
|
</div>
|
|
|
|
<div class="col-sm-4 col-xs-6">
|
2023-05-09 22:27:41 +00:00
|
|
|
<q-btn style="width: 100%" color="primary" :disable="sendDisabled" label="Senden" @click="sendAmount" />
|
2021-06-29 09:42:10 +00:00
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
|
|
import { computed, defineComponent, PropType, ref } from 'vue';
|
2023-05-17 11:46:54 +00:00
|
|
|
import { QInput } from 'quasar';
|
2021-06-29 09:42:10 +00:00
|
|
|
import UserSelector from '@flaschengeist/users/src/components/UserSelector.vue';
|
|
|
|
import { useBalanceStore } from '../store';
|
2023-05-17 11:46:54 +00:00
|
|
|
import { check_cent_step } from '../utils';
|
2021-06-29 09:42:10 +00:00
|
|
|
import { useUserStore } from '@flaschengeist/api';
|
|
|
|
export default defineComponent({
|
|
|
|
name: 'BalanceTransferBody',
|
|
|
|
components: { UserSelector },
|
|
|
|
props: {
|
|
|
|
user: {
|
|
|
|
type: [Object, String] as PropType<FG.User | string>,
|
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
emits: {
|
2023-05-09 22:27:41 +00:00
|
|
|
changeBalance: ({ sender, receiver }: { sender: FG.User; receiver: FG.User }) => sender && receiver,
|
2021-06-29 09:42:10 +00:00
|
|
|
},
|
|
|
|
setup(props, { emit }) {
|
|
|
|
const store = useBalanceStore();
|
|
|
|
const userStore = useUserStore();
|
|
|
|
const receiver = ref<FG.User | undefined>(undefined);
|
|
|
|
const amount = ref<number>(0);
|
2023-05-17 11:46:54 +00:00
|
|
|
const refAmount = ref<QInput>();
|
2021-06-29 09:42:10 +00:00
|
|
|
const sender = computed(() =>
|
|
|
|
(<FG.User>props.user).userid
|
|
|
|
? <FG.User>props.user
|
|
|
|
: <FG.User>userStore.users.find((a) => a.userid === <string>props.user)
|
|
|
|
);
|
|
|
|
|
|
|
|
const sendDisabled = computed(() => {
|
2023-05-17 11:46:54 +00:00
|
|
|
return !(
|
|
|
|
receiver.value &&
|
|
|
|
sender.value &&
|
|
|
|
sender.value.userid != receiver.value.userid &&
|
|
|
|
amount.value > 0 &&
|
|
|
|
!refAmount.value?.hasError
|
|
|
|
);
|
2021-06-29 09:42:10 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
async function sendAmount() {
|
2023-05-17 11:46:54 +00:00
|
|
|
await refAmount.value?.validate();
|
|
|
|
if (receiver.value && !refAmount.value?.hasError) {
|
2021-06-29 09:42:10 +00:00
|
|
|
await store.changeBalance(amount.value, receiver.value, sender.value);
|
2023-05-09 22:27:41 +00:00
|
|
|
emit('changeBalance', { sender: sender.value, receiver: receiver.value });
|
2021-06-29 09:42:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
receiver,
|
|
|
|
sender,
|
|
|
|
amount,
|
|
|
|
sendAmount,
|
|
|
|
sendDisabled,
|
2023-05-17 11:46:54 +00:00
|
|
|
refAmount,
|
|
|
|
check_cent_step,
|
2021-06-29 09:42:10 +00:00
|
|
|
};
|
|
|
|
},
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style scoped></style>
|