Skip to content

y471n/hijri-rn-date-picker

Repository files navigation

Hijri Calendar Date Picker for React Native

Introduction

This is a simple and easy-to-use Hijri calendar date picker for React Native. It is a cross-platform component that works on both iOS and Android. It is built using TypeScript and supports both TypeScript and JavaScript.

Features

  • Supports both iOS and Android.
  • Supports both TypeScript and JavaScript.
  • Supports both numeric and string month representation.
  • Supports both English and Arabic languages.
  • Supports custom styles.

Prerequisites

  • React Native >= 0.60.0
  • TypeScript >= 4.0.0

Installation

npm install react-native-hijri-date-picker

Usage

import * as React from 'react';

import { StyleSheet, Text, View } from 'react-native';
import {
  HijriRNDatePicker,
  type TDate,
} from 'react-native-hijri-date-picker';

export default function App() {
  const [date, setDate] = React.useState<TDate>({
    year: '',
    month: '',
    day: '',
  });

  const updateDate = (params: TDate) => {
    setDate((prevDate) => ({
      ...prevDate,
      ...params,
    }));
  };

  return (
    <View style={styles.container}>
      <HijriRNDatePicker
        updateDate={updateDate}
        numericMonth={false}
        labelLang="en"
        valueLang="ar"
        viewStyle={{ width: 300 }}
      />
      <Text style={styles.label}>{JSON.stringify(date)}</Text>
    </View>
  );
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    alignItems: 'center',
    justifyContent: 'center',
    width: '100%',
    height: 500,
    backgroundColor: '#f0f0f0',
  },
  label: {
    fontSize: 20,
    marginTop: 20,
  },
});

Screen Recording

iOS + Android

Hijri Date Picker in Action Hijri Date Picker in Action in Android

Contributing

See the contributing guide to learn how to contribute to the repository and the development workflow.

License

MIT


About

Hijri Date Picker for React native

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published