react-native-bpk-component-calendar v6.0.0
react-native-bpk-component-calendar
Backpack React Native calendar component.
Installation
npm install react-native-bpk-component-calendar --save-devBecause this package ships with native code, it is also necessary to add some native dependencies to your RN project:
Android
Add the following configurations to gradle:
- Define the react-native-bpk-component-calendarproject in yoursettings.gradlefile:
    include ':react-native-bpk-component-calendar'
    project(':react-native-bpk-component-calendar').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-bpk-component-calendar/src/android')- Add react-native-bpk-component-calendaras a dependency in your app/modulebuild.gradlefile:
    dependencies {
      implementation project(':react-native-bpk-component-calendar')
    }If you have defined project-wide properties in your root build.gradle, this library will detect the presence of the following properties:
ext {
    compileSdkVersion   = 28
    targetSdkVersion    = 28
    minSdkVersion       = 21
    buildToolsVersion   = "28.0.3"
}If you haven't or are using the pre compiled version bellow, it will use the values shown above.
Pre compiled version
Alternatively, the pre compiled version is available on Skyscanner's internal Artifactory. Make sure you have the infrastructure-maven registry configured and are logged in, then add the following dependency to your build.gradle file:
    dependencies {
      implementation 'net.skyscanner.backpack:react-native-bpk-component-calendar:<version>'
    }Note: The version should be the same used for the npm package.
Importing the bridge package
After you have installed the lib, import the CalendarPackage() in your react application:
import net.skyscanner.backpack.reactnative.calendar.CalendarPackage
....
@Override
protected List<ReactPackage> getPackages() {
    return Arrays.<ReactPackage>asList(
            new MainReactPackage(),
            new CalendarPackage()
    );
}iOS
Add a dependency to your Podfile using the path to the NPM package as follows:
  pod 'react-native-bpk-component-calendar', path: '../node_modules/react-native-bpk-component-calendar'Note that the react-native-bpk-component-calendar depends on Backpack. If your Podfile also depends on this directly, both dependencies must be for compatible semver versions.
Time Zones
BpkCalendar uses dates at the UTC midnight boundary exclusively for selected dates and expects that format for minDate and maxDate. If BpkCalendar is used with dates that are not UTC it will behave in undefined ways and most likely not work.
To create dates to be used with the component we recommend the following
// Min date of the calendar at 2019-01-02
const minDate = new Date(Date.UTC(2019, 0, 2));
// Dates can also be provided as timestamps
const minDate = Date.UTC(2019, 0, 2);To format the dates for display use
const locale = 'en-gb';
const formattedDate = date.toLocaleDateString(locale, { timeZone: 'UTC' });Usage
import React, { Component } from 'react';
import { StyleSheet, View } from 'react-native';
import { spacingBase } from 'bpk-tokens/tokens/base.react.native';
import BpkCalendar, { SELECTION_TYPES } from 'react-native-bpk-component-calendar';
class App extends Component {
  constructor(props) {
    super(props);
    this.state = { selectedDates: [] };
  }
  handleNewDates = newDates => {
    this.setState({
      selectedDates: newDates,
    });
  };
  render() {
    const { selectionType, onChangeSelectedDates, ...rest } = this.props;
    return (
      <BpkCalendar
        locale={'en-gb'}
        selectionType={SELECTION_TYPES.range}
        selectedDates={this.state.selectedDates}
        onChangeSelectedDates={this.handleNewDates}
        minDate={Date.UTC(2019, 0, 2)}
        maxDate={Date.UTC(2019, 11, 31)}
      />
    );
  }
}Props
BpkCalendar
| Property | PropType | Required | Default Value | 
|---|---|---|---|
| locale | string | true | - | 
| colorBuckets | arrayOf(ColorBucket) | false | undefined | 
| disabledDates | DateMatcher | false | null | 
| maxDate | oneOf(Date, number) | false | today + 1 year | 
| minDate | oneOf(Date, number) | false | today | 
| onChangeSelectedDates | function | false | null | 
| selectedDates | arrayOf(Date, number) | false | [] | 
| selectionType | oneOf(SELECTION_TYPES) | false | SELECTION_TYPES.single | 
selectedDates
- When selectionTypeisSELECTION_TYPES.single, you should only include zero or one entries in theselectedDatesarray.
- When selectionTypeisSELECTION_TYPES.range, you should only include zero, one or two entries in theselectedDatesarray.
API
Table of Contents
DateMatchers
range
Creates a range matcher to be used in BpkCalendar.
A range matcher will match any date in between start and end date, inclusive.
Parameters
Examples
<BpkCalendar
 disabledDates={DateMatchers.range(start, end)}
/>Returns DateMatcher a range date matcher.
after
Creates an after matcher to be used in BpkCalendar.
An after matcher will match all dates after the provided date.
Parameters
Examples
<BpkCalendar
 disabledDates={DateMatchers.after(date)}
/>Returns DateMatcher an after date matcher.
before
Creates a before matcher to be used in BpkCalendar.
A before matcher will match all dates before the provided date.
Parameters
Examples
<BpkCalendar
 disabledDates={DateMatchers.before(date)}
/>Returns DateMatcher an before date matcher.
any
Creates an any matcher to be used in BpkCalendar.
An any matcher will match if the date is equal to any of the dates provided.
Parameters
Examples
<BpkCalendar
 disabledDates={DateMatchers.any(...listOfDates)}
/>Returns DateMatcher an any date matcher.
colorBucket
Creates a new color bucket to be used in BpkCalendar.
A color bucket is used to define custom colours for calendar days.
NOTE: Your are responsible for ensuring multiple color buckets don't overlap, in case they do the last one applied (last in the list) will take precedence.
Parameters
- colorstring The background color
- daysDateMatcher The days in this bucket
- textStyleTextStyle? The text style. Valid values are- lightor- dark. Changes how the text looks based on the background color, where light or dark refers to the background colour. (optional, default- undefined)
Examples
<BpkCalendar
 colorBuckets={[
   colorBucket(colorPanjin, DateMatchers.range(startOfSummer, endOfSummer)),
   colorBucket(colorSagano, DateMatchers.after(endOfSummer))
 ]}
/>Returns ColorBucket A new color bucket
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago