Use nothingChanged in calendar and chart, too

This commit is contained in:
Julia Friesel
2018-10-15 14:07:47 +02:00
parent 124f6cfce7
commit e465b2a816
2 changed files with 6 additions and 3 deletions
+3 -2
View File
@@ -5,7 +5,7 @@ import { getOrCreateCycleDay, getBleedingDaysSortedByDate } from '../db'
import cycleModule from '../lib/cycle' import cycleModule from '../lib/cycle'
import {shadesOfRed} from '../styles/index' import {shadesOfRed} from '../styles/index'
import styles from '../styles/index' import styles from '../styles/index'
import nothingChanged from '../helpers/db-unchanged'
export default class CalendarView extends Component { export default class CalendarView extends Component {
constructor(props) { constructor(props) {
@@ -21,7 +21,8 @@ export default class CalendarView extends Component {
this.bleedingDays.addListener(this.setStateWithCalFormattedDays) this.bleedingDays.addListener(this.setStateWithCalFormattedDays)
} }
setStateWithCalFormattedDays = () => { setStateWithCalFormattedDays = (_, changes) => {
if (nothingChanged(changes)) return
const predictedMenses = cycleModule().getPredictedMenses() const predictedMenses = cycleModule().getPredictedMenses()
this.setState({ this.setState({
bleedingDaysInCalFormat: toCalFormat(this.bleedingDays), bleedingDaysInCalFormat: toCalFormat(this.bleedingDays),
+3 -1
View File
@@ -19,6 +19,7 @@ import MucusIcon from '../../assets/mucus'
import NoteIcon from '../../assets/note' import NoteIcon from '../../assets/note'
import PainIcon from '../../assets/pain' import PainIcon from '../../assets/pain'
import SexIcon from '../../assets/sex' import SexIcon from '../../assets/sex'
import nothingChanged from '../../helpers/db-unchanged'
export default class CycleChart extends Component { export default class CycleChart extends Component {
constructor(props) { constructor(props) {
@@ -48,7 +49,8 @@ export default class CycleChart extends Component {
if (this.state.chartHeight) return if (this.state.chartHeight) return
const height = nativeEvent.layout.height const height = nativeEvent.layout.height
this.setState({ chartHeight: height }) this.setState({ chartHeight: height })
this.reCalculateChartInfo = () => { this.reCalculateChartInfo = (_, changes) => {
if (nothingChanged(changes)) return
// how many symptoms need to be displayed on the chart's upper symptom row? // how many symptoms need to be displayed on the chart's upper symptom row?
this.symptomRowSymptoms = [ this.symptomRowSymptoms = [
'bleeding', 'bleeding',