1.0.1 • Published 5 years ago

react-native-stopwatch-timer-custom v1.0.1

Weekly downloads
4
License
ISC
Repository
github
Last release
5 years ago

React Native Stopwatch Timer

A React Native component that provides a stopwatch and timer that I've tweaked a little so you can hide the hours if you want.

Forked from michaeljstevens/react-native-stopwatch-timer

Instructions

import { Stopwatch, Timer } from 'react-native-stopwatch-timer-custom'

Options

Stopwatch and Timer Options

NameTypeDescriptionDefault
startbooleanstarts timer/stopwatch if true, stops if falsefalse
resetbooleanstops timer/stopwatch, resetsfalse
msecsbooleanincludes milliseconds in render of timefalse
optionsobjectdescribes style of rendered timer/stopwatchsee example

Stopwatch Options

NameTypeDescriptionDefault
lapsbooleanwill not count the laps of the stopped stopwatchfalse
getTimefunctionget the formatted value on each tick(time) => console.log(time)

Timer Options

NameTypeDescriptionDefault
totalDurationIntegernumber of milliseconds to set timer for0
handleFinishfunctionfunction to perform when timer completes() => alert("Timer Finished")
getTimefunctionget the formatted value on each tick(time) => console.log(time)
hoursbooleanshow the hours0

Example

import React, { Component } from 'react';
import { AppRegistry, StyleSheet,Text,View, TouchableHighlight } from 'react-native';
import { Stopwatch, Timer } from 'react-native-stopwatch-timer';

class TestApp extends Component {
  constructor(props) {
    super(props);
    this.state = {
      timerStart: false,
      stopwatchStart: false,
      totalDuration: 90000,
      timerReset: false,
      stopwatchReset: false,
    };
    this.toggleTimer = this.toggleTimer.bind(this);
    this.resetTimer = this.resetTimer.bind(this);
    this.toggleStopwatch = this.toggleStopwatch.bind(this);
    this.resetStopwatch = this.resetStopwatch.bind(this);
  }

  toggleTimer() {
    this.setState({timerStart: !this.state.timerStart, timerReset: false});
  }

  resetTimer() {
    this.setState({timerStart: false, timerReset: true});
  }

  toggleStopwatch() {
    this.setState({stopwatchStart: !this.state.stopwatchStart, stopwatchReset: false});
  }

  resetStopwatch() {
    this.setState({stopwatchStart: false, stopwatchReset: true});
  }
  
  getFormattedTime(time) {
      this.currentTime = time;
  };

  render() {
    return (
      <View>
        <Stopwatch laps msecs start={this.state.stopwatchStart}
          reset={this.state.stopwatchReset}
          options={options}
          getTime={this.getFormattedTime} />
        <TouchableHighlight onPress={this.toggleStopwatch}>
          <Text style={{fontSize: 30}}>{!this.state.stopwatchStart ? "Start" : "Stop"}</Text>
        </TouchableHighlight>
        <TouchableHighlight onPress={this.resetStopwatch}>
          <Text style={{fontSize: 30}}>Reset</Text>
        </TouchableHighlight>
        <Timer totalDuration={this.state.totalDuration} msecs start={this.state.timerStart}
          reset={this.state.timerReset}
          options={options}
          handleFinish={handleTimerComplete}
          getTime={this.getFormattedTime} />
        <TouchableHighlight onPress={this.toggleTimer}>
          <Text style={{fontSize: 30}}>{!this.state.timerStart ? "Start" : "Stop"}</Text>
        </TouchableHighlight>
        <TouchableHighlight onPress={this.resetTimer}>
          <Text style={{fontSize: 30}}>Reset</Text>
        </TouchableHighlight>
      </View>
    );
  }
}

const handleTimerComplete = () => alert("custom completion function");

const options = {
  container: {
    backgroundColor: '#000',
    padding: 5,
    borderRadius: 5,
    width: 220,
  },
  text: {
    fontSize: 30,
    color: '#FFF',
    marginLeft: 7,
  }
};

AppRegistry.registerComponent('TestApp', () => TestApp);