mirror of
https://github.com/n8n-io/n8n.git
synced 2024-12-31 15:37:26 -08:00
fix: Credentials save button is hidden unless you make changes to the (#11492)
This commit is contained in:
parent
0fdb79a270
commit
835fbfe337
|
@ -88,6 +88,7 @@ const isDeleting = ref(false);
|
||||||
const isSaving = ref(false);
|
const isSaving = ref(false);
|
||||||
const isTesting = ref(false);
|
const isTesting = ref(false);
|
||||||
const hasUnsavedChanges = ref(false);
|
const hasUnsavedChanges = ref(false);
|
||||||
|
const isSaved = ref(false);
|
||||||
const loading = ref(false);
|
const loading = ref(false);
|
||||||
const showValidationWarning = ref(false);
|
const showValidationWarning = ref(false);
|
||||||
const testedSuccessfully = ref(false);
|
const testedSuccessfully = ref(false);
|
||||||
|
@ -317,8 +318,8 @@ const defaultCredentialTypeName = computed(() => {
|
||||||
|
|
||||||
const showSaveButton = computed(() => {
|
const showSaveButton = computed(() => {
|
||||||
return (
|
return (
|
||||||
(hasUnsavedChanges.value || !!credentialId.value) &&
|
(props.mode === 'new' || hasUnsavedChanges.value || isSaved.value) &&
|
||||||
(credentialPermissions.value.create || credentialPermissions.value.update)
|
(credentialPermissions.value.create ?? credentialPermissions.value.update)
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -838,6 +839,7 @@ async function updateCredential(
|
||||||
isSharedWithChanged.value = false;
|
isSharedWithChanged.value = false;
|
||||||
}
|
}
|
||||||
hasUnsavedChanges.value = false;
|
hasUnsavedChanges.value = false;
|
||||||
|
isSaved.value = true;
|
||||||
|
|
||||||
if (credential) {
|
if (credential) {
|
||||||
await externalHooks.run('credential.saved', {
|
await externalHooks.run('credential.saved', {
|
||||||
|
@ -889,6 +891,7 @@ async function deleteCredential() {
|
||||||
isDeleting.value = true;
|
isDeleting.value = true;
|
||||||
await credentialsStore.deleteCredential({ id: credentialId.value });
|
await credentialsStore.deleteCredential({ id: credentialId.value });
|
||||||
hasUnsavedChanges.value = false;
|
hasUnsavedChanges.value = false;
|
||||||
|
isSaved.value = true;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
toast.showError(
|
toast.showError(
|
||||||
error,
|
error,
|
||||||
|
@ -1074,7 +1077,7 @@ function resetCredentialData(): void {
|
||||||
/>
|
/>
|
||||||
<SaveButton
|
<SaveButton
|
||||||
v-if="showSaveButton"
|
v-if="showSaveButton"
|
||||||
:saved="!hasUnsavedChanges && !isTesting"
|
:saved="!hasUnsavedChanges && !isTesting && !!credentialId"
|
||||||
:is-saving="isSaving || isTesting"
|
:is-saving="isSaving || isTesting"
|
||||||
:saving-label="
|
:saving-label="
|
||||||
isTesting
|
isTesting
|
||||||
|
|
|
@ -0,0 +1,70 @@
|
||||||
|
import { createComponentRenderer } from '@/__tests__/render';
|
||||||
|
import CredentialEdit from '@/components/CredentialEdit/CredentialEdit.vue';
|
||||||
|
import { createTestingPinia } from '@pinia/testing';
|
||||||
|
import { CREDENTIAL_EDIT_MODAL_KEY, STORES } from '@/constants';
|
||||||
|
import { cleanupAppModals, createAppModals, retry } from '@/__tests__/utils';
|
||||||
|
|
||||||
|
vi.mock('@/permissions', () => ({
|
||||||
|
getResourcePermissions: vi.fn(() => ({
|
||||||
|
credential: {
|
||||||
|
create: true,
|
||||||
|
update: true,
|
||||||
|
},
|
||||||
|
})),
|
||||||
|
}));
|
||||||
|
|
||||||
|
const renderComponent = createComponentRenderer(CredentialEdit, {
|
||||||
|
pinia: createTestingPinia({
|
||||||
|
initialState: {
|
||||||
|
[STORES.UI]: {
|
||||||
|
modalsById: {
|
||||||
|
[CREDENTIAL_EDIT_MODAL_KEY]: { open: true },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
[STORES.SETTINGS]: {
|
||||||
|
settings: {
|
||||||
|
templates: {
|
||||||
|
host: '',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
describe('CredentialEdit', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
createAppModals();
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
cleanupAppModals();
|
||||||
|
vi.clearAllMocks();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('shows the save button when credentialId is null', async () => {
|
||||||
|
const { queryByTestId } = renderComponent({
|
||||||
|
props: {
|
||||||
|
isTesting: false,
|
||||||
|
isSaving: false,
|
||||||
|
hasUnsavedChanges: false,
|
||||||
|
modalName: CREDENTIAL_EDIT_MODAL_KEY,
|
||||||
|
mode: 'new',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
await retry(() => expect(queryByTestId('credential-save-button')).toBeInTheDocument());
|
||||||
|
});
|
||||||
|
|
||||||
|
test('hides the save button when credentialId exists and there are no unsaved changes', async () => {
|
||||||
|
const { queryByTestId } = renderComponent({
|
||||||
|
props: {
|
||||||
|
activeId: '123', // credentialId will be set to this value in edit mode
|
||||||
|
isTesting: false,
|
||||||
|
isSaving: false,
|
||||||
|
hasUnsavedChanges: false,
|
||||||
|
modalName: CREDENTIAL_EDIT_MODAL_KEY,
|
||||||
|
mode: 'edit',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
await retry(() => expect(queryByTestId('credential-save-button')).not.toBeInTheDocument());
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue