import * as React from 'react'; import { _ } from '@joplin/lib/locale'; import CommandService from '@joplin/lib/services/CommandService'; import { ChangeEvent, useCallback } from 'react'; import NoteToolbar from '../../NoteToolbar/NoteToolbar'; import { buildStyle } from '@joplin/lib/theme'; import time from '@joplin/lib/time'; import styled from 'styled-components'; const StyledRoot = styled.div` display: flex; flex-direction: row; align-items: center; padding-left: ${props => props.theme.editorPaddingLeft}px; @media (max-width: 800px) { flex-direction: column; align-items: flex-start; } `; const InfoGroup = styled.div` display: flex; flex-direction: row; align-items: center; @media (max-width: 800px) { border-top: 1px solid ${props => props.theme.dividerColor}; width: 100%; } `; interface Props { themeId: number; noteUserUpdatedTime: number; noteTitle: string; noteIsTodo: number; isProvisional: boolean; titleInputRef: React.RefObject; onTitleChange(event: ChangeEvent): void; disabled: boolean; } function styles_(props: Props) { return buildStyle(['NoteEditorTitleBar'], props.themeId, theme => { return { titleInput: { flex: 1, display: 'inline-block', paddingTop: 5, minHeight: 38, boxSizing: 'border-box', fontWeight: 'bold', paddingBottom: 5, paddingLeft: 0, paddingRight: 8, color: theme.textStyle.color, fontSize: Math.round(theme.textStyle.fontSize * 1.5), backgroundColor: theme.backgroundColor, border: 'none', width: '100%', }, titleDate: { ...theme.textStyle, color: theme.colorFaded, paddingLeft: 8, whiteSpace: 'nowrap', }, toolbarStyle: { marginBottom: 0, minWidth: 0, }, }; }); } export default function NoteTitleBar(props: Props) { const styles = styles_(props); const onTitleKeydown: React.KeyboardEventHandler = useCallback((event) => { const titleElement = event.currentTarget; const selectionAtEnd = titleElement.selectionEnd === titleElement.value.length; if ((event.key === 'ArrowDown' && selectionAtEnd) || event.key === 'Enter') { event.preventDefault(); const moveCursorToStart = event.key === 'ArrowDown'; void CommandService.instance().execute('focusElement', 'noteBody', { moveCursorToStart }); } }, []); function renderTitleBarDate() { return {time.formatMsToLocal(props.noteUserUpdatedTime)}; } function renderNoteToolbar() { return ; } return ( {renderTitleBarDate()} {renderNoteToolbar()} ); }