Skip to content

Commit

Permalink
docs: document API for supported calendars, currency and countdown event
Browse files Browse the repository at this point in the history
  • Loading branch information
shivarm committed Oct 18, 2024
1 parent fb201d3 commit 7534c27
Show file tree
Hide file tree
Showing 9 changed files with 245 additions and 10 deletions.
12 changes: 6 additions & 6 deletions api/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions api/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "api",
"version": "1.3.2",
"version": "1.4.3",
"main": "./src/index.ts",
"scripts": {
"start": "node dist/index.js",
Expand All @@ -17,7 +17,7 @@
"dependencies": {
"dotenv": "^16.4.5",
"express": "^4.21.1",
"world-clockify": "^1.3.3"
"world-clockify": "^1.4.3"
},
"devDependencies": {
"@types/express": "^5.0.0",
Expand Down
58 changes: 57 additions & 1 deletion api/src/controllers/timezone.controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@ import {
convertTimeZone,
calculateDuration,
formatDateInTimeZone,
getSupportedCrrency,
getSupportedCalendar,
formatDateForLocale,
getCountdownToEvent,
} from 'world-clockify';

export const fetchCurrentTimeInZone = async (req: Request, res: Response) => {
Expand Down Expand Up @@ -34,6 +38,26 @@ export const fetchSupportedTimezones = async (_req: Request, res: Response) => {
}
};

export const fetchSupportedCrrency = async (req: Request, res: Response) => {
try {
const crrencies = getSupportedCrrency();
res.status(200).json({ crrencies });
} catch (error) {
console.error('Error fetching supported currencies:', error);
res.status(500).json({ message: 'Internal server error' });
}
};

export const fetchSupportedCalendar = async (req: Request, res: Response) => {
try {
const calendar = getSupportedCalendar();
res.status(200).json({ calendar });
} catch (error) {
console.error('Error fetching supported calendar:', error);
res.status(500).json({ message: 'Internal server error' });
}
};

export const fetchConvertedTime = async (req: Request, res: Response) => {
const { date, fromZone, toZone } = req.query;

Expand Down Expand Up @@ -96,7 +120,7 @@ export const formatDateInTimezone = (req: Request, res: Response) => {
typeof format === 'string'
) {
const formattedDate = formatDateInTimeZone(date, fromZone, toZone, format);
res.json({ formattedDate });
res.status(200).json({ formattedDate });
} else {
res.status(400).json({ message: 'Invalid parameters' });
}
Expand All @@ -105,3 +129,35 @@ export const formatDateInTimezone = (req: Request, res: Response) => {
res.status(500).json({ message: 'Internal server error' });
}
};

export const formatDateLocale = async (req: Request, res: Response) => {
const { dateStr, locale, timezone } = req.query;

try {
if (typeof dateStr === 'string' && typeof locale === 'string' && typeof timezone === 'string') {
const formatDateLocale = formatDateForLocale(dateStr, locale, timezone);
res.status(200).json({ formatDateLocale });
} else {
res.status(400).json({ message: 'Invalid parameters' });
}
} catch (error) {
console.error('Error formatting date for local:', error);
res.status(500).json({ message: 'Internal server error' });
}
};

export const countDownToEvent = async (req: Request, res: Response) => {
const { eventDate, eventTimezone } = req.query;

try {
if (typeof eventDate === 'string' && typeof eventTimezone === 'string') {
const countdown = getCountdownToEvent(eventDate, eventTimezone);
res.status(200).json({ countdown });
} else {
res.status(400).json({ message: 'Invalid parameters' });
}
} catch (error) {
console.error('Error getting countdown to event:', error);
res.status(500).json({ message: 'Internal server error' });
}
};
8 changes: 8 additions & 0 deletions api/src/routes/timezone.routes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,23 @@ import {
fetchTimeDifference,
calculateDurationBetweenDates,
formatDateInTimezone,
formatDateLocale,
fetchSupportedCrrency,
fetchSupportedCalendar,
countDownToEvent,
} from '../controllers/timezone.controller';

const router = express.Router();

router.get('/currenttime', fetchCurrentTimeInZone);
router.get('/supportedtimezone', fetchSupportedTimezones);
router.get('/currency', fetchSupportedCrrency);
router.get('/calendar', fetchSupportedCalendar);
router.get('/converttimezone', fetchConvertedTime);
router.get('/timedifference', fetchTimeDifference);
router.get('/calculateduration', calculateDurationBetweenDates);
router.get('/formattimezone', formatDateInTimezone);
router.get('/formatdatelocale', formatDateLocale);
router.get('/countdownevent', countDownToEvent);

export default router;
2 changes: 1 addition & 1 deletion docs/api/Introduction.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ Let’s explore why a user might prefer to use the API endpoints instead of inst

## Note

Our base URl for the API is `https://world-clockify.com/api/v1/` and all the endpoints are relative to this base URL.
Our base URl for the API is `https://world-clockify-api.onrender.com/api/v1` and all the endpoints are relative to this base URL.

## 1. Serverless/Lightweight Client Applications

Expand Down
42 changes: 42 additions & 0 deletions docs/api/fetchSupportedCalendar.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
# Get List of Supported Calendar

Fetch the list of all supported calendar.

## Endpoint

```http
GET /calendar
```

## Example Request

```http
GET https://world-clockify-api.onrender.com/api/v1/calendar
```

## Example Response

```json
{
"calendar": [
"buddhist",
"chinese",
"coptic",
"dangi",
"ethioaa",
"ethiopic",
"gregory",
"hebrew",
"indian",
"islamic",
"islamic-civil",
"islamic-rgsa",
"islamic-tbla",
"islamic-umalqura",
"iso8601",
"japanese",
"persian",
"roc"
]
}
```
55 changes: 55 additions & 0 deletions docs/api/fetchSupportedCurrency.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
# Get List of Supported Currencies

Fetch the list of all supported currencies.

## Endpoint

```http
GET /currency
```

## Example Request

```http
GET https://world-clockify-api.onrender.com/api/v1/currency
```

## Example Response

```json
{
"crrencies": [
"AED",
"AFN",
"ALL",
"AMD",
"ANG",
"AOA",
"ARS",
"AUD",
"AWG",
"AZN",
"BAM",
"BBD",
"BDT",
"BGN",
"BHD",
"BIF",
"BMD",
"BND",
"BOB",
"BRL",
"BSD",
"BTN",
"BWP",
"BYN",
"BZD",
"CAD",
"CDF",
"CHF",
"CLP",
"CNY",
... more currencies
]
}
```
37 changes: 37 additions & 0 deletions docs/api/formatDateInLocale.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# 6. Format Date for locale

Format a date/time string according to a locale (e.g. 'en-us', 'fr').

## Endpoint

```http
GET /formatdatelocale
```

## Query Parameters

- dateStr (string) - The date/time in ISO format (e.g., "2024-10-17T10:30:00").
- locale (string) – The locale to format the date/time (e.g., "en-us").
- timezone (string) – The timezone of the original date/time (e.g., "America/New_York").

## Example Request

```http
GET https://world-clockify-api.onrender.com/api/v1/formatdatelocale?dateStr=2024-10-18T12:00:00&locale=en-us&timezone=Europe/Paris
```

## Example Response

```json
{
"formatDateLocale": "October 18, 2024 at 12:00 PM GMT+2"
}
```

## Error Responses

```json
{
"message": "Invalid parameters"
}
```
37 changes: 37 additions & 0 deletions docs/api/getCountdownToEvent.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# Get Count Down To Event

This endpoint returns the count down to the event.

## Endpoint

```bash
GET /countdownevent
```

## Query Parameters

- eventDate (string) - The date/time in ISO format (e.g., "2024-10-17T10:30:00").
- eventTimezone (string) – The timezone of the original event date/time (e.g., "America/New_York").

## Example Request

```http
https://world-clockify-api.onrender.com/api/v1/countdownevent?eventDate=2024-10-21T15:00:00&eventTimezone=America/New_York
```

## Example Response

```json
{
"countdownToEvent": "3 days, 2 hours, 30 minutes, 0 seconds"
}
```

## Error Responses

```json
{
"message": "Invalid parameters"
}
```

0 comments on commit 7534c27

Please sign in to comment.