1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-17 18:44:45 +02:00

132 lines
3.6 KiB
JavaScript
Raw Normal View History

const React = require('react'); const Component = React.Component;
const { connect } = require('react-redux');
const { ListView, Text, TouchableHighlight, View, StyleSheet } = require('react-native');
const { Log } = require('lib/log.js');
const { _ } = require('lib/locale.js');
const { Checkbox } = require('lib/components/checkbox.js');
const { reg } = require('lib/registry.js');
const { Note } = require('lib/models/note.js');
const { time } = require('lib/time-utils.js');
const { globalStyle, themeStyle } = require('lib/components/global-style.js');
2017-07-22 23:52:24 +01:00
class NoteItemComponent extends Component {
2017-08-01 17:59:01 +00:00
constructor() {
super();
this.styles_ = {};
}
2017-07-22 23:52:24 +01:00
noteItem_press(noteId) {
this.props.dispatch({
type: 'NAV_GO',
2017-07-22 23:52:24 +01:00
routeName: 'Note',
noteId: noteId,
});
}
2017-08-01 17:59:01 +00:00
styles() {
const theme = themeStyle(this.props.theme);
if (this.styles_[this.props.theme]) return this.styles_[this.props.theme];
this.styles_ = {};
let styles = {
listItem: {
flexDirection: 'row',
//height: 40,
borderBottomWidth: 1,
borderBottomColor: theme.dividerColor,
2017-08-19 23:59:08 +02:00
alignItems: 'flex-start',
2017-08-01 17:59:01 +00:00
paddingLeft: theme.marginLeft,
paddingRight: theme.marginRight,
paddingTop: theme.itemMarginTop,
paddingBottom: theme.itemMarginBottom,
backgroundColor: theme.backgroundColor,
},
listItemText: {
flex: 1,
color: theme.color,
fontSize: theme.fontSize,
},
};
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 17:59:01 +00:00
this.styles_[this.props.theme] = StyleSheet.create(styles);
return this.styles_[this.props.theme];
}
2017-07-25 19:36:52 +01:00
async todoCheckbox_change(checked) {
if (!this.props.note) return;
const newNote = {
id: this.props.note.id,
todo_completed: checked ? time.unixMs() : 0,
}
await Note.save(newNote);
}
onPress() {
if (!this.props.note) return;
this.props.dispatch({
type: 'NAV_GO',
routeName: 'Note',
noteId: this.props.note.id,
});
}
2017-07-22 23:52:24 +01:00
render() {
const note = this.props.note ? this.props.note : {};
2017-08-19 23:59:08 +02:00
const isTodo = !!Number(note.is_todo);
2017-07-22 23:52:24 +01:00
const onPress = this.props.onPress;
const onCheckboxChange = this.props.onCheckboxChange;
2017-08-01 17:59:01 +00:00
const theme = themeStyle(this.props.theme);
2017-07-22 23:52:24 +01:00
2017-08-19 23:59:08 +02:00
let checkboxStyle = !isTodo ? { display: 'none' } : { color: theme.color };
if (isTodo) {
checkboxStyle.paddingRight = 10;
checkboxStyle.paddingTop = theme.itemMarginTop;
checkboxStyle.paddingBottom = theme.itemMarginBottom;
checkboxStyle.paddingLeft = theme.marginLeft;
}
2017-07-22 23:52:24 +01: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;
const rootStyle = isTodo && checkboxChecked ? {opacity: 0.4} : {};
2017-07-23 19:26:50 +01:00
2017-07-22 23:52:24 +01:00
return (
2017-08-19 23:59:08 +02:00
<TouchableHighlight onPress={() => this.onPress()} underlayColor="#0066FF" style={rootStyle}>
2017-07-23 19:26:50 +01:00
<View style={ listItemStyle }>
2017-07-25 19:36:52 +01:00
<Checkbox
style={checkboxStyle}
checked={checkboxChecked}
onChange={(checked) => this.todoCheckbox_change(checked)}
/>
2017-08-19 23:59:08 +02:00
<Text style={listItemTextStyle}>{note.title}</Text>
2017-07-22 23:52:24 +01:00
</View>
</TouchableHighlight>
);
}
}
const NoteItem = connect(
(state) => {
2017-08-01 17:59:01 +00:00
return {
theme: state.settings.theme,
};
2017-07-22 23:52:24 +01:00
}
)(NoteItemComponent)
2017-11-03 00:13:17 +00:00
module.exports = { NoteItem };