{"id":24874633,"url":"https://github.com/dirheimerb/react-repick","last_synced_at":"2025-03-27T02:15:40.849Z","repository":{"id":241391849,"uuid":"806779992","full_name":"dirheimerb/react-repick","owner":"dirheimerb","description":null,"archived":false,"fork":false,"pushed_at":"2024-05-28T21:04:12.000Z","size":187,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2024-05-29T16:24:18.497Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/dirheimerb.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-05-27T22:18:46.000Z","updated_at":"2024-05-28T21:04:16.000Z","dependencies_parsed_at":"2024-05-28T05:12:18.160Z","dependency_job_id":"080e2acb-767d-490b-8426-0d58bbd31a03","html_url":"https://github.com/dirheimerb/react-repick","commit_stats":null,"previous_names":["dirheimerb/react-repick"],"tags_count":1,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dirheimerb%2Freact-repick","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dirheimerb%2Freact-repick/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dirheimerb%2Freact-repick/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dirheimerb%2Freact-repick/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/dirheimerb","download_url":"https://codeload.github.com/dirheimerb/react-repick/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":245767360,"owners_count":20668826,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-02-01T07:28:03.255Z","updated_at":"2025-03-27T02:15:40.833Z","avatar_url":"https://github.com/dirheimerb.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# React Pickers Library\n\nA collection of reusable picker components including a Color Picker, Date Picker, Time Picker, and Date Range Picker. These components are built using React, TypeScript, and Tailwind CSS.\n\n## Components\n\n- **[ColorPicker](#colorpicker)**: A custom color picker with predefined colors and a color wheel.\n- **[DatePicker](#datepicker)**: A date picker to select a single date.\n- **[TimePicker](#colorpicker)**: A time picker to select a time with AM/PM format.\n- **[DateRangePicker](#daterangepicker)**: A date range picker to select a start and end date.\n\n## Installation\n\nTo install the Pickers library, add it to your project using npm or yarn:\n\n```bash\nnpm install react-repick\n# or\nyarn add react-repick\n# or\npnpm add react-repick\n```\n\n## Usage\n\n### ColorPicker\n\nThe `ColorPicker` component allows users to select a color from a predefined set or a color wheel.\n\n```tsx\nimport React, { useState } from 'react';\nimport { ColorPicker } from 'react-repick';\n\nconst App: React.FC = () =\u003e {\n    const [color, setColor] = useState('#ff0000');\n    const [showColorPicker, setShowColorPicker] = useState(false);\n\n    return (\n        \u003cdiv\u003e\n            \u003cbutton onClick={() =\u003e setShowColorPicker(!showColorPicker)}\u003e\n                Toggle Color Picker\n            \u003c/button\u003e\n            \u003cColorPicker\n                color={color}\n                onColorChange={setColor}\n                show={showColorPicker}\n            /\u003e\n        \u003c/div\u003e\n    );\n};\n\nexport default App;\n```\n\n### DatePicker\n\nThe `DatePicker` component allows users to select a single date.\n\n```tsx\nimport React, { useState } from 'react';\nimport { DatePicker } from 'react-repick';\n\nconst App: React.FC = () =\u003e {\n    const [selectedDate, setSelectedDate] = useState(new Date());\n    const [showDatePicker, setShowDatePicker] = useState(false);\n\n    return (\n        \u003cdiv\u003e\n            \u003cbutton onClick={() =\u003e setShowDatePicker(!showDatePicker)}\u003e\n                Toggle Date Picker\n            \u003c/button\u003e\n            \u003cDatePicker\n                selectedDate={selectedDate}\n                onChange={setSelectedDate}\n                show={showDatePicker}\n                setIsOpen={setShowDatePicker}\n            /\u003e\n        \u003c/div\u003e\n    );\n};\n\nexport default App;\n```\n\n### TimePicker\n\nThe `TimePicker` component allows users to select a time with AM/PM format.\n\n```tsx\nimport React, { useState } from 'react';\nimport { TimePicker } from 'react-repick';\n\nconst App: React.FC = () =\u003e {\n    const [time, setTime] = useState('12:00 PM');\n    const [showTimePicker, setShowTimePicker] = useState(false);\n\n    return (\n        \u003cdiv\u003e\n            \u003cbutton onClick={() =\u003e setShowTimePicker(!showTimePicker)}\u003e\n                Toggle Time Picker\n            \u003c/button\u003e\n            \u003cTimePicker value={time} onChange={setTime} /\u003e\n        \u003c/div\u003e\n    );\n};\n\nexport default App;\n```\n\n### DateRangePicker\n\nThe `DateRangePicker` component allows users to select a start and end date.\n\n```tsx\nimport React, { useState } from 'react';\nimport { DateRangePicker } from 'react-repick';\n\nconst App: React.FC = () =\u003e {\n    const [startDate, setStartDate] = useState\u003cDate | null\u003e(null);\n    const [endDate, setEndDate] = useState\u003cDate | null\u003e(null);\n    const [showDateRangePicker, setShowDateRangePicker] = useState(false);\n\n    const handleDateChange = (start: Date | null, end: Date | null) =\u003e {\n        setStartDate(start);\n        setEndDate(end);\n    };\n\n    return (\n        \u003cdiv\u003e\n            \u003cbutton\n                onClick={() =\u003e setShowDateRangePicker(!showDateRangePicker)}\n            \u003e\n                Toggle Date Range Picker\n            \u003c/button\u003e\n            \u003cDateRangePicker\n                startDate={startDate}\n                endDate={endDate}\n                onChange={handleDateChange}\n                show={showDateRangePicker}\n                onShow={setShowDateRangePicker}\n                selectedStartDate={startDate}\n                selectedEndDate={endDate}\n            /\u003e\n        \u003c/div\u003e\n    );\n};\n\nexport default App;\n```\n\n## API\n\n### ColorPicker Props\n\nAPI:\n\n- `color`: The current selected color.\n- `onColorChange`: Callback function to handle color change.\n- `show`: Boolean to show or hide the color picker.\n\n### DatePicker Props\n\nAPI:\n\n- `selectedDate`: The currently selected date.\n- `onChange`: Callback function to handle date change.\n- `show`: Boolean to show or hide the date picker.\n- `setIsOpen`: Callback function to set the visibility of the date picker.\n\n## TimePicker Props\n\nAPI:\n\n- `value`: The currently selected time.\n- `onChange`: Callback function to handle time change.\n\n## DateRangePicker Props\n\nAPI:\n\n- `startDate`: The currently selected start date.\n- `endDate`: The currently selected end date.\n- `onChange`: Callback function to handle date range change.\n- `show`: Boolean to show or hide the date range picker.\n- `onShow`: Callback function to set the visibility of the date range picker.\n- `selectedStartDate`: The selected start date.\n- `selectedEndDate`: The selected end date.\n\n## License\n\nMIT License\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdirheimerb%2Freact-repick","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdirheimerb%2Freact-repick","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdirheimerb%2Freact-repick/lists"}