diff --git a/frontend/src/components/Settings/PaymentGatewayDetails.vue b/frontend/src/components/Settings/PaymentGatewayDetails.vue index feb21f88..b6d5cb0d 100644 --- a/frontend/src/components/Settings/PaymentGatewayDetails.vue +++ b/frontend/src/components/Settings/PaymentGatewayDetails.vue @@ -131,7 +131,7 @@ watch(newGateway, () => { let fields = gatewayFields.data || [] arrangeFields(fields) newGatewayFields.value = makeSections(fields) - prepareGatewayData() + prepareGatewayData(fields) }) }) @@ -209,13 +209,11 @@ const allGatewayOptions = computed(() => { return options.map((gateway: string) => ({ label: gateway, value: gateway })) }) -const prepareGatewayData = () => { +const prepareGatewayData = (fields: any[]) => { newGatewayData.value = {} - if (newGatewayFields.value.length) { - newGatewayFields.value.forEach((field: any) => { - newGatewayData.value[field.fieldname] = field.default || '' - }) - } + fields.forEach((field: any) => { + newGatewayData.value[field.name] = field.default || '' + }) } const makeSections = (fields: any[]) => { diff --git a/frontend/src/components/Settings/PaymentGateways.vue b/frontend/src/components/Settings/PaymentGateways.vue index c1f2c809..a35b8344 100644 --- a/frontend/src/components/Settings/PaymentGateways.vue +++ b/frontend/src/components/Settings/PaymentGateways.vue @@ -88,6 +88,7 @@ import { Badge, Button, + call, createListResource, FeatherIcon, ListView, @@ -97,10 +98,12 @@ import { ListRow, ListRowItem, ListSelectBanner, + toast, } from 'frappe-ui' import { computed, ref } from 'vue' import { Plus, Trash2 } from 'lucide-vue-next' import PaymentGatewayDetails from '@/components/Settings/PaymentGatewayDetails.vue' +import { cleanError } from '@/utils' const showForm = ref(false) const currentGateway = ref(null) @@ -128,6 +131,23 @@ const openForm = (gatewayID) => { showForm.value = true } +const removeAccount = (selections, unselectAll) => { + call('lms.lms.api.delete_documents', { + doctype: 'Payment Gateway', + documents: Array.from(selections), + }) + .then(() => { + paymentGateways.reload() + toast.success(__('Payment gateways deleted successfully')) + unselectAll() + }) + .catch((err) => { + toast.error( + cleanError(err.messages[0]) || __('Error deleting payment gateways') + ) + }) +} + const columns = computed(() => { return [ { diff --git a/frontend/src/components/Settings/SettingFields.vue b/frontend/src/components/Settings/SettingFields.vue index 7dfacb3d..11a9a3f3 100644 --- a/frontend/src/components/Settings/SettingFields.vue +++ b/frontend/src/components/Settings/SettingFields.vue @@ -20,6 +20,7 @@ :doctype="field.doctype" :label="__(field.label)" :description="__(field.description)" + :required="field.reqd" />