0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Wired up Unsplash integration to Admin X (#17727)

closes https://github.com/TryGhost/Product/issues/3741
refs https://github.com/TryGhost/Product/issues/3729

- my first commit with some Admin X stuff! 🕺🏻
- Wired up the API to the Unsplash integration modal

---

<!-- Leave the line below if you'd like GitHub Copilot to generate a
summary from your commit -->
<!--
copilot:summary
-->
### <samp>🤖 Generated by Copilot at da09dd4</samp>

This pull request adds a toggle to the Unsplash modal in the advanced
settings to enable or disable the Unsplash integration. It also updates
the settings API hook to include the Unsplash setting in the query.
This commit is contained in:
Ronald Langeveld 2023-08-16 13:22:30 +02:00 committed by GitHub
parent 3e683c2f06
commit 0da4653f3a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 51 additions and 1 deletions

View file

@ -3,19 +3,38 @@ import IntegrationHeader from './IntegrationHeader';
import Modal from '../../../../admin-x-ds/global/modal/Modal'; import Modal from '../../../../admin-x-ds/global/modal/Modal';
import NiceModal from '@ebay/nice-modal-react'; import NiceModal from '@ebay/nice-modal-react';
import Toggle from '../../../../admin-x-ds/global/form/Toggle'; import Toggle from '../../../../admin-x-ds/global/form/Toggle';
import useRouting from '../../../../hooks/useRouting';
import {ReactComponent as Icon} from '../../../../assets/icons/unsplash.svg'; import {ReactComponent as Icon} from '../../../../assets/icons/unsplash.svg';
import {Setting, getSettingValues, useEditSettings} from '../../../../api/settings';
import {useGlobalData} from '../../../providers/GlobalDataProvider';
const UnsplashModal = NiceModal.create(() => { const UnsplashModal = NiceModal.create(() => {
const {updateRoute} = useRouting();
const modal = NiceModal.useModal(); const modal = NiceModal.useModal();
const {settings} = useGlobalData();
const [unsplashEnabled] = getSettingValues<boolean>(settings, ['unsplash']);
const {mutateAsync: editSettings} = useEditSettings();
const handleToggleChange = async (e: React.ChangeEvent<HTMLInputElement>) => {
const updates: Setting[] = [
{key: 'unsplash', value: (e.target.checked)}
];
await editSettings(updates);
};
return ( return (
<Modal <Modal
afterClose={() => {
updateRoute('integrations');
}}
cancelLabel='' cancelLabel=''
okColor='black' okColor='black'
okLabel='Close' okLabel='Close'
testId='unsplash-modal'
title='' title=''
onOk={() => { onOk={() => {
modal.remove(); modal.remove();
updateRoute('integrations');
}} }}
> >
<IntegrationHeader <IntegrationHeader
@ -26,9 +45,11 @@ const UnsplashModal = NiceModal.create(() => {
<div className='mt-7'> <div className='mt-7'>
<Form marginBottom={false} grouped> <Form marginBottom={false} grouped>
<Toggle <Toggle
checked={unsplashEnabled}
direction='rtl' direction='rtl'
hint={<>Enable <a className='text-green' href="https://unsplash.com" rel="noopener noreferrer" target="_blank">Unsplash</a> image integration for your posts</>} hint={<>Enable <a className='text-green' href="https://unsplash.com" rel="noopener noreferrer" target="_blank">Unsplash</a> image integration for your posts</>}
label='Enable Unsplash' label='Enable Unsplash'
onChange={handleToggleChange}
/> />
</Form> </Form>
</div> </div>
@ -36,4 +57,4 @@ const UnsplashModal = NiceModal.create(() => {
); );
}); });
export default UnsplashModal; export default UnsplashModal;

View file

@ -0,0 +1,29 @@
import {expect, test} from '@playwright/test';
import {globalDataRequests, mockApi, updatedSettingsResponse} from '../../../utils/e2e';
test.describe('Unsplash integration', async () => {
test('Supports toggling unsplash integration', async ({page}) => {
const {lastApiRequests} = await mockApi({page, requests: {
...globalDataRequests,
editSettings: {method: 'PUT', path: '/settings/', response: updatedSettingsResponse([
{key: 'unsplash', value: false}
])}
}});
await page.goto('/');
const section = page.getByTestId('integrations');
const unsplashElement = section.getByText('Unsplash').last();
await unsplashElement.hover();
await page.getByRole('button', {name: 'Configure'}).click();
const unsplashModal = page.getByTestId('unsplash-modal');
const unsplashToggle = unsplashModal.getByRole('switch');
await unsplashToggle.click();
expect(lastApiRequests.editSettings?.body).toEqual({
settings: [
{key: 'unsplash', value: false}
]
});
});
});