openreplay/frontend/app/components/Spots/SpotsList/EditItemModal.tsx
Andrey Babushkin fd5c0c9747
Add lokalisation (#3092)
* applied eslint

* add locales and lint the project

* removed error boundary

* updated locales

* fix min files

* fix locales
2025-03-06 17:43:15 +01:00

62 lines
1.6 KiB
TypeScript

import React from 'react';
import { Modal, Form, Input } from 'UI';
import { Button } from 'antd';
import { CloseOutlined } from '@ant-design/icons';
import { useTranslation } from 'react-i18next';
interface Props {
onSave: (newName: string) => void;
onClose: () => void;
itemName: string;
}
function EditItemModal(props: Props) {
const { t } = useTranslation();
const [name, setName] = React.useState(props.itemName);
const saveResult = () => {
props.onSave(name);
};
return (
<Modal open onClose={props.onClose}>
<Modal.Header className="flex items-center justify-between">
<div>{t('Edit Spot')}</div>
<Button
type="text"
name="close"
onClick={props.onClose}
icon={<CloseOutlined />}
/>
</Modal.Header>
<Modal.Content>
<Form onSubmit={saveResult}>
<label>{t('Title')}</label>
<Input
className=""
name="title"
value={name}
onChange={({ target: { value } }) => setName(value)}
placeholder={t('Title')}
maxLength={100}
autoFocus
/>
</Form>
</Modal.Content>
<Modal.Footer>
<div className="-mx-2 px-2">
<Button
type="primary"
onClick={saveResult}
className="float-left mr-2"
>
{t('Save')}
</Button>
<Button type="default" onClick={props.onClose}>
{t('Cancel')}
</Button>
</div>
</Modal.Footer>
</Modal>
);
}
export default EditItemModal;