added time to hourlycard and added dockerfile
This commit is contained in:
parent
19d3aec4fe
commit
856df75222
69
Dockerfile
Normal file
69
Dockerfile
Normal file
@ -0,0 +1,69 @@
|
||||
FROM node:18-alpine AS base
|
||||
|
||||
# Install dependencies only when needed
|
||||
FROM base AS deps
|
||||
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
|
||||
RUN apk add --no-cache libc6-compat
|
||||
WORKDIR /app
|
||||
|
||||
# Install dependencies based on the preferred package manager
|
||||
COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* ./
|
||||
RUN \
|
||||
if [ -f yarn.lock ]; then yarn --frozen-lockfile; \
|
||||
elif [ -f package-lock.json ]; then npm ci; \
|
||||
elif [ -f pnpm-lock.yaml ]; then corepack enable pnpm && pnpm i --frozen-lockfile; \
|
||||
else echo "Lockfile not found." && exit 1; \
|
||||
fi
|
||||
|
||||
|
||||
# Rebuild the source code only when needed
|
||||
FROM base AS builder
|
||||
WORKDIR /app
|
||||
COPY --from=deps /app/node_modules ./node_modules
|
||||
COPY . .
|
||||
|
||||
# Next.js collects completely anonymous telemetry data about general usage.
|
||||
# Learn more here: https://nextjs.org/telemetry
|
||||
# Uncomment the following line in case you want to disable telemetry during the build.
|
||||
# ENV NEXT_TELEMETRY_DISABLED 1
|
||||
|
||||
RUN \
|
||||
if [ -f yarn.lock ]; then yarn run build; \
|
||||
elif [ -f package-lock.json ]; then npm run build; \
|
||||
elif [ -f pnpm-lock.yaml ]; then corepack enable pnpm && pnpm run build; \
|
||||
else echo "Lockfile not found." && exit 1; \
|
||||
fi
|
||||
|
||||
# Production image, copy all the files and run next
|
||||
FROM base AS runner
|
||||
WORKDIR /app
|
||||
|
||||
ENV NODE_ENV production
|
||||
# Uncomment the following line in case you want to disable telemetry during runtime.
|
||||
# ENV NEXT_TELEMETRY_DISABLED 1
|
||||
|
||||
RUN addgroup --system --gid 1001 nodejs
|
||||
RUN adduser --system --uid 1001 nextjs
|
||||
|
||||
COPY --from=builder /app/public ./public
|
||||
|
||||
# Set the correct permission for prerender cache
|
||||
RUN mkdir .next
|
||||
RUN chown nextjs:nodejs .next
|
||||
|
||||
# Automatically leverage output traces to reduce image size
|
||||
# https://nextjs.org/docs/advanced-features/output-file-tracing
|
||||
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
|
||||
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
|
||||
|
||||
USER nextjs
|
||||
|
||||
EXPOSE 3000
|
||||
|
||||
ENV PORT 3000
|
||||
# set hostname to localhost
|
||||
ENV HOSTNAME "0.0.0.0"
|
||||
|
||||
# server.js is created by next build from the standalone output
|
||||
# https://nextjs.org/docs/pages/api-reference/next-config-js/output
|
||||
CMD ["node", "server.js"]
|
@ -22,7 +22,7 @@ export default function Home() {
|
||||
|
||||
return (
|
||||
<main>
|
||||
<div className='mx-auto max-w-3xl'>
|
||||
<div className='mx-auto max-w-3xl text-center'>
|
||||
<LocationContext.Provider value={contextValue}>
|
||||
<LocationSearch />
|
||||
<WeatherNow />
|
||||
|
@ -1,14 +1,17 @@
|
||||
import { HourlyCardPropType } from "@/types/types"
|
||||
import WeatherIcon from "./WeatherIcon"
|
||||
import HourlyTemp from "./HourlyTemp"
|
||||
import HourlyTime from "./HourlyTime";
|
||||
|
||||
export default function HourlyCard(props: HourlyCardPropType) {
|
||||
const time = props.time;
|
||||
const weatherCode = props.weatherCode
|
||||
const temperature = props.temperature
|
||||
return (
|
||||
<div className="m-2 text-center shadow-md border-slate-200 border-2 rounded">
|
||||
<WeatherIcon weatherCode={weatherCode}/>
|
||||
<HourlyTemp temperature={temperature} />
|
||||
<HourlyTime time={time} />
|
||||
</div>
|
||||
)
|
||||
};
|
7
components/HourlyCard/HourlyTime.tsx
Normal file
7
components/HourlyCard/HourlyTime.tsx
Normal file
@ -0,0 +1,7 @@
|
||||
import { headers } from "next/headers";
|
||||
|
||||
export default function HourlyTime(props: {time: string}) {
|
||||
return(
|
||||
<p>{props.time}</p>
|
||||
)
|
||||
}
|
@ -35,7 +35,7 @@ export default function WeatherNow() {
|
||||
};
|
||||
}, [geoLocation]);
|
||||
return (
|
||||
<>
|
||||
<div className="text-center">
|
||||
<h1 className="my-4 text-2xl">
|
||||
Here is the current weather in {geoLocation.name}
|
||||
</h1>
|
||||
@ -49,10 +49,11 @@ export default function WeatherNow() {
|
||||
key={index}
|
||||
temperature={temp}
|
||||
weatherCode={weather.hourly.weather_code[index]}
|
||||
time={weather.hourly.time[index]}
|
||||
/>
|
||||
))}
|
||||
</div>
|
||||
</WeatherContext.Provider>
|
||||
</>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
@ -1,4 +1,6 @@
|
||||
/** @type {import('next').NextConfig} */
|
||||
const nextConfig = {};
|
||||
const nextConfig = {
|
||||
output: "standalone"
|
||||
};
|
||||
|
||||
export default nextConfig;
|
||||
|
@ -217,4 +217,5 @@ export interface WeatherContextType {
|
||||
export interface HourlyCardPropType {
|
||||
temperature: number;
|
||||
weatherCode: number;
|
||||
time: string;
|
||||
}
|
Loading…
Reference in New Issue
Block a user