Initialize repo
This commit is contained in:
132
app/globals.css
Normal file
132
app/globals.css
Normal file
@@ -0,0 +1,132 @@
|
||||
@import 'tailwindcss';
|
||||
@import 'tw-animate-css';
|
||||
|
||||
@custom-variant dark (&:is(.dark *));
|
||||
|
||||
|
||||
html {
|
||||
scroll-behavior: smooth;
|
||||
scroll-padding-top: 5rem; /* Offset for fixed header */
|
||||
}
|
||||
|
||||
:root {
|
||||
--background: oklch(0.98 0.005 80);
|
||||
--foreground: oklch(0.25 0.02 50);
|
||||
--card: oklch(1 0 0);
|
||||
--card-foreground: oklch(0.25 0.02 50);
|
||||
--popover: oklch(1 0 0);
|
||||
--popover-foreground: oklch(0.25 0.02 50);
|
||||
--primary: oklch(0.55 0.12 55);
|
||||
--primary-foreground: oklch(0.98 0.005 80);
|
||||
--secondary: oklch(0.95 0.015 80);
|
||||
--secondary-foreground: oklch(0.35 0.03 50);
|
||||
--muted: oklch(0.94 0.01 80);
|
||||
--muted-foreground: oklch(0.5 0.02 50);
|
||||
--accent: oklch(0.85 0.08 85);
|
||||
--accent-foreground: oklch(0.3 0.03 50);
|
||||
--destructive: oklch(0.577 0.245 27.325);
|
||||
--destructive-foreground: oklch(0.577 0.245 27.325);
|
||||
--border: oklch(0.9 0.02 80);
|
||||
--input: oklch(0.92 0.015 80);
|
||||
--ring: oklch(0.55 0.12 55);
|
||||
--chart-1: oklch(0.646 0.222 41.116);
|
||||
--chart-2: oklch(0.6 0.118 184.704);
|
||||
--chart-3: oklch(0.398 0.07 227.392);
|
||||
--chart-4: oklch(0.828 0.189 84.429);
|
||||
--chart-5: oklch(0.769 0.188 70.08);
|
||||
--radius: 0.625rem;
|
||||
--sidebar: oklch(0.985 0 0);
|
||||
--sidebar-foreground: oklch(0.145 0 0);
|
||||
--sidebar-primary: oklch(0.205 0 0);
|
||||
--sidebar-primary-foreground: oklch(0.985 0 0);
|
||||
--sidebar-accent: oklch(0.97 0 0);
|
||||
--sidebar-accent-foreground: oklch(0.205 0 0);
|
||||
--sidebar-border: oklch(0.922 0 0);
|
||||
--sidebar-ring: oklch(0.708 0 0);
|
||||
}
|
||||
|
||||
.dark {
|
||||
--background: oklch(0.145 0 0);
|
||||
--foreground: oklch(0.985 0 0);
|
||||
--card: oklch(0.145 0 0);
|
||||
--card-foreground: oklch(0.985 0 0);
|
||||
--popover: oklch(0.145 0 0);
|
||||
--popover-foreground: oklch(0.985 0 0);
|
||||
--primary: oklch(0.985 0 0);
|
||||
--primary-foreground: oklch(0.205 0 0);
|
||||
--secondary: oklch(0.269 0 0);
|
||||
--secondary-foreground: oklch(0.985 0 0);
|
||||
--muted: oklch(0.269 0 0);
|
||||
--muted-foreground: oklch(0.708 0 0);
|
||||
--accent: oklch(0.269 0 0);
|
||||
--accent-foreground: oklch(0.985 0 0);
|
||||
--destructive: oklch(0.396 0.141 25.723);
|
||||
--destructive-foreground: oklch(0.637 0.237 25.331);
|
||||
--border: oklch(0.269 0 0);
|
||||
--input: oklch(0.269 0 0);
|
||||
--ring: oklch(0.439 0 0);
|
||||
--chart-1: oklch(0.488 0.243 264.376);
|
||||
--chart-2: oklch(0.696 0.17 162.48);
|
||||
--chart-3: oklch(0.769 0.188 70.08);
|
||||
--chart-4: oklch(0.627 0.265 303.9);
|
||||
--chart-5: oklch(0.645 0.246 16.439);
|
||||
--sidebar: oklch(0.205 0 0);
|
||||
--sidebar-foreground: oklch(0.985 0 0);
|
||||
--sidebar-primary: oklch(0.488 0.243 264.376);
|
||||
--sidebar-primary-foreground: oklch(0.985 0 0);
|
||||
--sidebar-accent: oklch(0.269 0 0);
|
||||
--sidebar-accent-foreground: oklch(0.985 0 0);
|
||||
--sidebar-border: oklch(0.269 0 0);
|
||||
--sidebar-ring: oklch(0.439 0 0);
|
||||
}
|
||||
|
||||
@theme inline {
|
||||
--font-sans: var(--font-dm-sans), 'DM Sans', system-ui, sans-serif;
|
||||
--font-serif: var(--font-playfair), 'Playfair Display', Georgia, serif;
|
||||
--font-mono: 'Geist Mono', 'Geist Mono Fallback';
|
||||
--color-background: var(--background);
|
||||
--color-foreground: var(--foreground);
|
||||
--color-card: var(--card);
|
||||
--color-card-foreground: var(--card-foreground);
|
||||
--color-popover: var(--popover);
|
||||
--color-popover-foreground: var(--popover-foreground);
|
||||
--color-primary: var(--primary);
|
||||
--color-primary-foreground: var(--primary-foreground);
|
||||
--color-secondary: var(--secondary);
|
||||
--color-secondary-foreground: var(--secondary-foreground);
|
||||
--color-muted: var(--muted);
|
||||
--color-muted-foreground: var(--muted-foreground);
|
||||
--color-accent: var(--accent);
|
||||
--color-accent-foreground: var(--accent-foreground);
|
||||
--color-destructive: var(--destructive);
|
||||
--color-destructive-foreground: var(--destructive-foreground);
|
||||
--color-border: var(--border);
|
||||
--color-input: var(--input);
|
||||
--color-ring: var(--ring);
|
||||
--color-chart-1: var(--chart-1);
|
||||
--color-chart-2: var(--chart-2);
|
||||
--color-chart-3: var(--chart-3);
|
||||
--color-chart-4: var(--chart-4);
|
||||
--color-chart-5: var(--chart-5);
|
||||
--radius-sm: calc(var(--radius) - 4px);
|
||||
--radius-md: calc(var(--radius) - 2px);
|
||||
--radius-lg: var(--radius);
|
||||
--radius-xl: calc(var(--radius) + 4px);
|
||||
--color-sidebar: var(--sidebar);
|
||||
--color-sidebar-foreground: var(--sidebar-foreground);
|
||||
--color-sidebar-primary: var(--sidebar-primary);
|
||||
--color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
|
||||
--color-sidebar-accent: var(--sidebar-accent);
|
||||
--color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
|
||||
--color-sidebar-border: var(--sidebar-border);
|
||||
--color-sidebar-ring: var(--sidebar-ring);
|
||||
}
|
||||
|
||||
@layer base {
|
||||
* {
|
||||
@apply border-border outline-ring/50;
|
||||
}
|
||||
body {
|
||||
@apply bg-background text-foreground;
|
||||
}
|
||||
}
|
||||
106
app/layout.tsx
Normal file
106
app/layout.tsx
Normal file
@@ -0,0 +1,106 @@
|
||||
import React from "react"
|
||||
import type { Metadata, Viewport } from 'next'
|
||||
import { DM_Sans, Playfair_Display } from 'next/font/google'
|
||||
import { Analytics } from '@vercel/analytics/next'
|
||||
import './globals.css'
|
||||
|
||||
const dmSans = DM_Sans({ subsets: ["latin"], variable: "--font-dm-sans" });
|
||||
const playfair = Playfair_Display({ subsets: ["latin"], variable: "--font-playfair" });
|
||||
|
||||
export const metadata: Metadata = {
|
||||
metadataBase: new URL('https://sloneczko-dzwirzyno.pl'), // Replace with actual domain if known, or use localhost/placeholder
|
||||
title: {
|
||||
default: 'Domki Letniskowe Słoneczko | Dźwirzyno',
|
||||
template: '%s | Domki Letniskowe Słoneczko',
|
||||
},
|
||||
description: 'Spędź niezapomniane wakacje w Domkach Letniskowych Słoneczko w Dźwirzynie. Komfortowe noclegi blisko morza (450m) i jeziora Resko.',
|
||||
keywords: ['domki letniskowe', 'Dźwirzyno', 'noclegi nad morzem', 'wakacje dla rodzin', 'domki blisko plaży', 'wczasy Dźwirzyno'],
|
||||
authors: [{ name: 'Słoneczko' }],
|
||||
creator: 'Słoneczko',
|
||||
publisher: 'Słoneczko',
|
||||
formatDetection: {
|
||||
email: false,
|
||||
address: false,
|
||||
telephone: false,
|
||||
},
|
||||
openGraph: {
|
||||
title: 'Domki Letniskowe Słoneczko | Rodzinne Wakacje w Dźwirzynie',
|
||||
description: 'Komfortowe domki letniskowe i pokoje w Dźwirzynie. Tylko 450m od morza! Plac zabaw, grill, parking. Zarezerwuj swój pobyt.',
|
||||
url: 'https://sloneczko-dzwirzyno.pl',
|
||||
siteName: 'Domki Letniskowe Słoneczko',
|
||||
locale: 'pl_PL',
|
||||
type: 'website',
|
||||
},
|
||||
twitter: {
|
||||
card: 'summary_large_image',
|
||||
title: 'Domki Letniskowe Słoneczko | Dźwirzyno',
|
||||
description: 'Wypoczynek blisko natury. Domki 450m od morza.',
|
||||
},
|
||||
robots: {
|
||||
index: true,
|
||||
follow: true,
|
||||
googleBot: {
|
||||
index: true,
|
||||
follow: true,
|
||||
'max-video-preview': -1,
|
||||
'max-image-preview': 'large',
|
||||
'max-snippet': -1,
|
||||
},
|
||||
},
|
||||
icons: {
|
||||
icon: [
|
||||
{ url: '/icon-light-32x32.png', media: '(prefers-color-scheme: light)' },
|
||||
{ url: '/icon-dark-32x32.png', media: '(prefers-color-scheme: dark)' },
|
||||
{ url: '/icon.svg', type: 'image/svg+xml' },
|
||||
],
|
||||
apple: '/apple-icon.png',
|
||||
},
|
||||
}
|
||||
|
||||
export const viewport: Viewport = {
|
||||
width: 'device-width',
|
||||
initialScale: 1,
|
||||
}
|
||||
|
||||
export default function RootLayout({
|
||||
children,
|
||||
}: Readonly<{
|
||||
children: React.ReactNode
|
||||
}>) {
|
||||
return (
|
||||
<html lang="pl">
|
||||
<body className={`${dmSans.variable} ${playfair.variable} font-sans antialiased`}>
|
||||
{children}
|
||||
<script
|
||||
type="application/ld+json"
|
||||
dangerouslySetInnerHTML={{
|
||||
__html: JSON.stringify({
|
||||
'@context': 'https://schema.org',
|
||||
'@type': 'LodgingBusiness',
|
||||
name: 'Domki Letniskowe Słoneczko',
|
||||
image: 'https://sloneczko-dzwirzyno.pl/sloneczko.webp',
|
||||
'@id': 'https://sloneczko-dzwirzyno.pl',
|
||||
url: 'https://sloneczko-dzwirzyno.pl',
|
||||
telephone: '+48664786167',
|
||||
address: {
|
||||
'@type': 'PostalAddress',
|
||||
streetAddress: 'Wczasowa 1',
|
||||
addressLocality: 'Dźwirzyno',
|
||||
postalCode: '78-131',
|
||||
addressCountry: 'PL',
|
||||
},
|
||||
geo: {
|
||||
'@type': 'GeoCoordinates',
|
||||
latitude: 54.1537,
|
||||
longitude: 15.4214,
|
||||
},
|
||||
priceRange: '$$',
|
||||
description: 'Domki letniskowe i pokoje gościnne blisko morza w Dźwirzynie.',
|
||||
}),
|
||||
}}
|
||||
/>
|
||||
<Analytics />
|
||||
</body>
|
||||
</html>
|
||||
)
|
||||
}
|
||||
38
app/page.tsx
Normal file
38
app/page.tsx
Normal file
@@ -0,0 +1,38 @@
|
||||
import { Header } from "@/components/header";
|
||||
import { Hero } from "@/components/hero";
|
||||
import { About } from "@/components/about";
|
||||
import { Gallery } from "@/components/gallery";
|
||||
import { Amenities } from "@/components/amenities";
|
||||
import { Pricing } from "@/components/pricing";
|
||||
import { Location } from "@/components/location";
|
||||
import { Contact } from "@/components/contact";
|
||||
import { Footer } from "@/components/footer";
|
||||
import { FadeIn } from "@/components/ui/fade-in";
|
||||
|
||||
export default function Home() {
|
||||
return (
|
||||
<main className="min-h-screen">
|
||||
<Header />
|
||||
<Hero />
|
||||
<FadeIn>
|
||||
<About />
|
||||
</FadeIn>
|
||||
<FadeIn>
|
||||
<Gallery />
|
||||
</FadeIn>
|
||||
<FadeIn>
|
||||
<Amenities />
|
||||
</FadeIn>
|
||||
<FadeIn>
|
||||
<Pricing />
|
||||
</FadeIn>
|
||||
<FadeIn>
|
||||
<Location />
|
||||
</FadeIn>
|
||||
<FadeIn>
|
||||
<Contact />
|
||||
</FadeIn>
|
||||
<Footer />
|
||||
</main>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user