diff --git a/package-lock.json b/package-lock.json index 690ea9194..0b1bef388 100644 --- a/package-lock.json +++ b/package-lock.json @@ -15,7 +15,7 @@ "@headlessui/vue": "^1.7.13", "@nethesis/nethesis-light-svg-icons": "github:nethesis/Font-Awesome#ns-light", "@nethesis/nethesis-solid-svg-icons": "github:nethesis/Font-Awesome#ns-solid", - "@nethserver/vue-tailwind-lib": "^0.0.77", + "@nethserver/vue-tailwind-lib": "^0.0.79", "@types/lodash": "^4.14.195", "axios": "^1.4.0", "chart.js": "^4.4.0", @@ -1275,9 +1275,9 @@ } }, "node_modules/@nethserver/vue-tailwind-lib": { - "version": "0.0.77", - "resolved": "https://registry.npmmirror.com/@nethserver/vue-tailwind-lib/-/vue-tailwind-lib-0.0.77.tgz", - "integrity": "sha512-hWg/BsFWJhOrFkdNgunCjLur0tZfq3Q3FKZ0DKgk1ERtePGvgneVPjjleUTWhOLU62tsX3bU74a1RrR1J6TyuA==", + "version": "0.0.79", + "resolved": "https://registry.npmmirror.com/@nethserver/vue-tailwind-lib/-/vue-tailwind-lib-0.0.79.tgz", + "integrity": "sha512-oscpVqhP5EYLd4gD2oyrWf3kY1xUXwdzioXGnCYFDf+o9dm/qE3M6Haq9fvTr0bkKTLRKzKzYwcJfSPE2SfwSg==", "dependencies": { "@fortawesome/fontawesome-svg-core": "^6.4.0", "@fortawesome/free-solid-svg-icons": "github:nethesis/Font-Awesome#solid", diff --git a/package.json b/package.json index 544760bbf..a1a0e6bed 100644 --- a/package.json +++ b/package.json @@ -21,7 +21,7 @@ "@headlessui/vue": "^1.7.13", "@nethesis/nethesis-light-svg-icons": "github:nethesis/Font-Awesome#ns-light", "@nethesis/nethesis-solid-svg-icons": "github:nethesis/Font-Awesome#ns-solid", - "@nethserver/vue-tailwind-lib": "^0.0.77", + "@nethserver/vue-tailwind-lib": "^0.0.79", "@types/lodash": "^4.14.195", "axios": "^1.4.0", "chart.js": "^4.4.0", diff --git a/public/i18n/en/translation.json b/public/i18n/en/translation.json index da9ebc7a8..33937c59a 100644 --- a/public/i18n/en/translation.json +++ b/public/i18n/en/translation.json @@ -57,11 +57,11 @@ "cannot_retrieve_wan_traffic": "Cannot retrieve WAN traffic", "register_unit_error": "Cannot register unit", "cancel_registration_error": "Cannot cancel registration", - "cannot_load_routes": "Cannot retrive routes", + "cannot_load_routes": "Cannot retrieve routes", "cannot_create_route": "Cannot create route", "cannot_edit_route": "Cannot edit route", - "cannot_retrive_interfaces": "Cannot retrieve interfaces", - "cannot_retrive_route_types": "Cannot retrieve route types", + "cannot_retrieve_interfaces": "Cannot retrieve interfaces", + "cannot_retrieve_route_types": "Cannot retrieve route types", "invalid_metric": "Enter an integer number greater than or equal to 0", "cannot_update_status_route": "Cannot update route status", "cannot_delete_port_forward": "Cannot delete port forward", @@ -480,7 +480,8 @@ "route_type": "Route type", "route_choose_type": "Select route type", "route_mtu": "MTU", - "route_onlink": "On-link\nWhen enabled, gateway is on-link even if the gateway does not match any interface prefix" + "route_onlink": "On-link", + "route_onlink_description": "When enabled, gateway is on-link even if the gateway does not match any interface prefix" }, "users_and_objects": { "title": "Users & objects" diff --git a/src/components/standalone/routes/CreateOrEditRouteDrawer.vue b/src/components/standalone/routes/CreateOrEditRouteDrawer.vue index 9852925ff..815151df2 100644 --- a/src/components/standalone/routes/CreateOrEditRouteDrawer.vue +++ b/src/components/standalone/routes/CreateOrEditRouteDrawer.vue @@ -130,7 +130,7 @@ watch( if (selectedRoute.item.interface) form.value.routeInterface = selectedRoute.item.interface if (selectedRoute.item.type) form.value.routeType = selectedRoute.item.type if (selectedRoute.item.mtu) form.value.mtu = selectedRoute.item.mtu - if (selectedRoute.item.onlink) form.value.onlink = selectedRoute.item.mtu === '0' + if (selectedRoute.item.onlink) form.value.onlink = selectedRoute.item.onlink === '1' } else form.value = { ...originalForm } } else form.value = { ...originalForm } } @@ -163,7 +163,7 @@ async function getFirewallData() { error = ref({ ...objError }) errorLoadingData = ref({ ...objError }) - // Retrive list interfaces && route types + // retrieve list interfaces && route types try { let getInterfaces = await ubusCall('ns.routes', 'list-interfaces', {}) if ( @@ -172,7 +172,10 @@ async function getFirewallData() { getInterfaces.data.interfaces && getInterfaces.data.interfaces.length ) { - routeInterfaces.value = getInterfaces.data.interfaces.map((item: RouteInterface) => ({ + let responseData = getInterfaces.data.interfaces + responseData = responseData.filter((item: string) => item !== 'loopback') + + routeInterfaces.value = responseData.map((item: RouteInterface) => ({ id: item, label: item })) @@ -184,7 +187,7 @@ async function getFirewallData() { } } } catch (exception: any) { - errorLoadingData.value.notificationTitle = t('error.cannot_retrive_interfaces') + errorLoadingData.value.notificationTitle = t('error.cannot_retrieve_interfaces') errorLoadingData.value.notificationDescription = t(getAxiosErrorMessage(exception)) } finally { try { @@ -200,7 +203,7 @@ async function getFirewallData() { label: item })) } catch (exception: any) { - errorLoadingData.value.notificationTitle = t('error.cannot_retrive_route_types') + errorLoadingData.value.notificationTitle = t('error.cannot_retrieve_route_types') errorLoadingData.value.notificationDescription = t(getAxiosErrorMessage(exception)) } finally { loading.value = false @@ -331,7 +334,6 @@ function validate(): boolean { function createRoute() { if (validate()) { saving.value = true - let isValidCreate = true // create payload let payload = { @@ -355,28 +357,30 @@ function createRoute() { ubusCall('ns.routes', methodUpdateStatus, { id: response.data.id - }).catch((exception: AxiosError) => { - error.value.notificationTitle = t('error.cannot_update_status_route') - error.value.notificationDescription = t(getAxiosErrorMessage(exception)) - isValidCreate = false }) + .then(() => { + emit('routeCreated') + }) + .catch((exception: AxiosError) => { + error.value.notificationTitle = t('error.cannot_update_status_route') + error.value.notificationDescription = t(getAxiosErrorMessage(exception)) + }) + .finally(() => { + saving.value = false + }) } }) .catch((exception: AxiosError) => { error.value.notificationTitle = t('error.cannot_create_route') error.value.notificationDescription = t(getAxiosErrorMessage(exception)) - isValidCreate = false + saving.value = false }) - .finally(() => (saving.value = false)) - - if (isValidCreate) emit('routeCreated') } } function editRoute() { if (validate()) { saving.value = true - let isValidUpdate = true // create payload let payload = { @@ -401,21 +405,24 @@ function editRoute() { ubusCall('ns.routes', methodUpdateStatus, { id: response.data.id - }).catch((exception: AxiosError) => { - error.value.notificationTitle = t('error.cannot_update_status_route') - error.value.notificationDescription = t(getAxiosErrorMessage(exception)) - isValidUpdate = false }) + .then(() => { + emit('routeEdited') + }) + .catch((exception: AxiosError) => { + error.value.notificationTitle = t('error.cannot_update_status_route') + error.value.notificationDescription = t(getAxiosErrorMessage(exception)) + }) + .finally(() => { + saving.value = false + }) } }) .catch((exception: AxiosError) => { error.value.notificationTitle = t('error.cannot_edit_route') error.value.notificationDescription = t(getAxiosErrorMessage(exception)) - isValidUpdate = false + saving.value = false }) - .finally(() => (saving.value = false)) - - if (isValidUpdate) emit('routeEdited') } } @@ -514,6 +521,10 @@ function editRoute() { ref="mtuRef" /> + - {{ t('common.edit') }} + {{ t('common.save') }} diff --git a/src/components/standalone/routes/RoutesContent.vue b/src/components/standalone/routes/RoutesContent.vue index da7e88e08..62cfcd5c8 100644 --- a/src/components/standalone/routes/RoutesContent.vue +++ b/src/components/standalone/routes/RoutesContent.vue @@ -14,10 +14,10 @@ import { NeDropdown, NeTitle, NeModal, + NeEmptyState, NeInlineNotification } from '@nethserver/vue-tailwind-lib' import NeTable from '@/components/standalone/NeTable.vue' -import HorizontalCard from '@/components/standalone/HorizontalCard.vue' import { FontAwesomeIcon } from '@fortawesome/vue-fontawesome' import { faCirclePlus, @@ -68,6 +68,7 @@ onMounted(async () => { * get all routes */ async function loadRoutes() { + loading.value = true try { const res = await ubusCall('ns.routes', 'list-routes', { protocol: props.protocol @@ -84,9 +85,10 @@ async function loadRoutes() { routes.value = items } catch (err: any) { - console.error(err) error.value.notificationTitle = t('error.cannot_load_routes') error.value.notificationDescription = t(getAxiosErrorMessage(err)) + } finally { + loading.value = false } } @@ -101,7 +103,6 @@ async function loadMainTable() { if (res.data) table.value = res.data.table } catch (err: any) { - console.error(err) error.value.notificationTitle = t('error.cannot_load_routes') error.value.notificationDescription = t(getAxiosErrorMessage(err)) } @@ -116,8 +117,9 @@ function routeCreatedEditedHandler() { } function reloadConfig() { - loadRoutes() uciPendingChangesStore.getChanges() + loadRoutes() + loadMainTable() } function openCreateRoute() { @@ -159,15 +161,18 @@ function scrollToMainTable() { - - {{ t('standalone.routes.no_route_found') }} - + + - + - {{ t('standalone.routes.create_route') }} - - + {{ t('standalone.routes.create_route') }} + @@ -199,7 +204,13 @@ function scrollToMainTable() { /> - + {{ t('standalone.routes.main_table') }} @@ -242,12 +253,12 @@ function scrollToMainTable() { - - + + {{ item.ns_description }} - - + - + {{ item.target }} - + {{ item.gateway }} - + {{ item.metric }} - + {{ t('standalone.routes.route_status_enabled') }}
{{ t('standalone.routes.no_route_found') }}