Skip to content
This repository was archived by the owner on Jun 3, 2024. It is now read-only.

Setting Locale in DatePicker Components #727

Open
wants to merge 1 commit into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 11 additions & 0 deletions src/components/DatePickerRange.react.js
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,16 @@ DatePickerRange.propTypes = {
* session: window.sessionStorage, data is cleared once the browser quit.
*/
persistence_type: PropTypes.oneOf(['local', 'session', 'memory']),

/**
* The language used to set locale globally.
* Pass the default parameter `auto` to use the browser's default language.
* For example: `language='en'` sets the default locale of this component globally to English.
* Important: The same locale needs to be set for ALL DatePicker components located on the same page!
* This limitation is caused by the fact that locale is being set GLOBALLY.
* See https://momentjs.com/docs/#/i18n/ for details.
*/
language: PropTypes.string,
};

DatePickerRange.defaultProps = {
Expand All @@ -278,6 +288,7 @@ DatePickerRange.defaultProps = {
updatemode: 'singledate',
persisted_props: ['start_date', 'end_date'],
persistence_type: 'local',
language: 'auto',
};

export const propTypes = DatePickerRange.propTypes;
Expand Down
11 changes: 11 additions & 0 deletions src/components/DatePickerSingle.react.js
Original file line number Diff line number Diff line change
Expand Up @@ -218,6 +218,16 @@ DatePickerSingle.propTypes = {
* session: window.sessionStorage, data is cleared once the browser quit.
*/
persistence_type: PropTypes.oneOf(['local', 'session', 'memory']),

/**
* The language used to set locale globally.
* Pass the default parameter `auto` to use the browser's default language.
* For example: `language='en'` sets the default locale of this component globally to English.
* Important: The same locale needs to be set for ALL DatePicker components located on the same page!
* This limitation is caused by the fact that locale is being set GLOBALLY.
* See https://momentjs.com/docs/#/i18n/ for details.
*/
language: PropTypes.string,
};

DatePickerSingle.defaultProps = {
Expand All @@ -235,6 +245,7 @@ DatePickerSingle.defaultProps = {
disabled: false,
persisted_props: ['date'],
persistence_type: 'local',
language: 'auto',
};

export const propTypes = DatePickerSingle.propTypes;
Expand Down
3 changes: 2 additions & 1 deletion src/fragments/DatePickerRange.react.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,12 @@ import React, {Component} from 'react';
import uniqid from 'uniqid';

import {propTypes, defaultProps} from '../components/DatePickerRange.react';
import convertToMoment from '../utils/convertToMoment';
import convertToMoment, {setLocaleGlobally} from '../utils/convertToMoment';

export default class DatePickerRange extends Component {
constructor(props) {
super(props);
setLocaleGlobally(this.props.language);
this.propsToState = this.propsToState.bind(this);
this.onDatesChange = this.onDatesChange.bind(this);
this.isOutsideRange = this.isOutsideRange.bind(this);
Expand Down
7 changes: 4 additions & 3 deletions src/fragments/DatePickerSingle.react.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,12 @@ import moment from 'moment';
import React, {Component} from 'react';

import {propTypes, defaultProps} from '../components/DatePickerSingle.react';
import convertToMoment from '../utils/convertToMoment';
import convertToMoment, {setLocaleGlobally} from '../utils/convertToMoment';

export default class DatePickerSingle extends Component {
constructor() {
super();
constructor(props) {
super(props);
setLocaleGlobally(this.props.language);
this.isOutsideRange = this.isOutsideRange.bind(this);
this.onDateChange = this.onDateChange.bind(this);
this.state = {focused: false};
Expand Down
14 changes: 14 additions & 0 deletions src/utils/convertToMoment.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,20 @@
import moment from 'moment';
import {has} from 'ramda';

/**
* Set locale globally based on `language` parameter.
* Pass `language` parameter `auto` to use the browser's default language.
* See https://momentjs.com/docs/#/i18n/ for details.
*
* @param {string} language
*/
export const setLocaleGlobally = (language) => {
if (language === "auto") {
language = window.navigator.language || 'en';
}
moment.locale(language);
};

export default (newProps, momentProps) => {
const dest = {};

Expand Down