1
0
mirror of https://github.com/laurent22/joplin.git synced 2024-12-30 10:36:35 +02:00
joplin/packages/app-mobile/components/NotesBarListItem.tsx

133 lines
3.0 KiB
TypeScript
Raw Normal View History

2022-09-09 16:06:03 +02:00
import * as React from 'react';
import Checkbox from './checkbox';
import Note from '@joplin/lib/models/Note';
import { View, TouchableOpacity, Text, StyleSheet } from 'react-native';
import { Style } from './global-style';
import { State } from '@joplin/lib/reducer';
const { connect } = require('react-redux');
const { _ } = require('@joplin/lib/locale');
import shim from '@joplin/lib/shim';
import { themeStyle } from './global-style';
interface NoteListProps {
note: any;
themeId: number;
todoCheckbox_change: (checked: boolean)=> void;
dispatch: Function;
selectedNoteId: string;
}
const NotesBarListItemComponent = function(props: NoteListProps) {
const note = props.note ?? {};
const isTodo = !!Number(note.is_todo);
const styles = (): Style => {
const themeId = props.themeId;
const theme = themeStyle(themeId);
const styles: Style = {
horizontalFlex: {
flexDirection: 'row',
},
padding: {
paddingLeft: theme.marginLeft,
paddingRight: theme.marginRight,
paddingTop: 12,
paddingBottom: 12,
},
button: {
height: 42,
width: 42,
backgroundColor: theme.color4,
alignItems: 'center',
justifyContent: 'center',
borderRadius: 4,
flex: 0.5,
marginLeft: 8,
},
itemText: {
fontSize: theme.fontSize,
color: theme.color,
paddingTop: 12,
paddingBottom: 12,
},
checkbox: {
paddingRight: 10,
paddingLeft: theme.marginLeft,
paddingTop: 12,
paddingBottom: 12,
color: theme.color,
},
selectedItem: props.selectedNoteId === note.id ? {
backgroundColor: theme.dividerColor,
} : null,
item: {
borderBottomWidth: 1,
borderColor: theme.dividerColor,
},
};
return StyleSheet.create(styles);
};
const onTodoCheckboxChange = async (checked: boolean) => {
await props.todoCheckbox_change(checked);
};
const onPress = async () => {
if (!note) return;
if (note.encryption_applied) return;
props.dispatch({
type: 'NAV_BACK',
});
shim.setTimeout(() => {
props.dispatch({
type: 'NAV_GO',
routeName: 'Note',
noteId: note.id,
});
}, 5);
};
const noteTitle = Note.displayTitle(note);
let item;
if (isTodo) {
item = (
<View>
<TouchableOpacity style={[styles().horizontalFlex, styles().item, styles().selectedItem]} onPress={onPress}>
<Checkbox
style={styles().checkbox}
checked={!!Number(note.todo_completed)}
onChange={(checked) => onTodoCheckboxChange(checked)}
accessibilityLabel={_('to-do: %s', noteTitle)}
/>
<Text style={styles().itemText}>{noteTitle}</Text>
</TouchableOpacity>
</View>
);
} else {
item = (
<View>
<TouchableOpacity onPress={onPress} style={[styles().selectedItem, styles().item]}>
<Text style={[styles().itemText, styles().padding]}>{noteTitle}</Text>
</TouchableOpacity>
</View>
);
}
return item;
};
const NotesBarListItem = connect((state: State) => {
return {
themeId: state.settings.theme,
selectedNoteId: state.selectedNoteIds[0],
};
})(NotesBarListItemComponent);
export default NotesBarListItem;