1
0
mirror of https://github.com/laurent22/joplin.git synced 2024-12-12 08:54:00 +02:00
joplin/packages/app-mobile/components/note-item.js

163 lines
4.7 KiB
JavaScript
Raw Normal View History

2019-07-29 15:43:53 +02:00
const React = require('react');
const Component = React.Component;
const { connect } = require('react-redux');
2019-07-29 15:58:33 +02:00
const { Text, TouchableOpacity, View, StyleSheet } = require('react-native');
const { Checkbox } = require('./checkbox.js');
const Note = require('@joplin/lib/models/Note').default;
const time = require('@joplin/lib/time').default;
2020-11-05 18:58:23 +02:00
const { themeStyle } = require('./global-style.js');
const { _ } = require('@joplin/lib/locale');
2017-07-23 00:52:24 +02:00
class NoteItemComponent extends Component {
2017-08-01 19:59:01 +02:00
constructor() {
super();
this.styles_ = {};
}
2017-07-23 00:52:24 +02:00
noteItem_press(noteId) {
this.props.dispatch({
type: 'NAV_GO',
routeName: 'Note',
2017-07-23 00:52:24 +02:00
noteId: noteId,
});
}
2017-08-01 19:59:01 +02:00
styles() {
2020-09-15 15:01:07 +02:00
const theme = themeStyle(this.props.themeId);
2017-08-01 19:59:01 +02:00
2020-09-15 15:01:07 +02:00
if (this.styles_[this.props.themeId]) return this.styles_[this.props.themeId];
2017-08-01 19:59:01 +02:00
this.styles_ = {};
const styles = {
2017-08-01 19:59:01 +02:00
listItem: {
flexDirection: 'row',
2019-10-09 21:35:13 +02:00
// height: 40,
2017-08-01 19:59:01 +02:00
borderBottomWidth: 1,
borderBottomColor: theme.dividerColor,
alignItems: 'flex-start',
2017-08-01 19:59:01 +02:00
paddingLeft: theme.marginLeft,
paddingRight: theme.marginRight,
paddingTop: theme.itemMarginTop,
paddingBottom: theme.itemMarginBottom,
2019-10-09 21:35:13 +02:00
// backgroundColor: theme.backgroundColor,
2017-08-01 19:59:01 +02:00
},
listItemText: {
flex: 1,
color: theme.color,
fontSize: theme.fontSize,
},
selectionWrapper: {
backgroundColor: theme.backgroundColor,
},
2017-08-01 19:59:01 +02:00
};
2017-08-19 23:59:08 +02:00
styles.listItemWithCheckbox = Object.assign({}, styles.listItem);
delete styles.listItemWithCheckbox.paddingTop;
delete styles.listItemWithCheckbox.paddingBottom;
delete styles.listItemWithCheckbox.paddingLeft;
styles.listItemTextWithCheckbox = Object.assign({}, styles.listItemText);
styles.listItemTextWithCheckbox.marginTop = styles.listItem.paddingTop - 1;
styles.listItemTextWithCheckbox.marginBottom = styles.listItem.paddingBottom;
2017-08-01 19:59:01 +02:00
styles.selectionWrapperSelected = Object.assign({}, styles.selectionWrapper);
styles.selectionWrapperSelected.backgroundColor = theme.selectedColor;
2020-09-15 15:01:07 +02:00
this.styles_[this.props.themeId] = StyleSheet.create(styles);
return this.styles_[this.props.themeId];
2017-08-01 19:59:01 +02:00
}
2019-07-29 15:43:53 +02:00
async todoCheckbox_change(checked) {
2017-07-25 20:36:52 +02:00
if (!this.props.note) return;
const newNote = {
id: this.props.note.id,
todo_completed: checked ? time.unixMs() : 0,
2019-07-29 15:43:53 +02:00
};
2017-07-25 20:36:52 +02:00
await Note.save(newNote);
}
onPress() {
if (!this.props.note) return;
2019-07-29 15:43:53 +02:00
if (this.props.note.encryption_applied) return;
2017-07-25 20:36:52 +02:00
if (this.props.noteSelectionEnabled) {
this.props.dispatch({
type: 'NOTE_SELECTION_TOGGLE',
id: this.props.note.id,
});
} else {
this.props.dispatch({
type: 'NAV_GO',
routeName: 'Note',
noteId: this.props.note.id,
});
}
}
onLongPress() {
if (!this.props.note) return;
2017-07-25 20:36:52 +02:00
this.props.dispatch({
type: this.props.noteSelectionEnabled ? 'NOTE_SELECTION_TOGGLE' : 'NOTE_SELECTION_START',
id: this.props.note.id,
2017-07-25 20:36:52 +02:00
});
}
2017-07-23 00:52:24 +02:00
render() {
const note = this.props.note ? this.props.note : {};
2017-08-19 23:59:08 +02:00
const isTodo = !!Number(note.is_todo);
2019-07-29 15:58:33 +02:00
2020-09-15 15:01:07 +02:00
const theme = themeStyle(this.props.themeId);
2017-07-23 00:52:24 +02:00
2017-11-19 02:03:42 +02:00
// IOS: display: none crashes the app
const checkboxStyle = !isTodo ? { display: 'none' } : { color: theme.color };
2017-08-19 23:59:08 +02:00
if (isTodo) {
checkboxStyle.paddingRight = 10;
checkboxStyle.paddingTop = theme.itemMarginTop;
checkboxStyle.paddingBottom = theme.itemMarginBottom;
checkboxStyle.paddingLeft = theme.marginLeft;
}
2017-07-23 00:52:24 +02:00
const checkboxChecked = !!Number(note.todo_completed);
2017-08-19 23:59:08 +02:00
const listItemStyle = isTodo ? this.styles().listItemWithCheckbox : this.styles().listItem;
const listItemTextStyle = isTodo ? this.styles().listItemTextWithCheckbox : this.styles().listItemText;
2019-07-29 15:43:53 +02:00
const opacityStyle = isTodo && checkboxChecked ? { opacity: 0.4 } : {};
const isSelected = this.props.noteSelectionEnabled && this.props.selectedNoteIds.indexOf(note.id) >= 0;
const selectionWrapperStyle = isSelected ? this.styles().selectionWrapperSelected : this.styles().selectionWrapper;
2017-07-23 20:26:50 +02:00
const noteTitle = Note.displayTitle(note);
2017-07-23 00:52:24 +02:00
return (
2019-07-29 15:43:53 +02:00
<TouchableOpacity onPress={() => this.onPress()} onLongPress={() => this.onLongPress()} activeOpacity={0.5}>
<View style={selectionWrapperStyle}>
<View style={opacityStyle}>
<View style={listItemStyle}>
<Checkbox
style={checkboxStyle}
checked={checkboxChecked}
onChange={checked => this.todoCheckbox_change(checked)}
accessibilityLabel={_('to-do: %s', noteTitle)}
/>
<Text style={listItemTextStyle}>{noteTitle}</Text>
</View>
</View>
2017-07-23 00:52:24 +02:00
</View>
</TouchableOpacity>
2017-07-23 00:52:24 +02:00
);
}
}
const NoteItem = connect(state => {
2019-07-29 15:43:53 +02:00
return {
2020-09-15 15:01:07 +02:00
themeId: state.settings.theme,
2019-07-29 15:43:53 +02:00
noteSelectionEnabled: state.noteSelectionEnabled,
selectedNoteIds: state.selectedNoteIds,
};
})(NoteItemComponent);
2017-07-23 00:52:24 +02:00
2019-07-29 15:43:53 +02:00
module.exports = { NoteItem };