mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 12:28:01 +00:00
51 lines
1.0 KiB
TypeScript
51 lines
1.0 KiB
TypeScript
// Copyright 2017-2026 @pezkuwi/react-components authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { IconName } from '@fortawesome/fontawesome-svg-core';
|
|
|
|
import React from 'react';
|
|
|
|
import { colorLink } from './styles/theme.js';
|
|
import Icon from './Icon.js';
|
|
import { styled } from './styled.js';
|
|
|
|
interface Props {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
icon?: IconName;
|
|
onClick?: () => void;
|
|
}
|
|
|
|
function EditButton ({ children, className = '', icon = 'edit', onClick }: Props): React.ReactElement<Props> {
|
|
return (
|
|
<StyledDiv
|
|
className={`${className} ui--EditButton`}
|
|
onClick={onClick}
|
|
>
|
|
{children}
|
|
<span className='editSpan'>
|
|
<Icon
|
|
className='icon-button'
|
|
icon={icon}
|
|
/>
|
|
</span>
|
|
</StyledDiv>
|
|
);
|
|
}
|
|
|
|
const StyledDiv = styled.div`
|
|
cursor: pointer;
|
|
|
|
.ui--Icon.icon-button {
|
|
color: ${colorLink};
|
|
cursor: pointer;
|
|
margin: 0 0 0 0.5rem;
|
|
}
|
|
|
|
.editSpan {
|
|
white-space: nowrap;
|
|
}
|
|
`;
|
|
|
|
export default React.memo(EditButton);
|