mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
🐛 Fixed Admin navigation settings, pressing ENTER will now create a new navigation item (#21591)
Ref https://linear.app/ghost/issue/DES-73/enter-should-create-new-navigation-itemmove-to-next-field
This commit is contained in:
parent
c41bc5c237
commit
7f158c0e18
2 changed files with 25 additions and 4 deletions
|
@ -26,6 +26,7 @@ const NavigationEditForm: React.FC<{
|
|||
<Icon colorClass='text-grey-300 dark:text-grey-900 mt-1' name='add' size='sm' />
|
||||
<NavigationItemEditor
|
||||
action={<Button className='mx-2 mt-1 self-center rounded bg-green p-1' data-testid="add-button" icon="add" iconColorClass='text-white' size='sm' unstyled onClick={navigation.addItem} />}
|
||||
addItem={navigation.addItem}
|
||||
baseUrl={baseUrl}
|
||||
className="mt-1"
|
||||
clearError={key => navigation.clearError(navigation.newItem.id, key)}
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
import React, {ReactNode} from 'react';
|
||||
import clsx from 'clsx';
|
||||
import {EditableItem, NavigationItem, NavigationItemErrors} from '../../../../hooks/site/useNavigationEditor';
|
||||
import {TextField, URLTextField} from '@tryghost/admin-x-design-system';
|
||||
import {TextField, URLTextField, formatUrl} from '@tryghost/admin-x-design-system';
|
||||
|
||||
export type NavigationItemEditorProps = React.HTMLAttributes<HTMLDivElement> & {
|
||||
baseUrl: string;
|
||||
|
@ -12,9 +12,10 @@ export type NavigationItemEditorProps = React.HTMLAttributes<HTMLDivElement> & {
|
|||
unstyled?: boolean
|
||||
textFieldClasses?: string
|
||||
action?: ReactNode
|
||||
addItem?: () => void
|
||||
}
|
||||
|
||||
const NavigationItemEditor: React.FC<NavigationItemEditorProps> = ({baseUrl, item, updateItem, clearError, labelPlaceholder, unstyled, textFieldClasses, action, className, ...props}) => {
|
||||
const NavigationItemEditor: React.FC<NavigationItemEditorProps> = ({baseUrl, item, updateItem, addItem, clearError, labelPlaceholder, unstyled, textFieldClasses, action, className, ...props}) => {
|
||||
return (
|
||||
<div className={clsx('flex w-full items-start gap-3', className)} data-testid='navigation-item-editor' {...props}>
|
||||
<div className="flex flex-1 pt-1">
|
||||
|
@ -29,7 +30,14 @@ const NavigationItemEditor: React.FC<NavigationItemEditorProps> = ({baseUrl, ite
|
|||
value={item.label}
|
||||
hideTitle
|
||||
onChange={e => updateItem?.({label: e.target.value})}
|
||||
onKeyDown={() => clearError?.('label')}
|
||||
onKeyDown={(e) => {
|
||||
updateItem?.({label: (e.target as HTMLInputElement).value});
|
||||
if (e.key === 'Enter') {
|
||||
e.preventDefault();
|
||||
addItem?.();
|
||||
}
|
||||
!!item.errors.label && clearError?.('label');
|
||||
}}
|
||||
/>
|
||||
</div>
|
||||
<div className="flex flex-1 pt-1">
|
||||
|
@ -44,7 +52,19 @@ const NavigationItemEditor: React.FC<NavigationItemEditorProps> = ({baseUrl, ite
|
|||
value={item.url}
|
||||
hideTitle
|
||||
onChange={value => updateItem?.({url: value || ''})}
|
||||
onKeyDown={() => clearError?.('url')}
|
||||
onKeyDown={(e) => {
|
||||
const urls = formatUrl((e.target as HTMLInputElement).value, baseUrl, true);
|
||||
updateItem?.({url: urls.save || ''});
|
||||
}}
|
||||
onKeyUp={(e) => {
|
||||
if (e.key === 'Enter') {
|
||||
e.preventDefault();
|
||||
const urls = formatUrl((e.target as HTMLInputElement).value, baseUrl, true);
|
||||
updateItem?.({url: urls.save || ''});
|
||||
addItem?.();
|
||||
}
|
||||
!!item.errors.url && clearError?.('url');
|
||||
}}
|
||||
/>
|
||||
</div>
|
||||
{action}
|
||||
|
|
Loading…
Reference in a new issue