From 97f5c141d2b57048dcaed2cb3acbf23b5edb0284 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jo=C3=A3o=20Pedro=20Henrique?= Date: Fri, 5 May 2023 09:09:06 -0300 Subject: [PATCH] feat: add eet column in table (#140) --- .../app/src/components/FlightsTable/index.tsx | 107 +++++++++++------- 1 file changed, 66 insertions(+), 41 deletions(-) diff --git a/packages/app/src/components/FlightsTable/index.tsx b/packages/app/src/components/FlightsTable/index.tsx index 32488167..074fe0fc 100644 --- a/packages/app/src/components/FlightsTable/index.tsx +++ b/packages/app/src/components/FlightsTable/index.tsx @@ -1,15 +1,23 @@ -"use client" +"use client"; -import Flight from '@mach/common' -import { FC, useState } from 'react' -import { Airport } from '../../services/fetch-airports' -import { formatAirport } from '../../utils/format-airport' -import Button from '../Button' -import FlightModal from '../FlightModal' -import styles from './index.module.css' +import Flight from "@mach/common"; +import { FC, useState } from "react"; +import { Airport } from "../../services/fetch-airports"; +import { formatAirport } from "../../utils/format-airport"; +import Button from "../Button"; +import FlightModal from "../FlightModal"; +import styles from "./index.module.css"; type Props = { - items: Array + items: Array; +}; + +function minutesToEet(totalMinutes: number) { + const hours = Math.floor(totalMinutes / 60); + const minutes = totalMinutes % 60; + return `${hours.toString().padStart(2, "0")}${minutes + .toString() + .padStart(2, "0")}`; } const FlightsTable: FC = ({ items }) => { @@ -18,36 +26,53 @@ const FlightsTable: FC = ({ items }) => { return (
- - - - - - - - - +
CallsignDepartureArrivalEOBTAircraftDetails
+ + + + + + + + + + + + + {items.map((flight, key) => ( + + + + + + + + - - - {items.map((flight, key) => ( - - - - - - - - - ))} - + ))} +
CallsignDepartureArrivalEOBTEETAircraftDetails
{flight.callsign} + + {flight.departureIcao} + + + + {flight.arrivalIcao} + + {flight.estimatedOffBlockTime}{minutesToEet(flight.estimatedEnrouteMinutes)}{flight.aircraft.icaoCode} + +
{flight.callsign}{flight.departureIcao}{flight.arrivalIcao}{flight.estimatedOffBlockTime}{flight.aircraft.icaoCode} - -
= ({ items }) => { onClose={() => setFlight(undefined)} />
- ) -} + ); +}; -export default FlightsTable +export default FlightsTable;