2021-02-04 03:17:17 +00:00
|
|
|
import {isDesktop} from 'app/client/lib/browserInfo';
|
2023-09-21 16:57:58 +00:00
|
|
|
import {colors, theme} from 'app/client/ui2018/cssVars';
|
2021-02-04 03:17:17 +00:00
|
|
|
import {icon} from 'app/client/ui2018/icons';
|
|
|
|
import {IEditorCommandGroup} from 'app/client/widgets/NewBaseEditor';
|
|
|
|
import {dom, styled} from 'grainjs';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates Save/Cancel icon buttons to show next to the cell editor.
|
|
|
|
*/
|
|
|
|
export function createMobileButtons(commands: IEditorCommandGroup) {
|
|
|
|
// TODO A better check may be to detect a physical keyboard or touch support.
|
|
|
|
return isDesktop() ? null : [
|
2024-04-26 20:34:16 +00:00
|
|
|
cssCancelBtn(cssIconWrap(cssFinishIcon('CrossSmall')), dom.on('mousedown', commands.fieldEditCancel)),
|
|
|
|
cssSaveBtn(cssIconWrap(cssFinishIcon('Tick')), dom.on('mousedown', commands.fieldEditSaveHere)),
|
2021-02-04 03:17:17 +00:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getButtonMargins() {
|
|
|
|
return isDesktop() ? undefined : {left: 20, right: 20, top: 0, bottom: 0};
|
|
|
|
}
|
|
|
|
|
|
|
|
const cssFinishBtn = styled('div', `
|
|
|
|
height: 40px;
|
|
|
|
width: 40px;
|
|
|
|
padding: 8px;
|
|
|
|
position: absolute;
|
|
|
|
top: -8px;
|
2023-09-21 16:57:58 +00:00
|
|
|
--icon-color: ${theme.controlPrimaryFg};
|
2021-02-04 03:17:17 +00:00
|
|
|
`);
|
|
|
|
|
|
|
|
const cssCancelBtn = styled(cssFinishBtn, `
|
|
|
|
--icon-background-color: ${colors.error};
|
|
|
|
left: -40px;
|
|
|
|
`);
|
|
|
|
|
|
|
|
const cssSaveBtn = styled(cssFinishBtn, `
|
2023-09-21 16:57:58 +00:00
|
|
|
--icon-background-color: ${theme.controlPrimaryBg};
|
2021-02-04 03:17:17 +00:00
|
|
|
right: -40px;
|
|
|
|
`);
|
|
|
|
|
|
|
|
const cssIconWrap = styled('div', `
|
|
|
|
border-radius: 20px;
|
|
|
|
background-color: var(--icon-background-color);
|
|
|
|
height: 24px;
|
|
|
|
width: 24px;
|
|
|
|
`);
|
|
|
|
|
|
|
|
const cssFinishIcon = styled(icon, `
|
|
|
|
height: 24px;
|
|
|
|
width: 24px;
|
|
|
|
`);
|