1.0.6 • Published 9 months ago

persian-react-calender v1.0.6

Weekly downloads
-
License
MIT
Repository
github
Last release
9 months ago

miminal and fully customizable calender

persian calender overview

installation :

npm i persian-react-calender

usage :

typescript users :

import type { CSSProperties } from "react";
import { Calender } from "persian-react-calender";
import { DayColumn, weekColumn, Header } from "persian-react-calender/types";

const styles: CSSProperties = {
  width: "80px",
  height: "50px",
  display: "flex",
  justifyContent: "center",
  alignItems: "center",
  border: "1px solid",
  margin: "5px",
  borderRadius: "10px",
  backgroundColor: "#38598b",
  color: "black",
};

const dayNumberStyle: CSSProperties = {
  ...styles,
  backgroundColor: "#a2a8d3",
};

const HeaderStyle: CSSProperties = {
  display: "flex",
  justifyContent: "space-between",
  width: "100%",
};

const WeekColumn: weekColumn = ({ name }) => {
  return <div style={styles}>{name}</div>;
};

const DayColumn: DayColumn = ({ dayNumber, month, year, currentDate }) => {
  return (
    <div
      style={{
        ...dayNumberStyle,
        backgroundColor: currentDate ? "#e84a5f" : "#a2a8d3",
      }}
      onClick={() => console.log({ dayNumber, month, year })}
    >
      {dayNumber}
    </div>
  );
};

const Header: Header = ({ month, year, prevHandle, nextHandle }) => {
  return (
    <div style={HeaderStyle}>
      <button onClick={nextHandle}>Next</button>
      <div>
        <b>{year}</b> {month}
      </div>
      <button onClick={prevHandle}>Prev</button>
    </div>
  );
};

function App() {
  return (
    <>
      <Calender WeekColumn={WeekColumn} DayColumn={DayColumn} Header={Header} />
    </>
  );
}

export default App;

javascript users :

import { Calender } from "persian-react-calender";

const styles = {
  width: "80px",
  height: "50px",
  display: "flex",
  justifyContent: "center",
  alignItems: "center",
  border: "1px solid",
  margin: "5px",
  borderRadius: "10px",
  backgroundColor: "#38598b",
  color: "black",
};

const dayNumberStyle = {
  ...styles,
  backgroundColor: "#a2a8d3",
};

const HeaderStyle = {
  display: "flex",
  justifyContent: "space-between",
  width: "100%",
};

const WeekColumn = ({ name }) => {
  return <div style={styles}>{name}</div>;
};

const DayColumn = ({ dayNumber, month, year, currentDate }) => {
  return (
    <div
      style={{
        ...dayNumberStyle,
        backgroundColor: currentDate ? "#e84a5f" : "#a2a8d3",
      }}
      onClick={() => console.log({ dayNumber, month, year })}
    >
      {dayNumber}
    </div>
  );
};

const Header = ({ month, year, prevHandle, nextHandle }) => {
  return (
    <div style={HeaderStyle}>
      <button onClick={nextHandle}>Next</button>
      <div>
        <b>{year}</b> {month}
      </div>
      <button onClick={prevHandle}>Prev</button>
    </div>
  );
};

function App() {
  return (
    <>
      <Calender WeekColumn={WeekColumn} DayColumn={DayColumn} Header={Header} />
    </>
  );
}

export default App;
1.0.6

9 months ago

1.0.2

9 months ago

1.0.1

9 months ago

1.0.0

12 months ago

1.0.5

12 months ago

1.0.4

12 months ago

1.0.3

12 months ago