0b6cc1acae
- Set 'sv' as default in LanguageProvider + layout (users can switch to 'en') - Completely revamped mobile drawer menu: slide animation (framer-motion), icons, active states with high-contrast text, large touch targets, better tap feedback - Horizontal snap-scrolling category filters on mobile (homepage + /menu) for thumb-friendly UX - Added active:scale / touch-manipulation + press states across cards, buttons, filters for better mobile tap visibility/feedback - Updated translations for menu page, locations, footer, experience (Swedish-first) - Made locations + footer language-aware - Trimmed banner_mobile.mp4 (raw + re-optimized) from 6s to 4s for faster load on mobile - Reordered languages so Svenska appears first in switcher - .gitignore already protects developer_instructions.txt (previous commit)
330 lines
12 KiB
TypeScript
330 lines
12 KiB
TypeScript
export type Language = 'en' | 'sv' | 'hi' | 'ur';
|
|
|
|
export const languages: { code: Language; name: string; native: string; flag: string }[] = [
|
|
{ code: 'sv', name: 'Swedish', native: 'Svenska', flag: '🇸🇪' },
|
|
{ code: 'en', name: 'English', native: 'English', flag: '🇬🇧' },
|
|
{ code: 'hi', name: 'Hindi', native: 'हिंदी', flag: '🇮🇳' },
|
|
{ code: 'ur', name: 'Urdu', native: 'اردو', flag: '🇵🇰' },
|
|
];
|
|
|
|
export const translations = {
|
|
en: {
|
|
// Navbar
|
|
nav: {
|
|
home: 'Home',
|
|
menu: 'Menu',
|
|
locations: 'Locations',
|
|
experience: 'Experience',
|
|
contact: 'Contact',
|
|
},
|
|
reserve: 'Reserve Table',
|
|
cart: 'Cart',
|
|
|
|
// Hero
|
|
hero: {
|
|
badge: 'Royal Indian & Pakistani Since 2016',
|
|
welcome: 'Welcome to',
|
|
title: 'ShahiKitchen Online',
|
|
subtitle: 'Experience the warmth of royal hospitality and the richness of authentic Indian and Pakistani flavors — now brought to you with elegance, from the heart of Gothenburg.',
|
|
exploreMenu: 'Explore the Menu',
|
|
viewExperience: 'The Shahi Experience',
|
|
},
|
|
|
|
// Signature Menu
|
|
signatureMenu: {
|
|
title: 'Signature Menu',
|
|
subtitle: 'A curated selection of our most beloved dishes.',
|
|
filterAll: 'All',
|
|
filterCurry: 'Curry',
|
|
filterRice: 'Rice',
|
|
filterGrill: 'Grill',
|
|
filterSweet: 'Sweet',
|
|
addToTable: 'Add to Table',
|
|
viewFullMenu: 'VIEW THE COMPLETE MENU — 40+ DISHES',
|
|
},
|
|
|
|
// Experience
|
|
experience: {
|
|
badge: 'THE SHAHI WAY',
|
|
title: 'Warmth like a feast.\nCalm like a palace.',
|
|
heritage: {
|
|
title: 'Royal Heritage',
|
|
text: 'Recipes passed through generations. Every dish tells a story of Punjab and the royal kitchens of the subcontinent.',
|
|
},
|
|
generous: {
|
|
title: 'Generous & Honest',
|
|
text: 'Large portions. No shortcuts. We treat every guest like family — the way hospitality was meant to be.',
|
|
},
|
|
grace: {
|
|
title: 'Modern Grace',
|
|
text: 'Beautiful spaces in Askim & Backaplan. Fast, thoughtful service. Packaging worthy of a gift.',
|
|
},
|
|
},
|
|
|
|
// Locations
|
|
locations: {
|
|
badge: 'TWO HOMES IN GOTHENBURG',
|
|
title: 'Come as guests.\nLeave as family.',
|
|
},
|
|
|
|
// Footer
|
|
footer: {
|
|
tagline: 'Authentic Indian & Pakistani cuisine in Gothenburg since 2016.',
|
|
locations: 'OUR LOCATIONS',
|
|
explore: 'EXPLORE',
|
|
follow: 'FOLLOW US',
|
|
},
|
|
|
|
// Common
|
|
add: 'Add',
|
|
viewCart: 'View Cart',
|
|
|
|
// Full Menu Page
|
|
menu: {
|
|
title: 'Our Menu',
|
|
subtitle: 'Traditional recipes. Generous portions. Made with heart.',
|
|
searchPlaceholder: 'Search dishes...',
|
|
showVegetarian: 'Show Vegetarian',
|
|
vegetarianOnly: 'Vegetarian Only',
|
|
clearFilters: 'Clear filters',
|
|
noResults: 'No dishes found matching your filters.',
|
|
dishes: 'dishes',
|
|
},
|
|
},
|
|
|
|
sv: {
|
|
nav: {
|
|
home: 'Hem',
|
|
menu: 'Meny',
|
|
locations: 'Platser',
|
|
experience: 'Upplevelse',
|
|
contact: 'Kontakt',
|
|
},
|
|
reserve: 'Boka Bord',
|
|
cart: 'Varukorg',
|
|
|
|
hero: {
|
|
badge: 'Kunglig Indisk & Pakistansk Sedan 2016',
|
|
welcome: 'Välkommen till',
|
|
title: 'ShahiKitchen Online',
|
|
subtitle: 'Upplev värmen från kunglig gästfrihet och rikedomen av autentiska indiska och pakistanska smaker — nu med elegans, från Göteborgs hjärta.',
|
|
exploreMenu: 'Utforska Menyn',
|
|
viewExperience: 'Shahi-upplevelsen',
|
|
},
|
|
|
|
signatureMenu: {
|
|
title: 'Signaturmeny',
|
|
subtitle: 'Ett noga utvalt urval av våra mest älskade rätter.',
|
|
filterAll: 'Alla',
|
|
filterCurry: 'Curry',
|
|
filterRice: 'Ris',
|
|
filterGrill: 'Grill',
|
|
filterSweet: 'Sött',
|
|
addToTable: 'Lägg till',
|
|
viewFullMenu: 'SE HELA MENYN — 40+ RÄTTER',
|
|
},
|
|
|
|
experience: {
|
|
badge: 'SHAHI-SÄTTET',
|
|
title: 'Värme som en fest.\nLugn som ett palats.',
|
|
heritage: {
|
|
title: 'Kungligt Arv',
|
|
text: 'Recept som gått i arv i generationer. Varje rätt berättar en historia från Punjab och de kungliga köken på subkontinenten.',
|
|
},
|
|
generous: {
|
|
title: 'Generöst & Ärligt',
|
|
text: 'Stora portioner. Inga genvägar. Vi behandlar varje gäst som familj — så som gästfrihet ska vara.',
|
|
},
|
|
grace: {
|
|
title: 'Modern Elegans',
|
|
text: 'Vackra lokaler i Askim & Backaplan. Snabb och omtänksam service. Förpackning värdig en gåva.',
|
|
},
|
|
},
|
|
|
|
locations: {
|
|
badge: 'TVÅ HEM I GÖTEBORG',
|
|
title: 'Kom som gäst.\nLämna som familj.',
|
|
},
|
|
|
|
footer: {
|
|
tagline: 'Autentisk indisk och pakistansk mat i Göteborg sedan 2016.',
|
|
locations: 'VÅRA PLATSER',
|
|
explore: 'UPPTÄCK',
|
|
follow: 'FÖLJ OSS',
|
|
},
|
|
|
|
add: 'Lägg till',
|
|
viewCart: 'Visa Varukorg',
|
|
|
|
// Full Menu Page
|
|
menu: {
|
|
title: 'Vår Meny',
|
|
subtitle: 'Traditionella recept. Generösa portioner. Tillagade med hjärta.',
|
|
searchPlaceholder: 'Sök rätter...',
|
|
showVegetarian: 'Visa vegetariskt',
|
|
vegetarianOnly: 'Endast vegetariskt',
|
|
clearFilters: 'Rensa filter',
|
|
noResults: 'Inga rätter matchar dina filter.',
|
|
dishes: 'rätter',
|
|
},
|
|
},
|
|
|
|
hi: {
|
|
nav: {
|
|
home: 'होम',
|
|
menu: 'मेन्यू',
|
|
locations: 'स्थान',
|
|
experience: 'अनुभव',
|
|
contact: 'संपर्क',
|
|
},
|
|
reserve: 'टेबल बुक करें',
|
|
cart: 'कार्ट',
|
|
|
|
hero: {
|
|
badge: '2016 से शाही भारतीय और पाकिस्तानी',
|
|
welcome: 'स्वागत है',
|
|
title: 'ShahiKitchen Online',
|
|
subtitle: 'शाही आतिथ्य की गर्माहट और असली भारतीय-पाकिस्तानी स्वादों की समृद्धि का अनुभव करें — अब गॉथेनबर्ग के दिल से, शान के साथ।',
|
|
exploreMenu: 'मेन्यू देखें',
|
|
viewExperience: 'शाही अनुभव',
|
|
},
|
|
|
|
signatureMenu: {
|
|
title: 'सिग्नेचर मेन्यू',
|
|
subtitle: 'हमारी सबसे पसंदीदा व्यंजनों का विशेष चयन।',
|
|
filterAll: 'सभी',
|
|
filterCurry: 'करी',
|
|
filterRice: 'चावल',
|
|
filterGrill: 'ग्रिल',
|
|
filterSweet: 'मिठाई',
|
|
addToTable: 'ऐड करें',
|
|
viewFullMenu: 'पूरी मेन्यू देखें — 40+ व्यंजन',
|
|
},
|
|
|
|
// Full Menu Page (fallback to English for now)
|
|
menu: {
|
|
title: 'Our Menu',
|
|
subtitle: 'Traditional recipes. Generous portions. Made with heart.',
|
|
searchPlaceholder: 'Search dishes...',
|
|
showVegetarian: 'Show Vegetarian',
|
|
vegetarianOnly: 'Vegetarian Only',
|
|
clearFilters: 'Clear filters',
|
|
noResults: 'No dishes found matching your filters.',
|
|
dishes: 'dishes',
|
|
},
|
|
|
|
experience: {
|
|
badge: 'शाही तरीका',
|
|
title: 'दावत जैसी गर्माहट।\nमहल जैसा सुकून।',
|
|
heritage: {
|
|
title: 'शाही विरासत',
|
|
text: 'पीढ़ियों से चले आ रहे रेसिपी। हर व्यंजन पंजाब और उपमहाद्वीप के शाही रसोईघरों की कहानी कहता है।',
|
|
},
|
|
generous: {
|
|
title: 'उदार और ईमानदार',
|
|
text: 'बड़ी सर्विंग्स। कोई शॉर्टकट नहीं। हम हर मेहमान को परिवार की तरह मानते हैं — जैसी आतिथ्य होनी चाहिए।',
|
|
},
|
|
grace: {
|
|
title: 'आधुनिक शान',
|
|
text: 'अस्किम और बैकाप्लान में खूबसूरत जगहें। तेज़ और सोच-समझकर की गई सेवा। तोहफे जैसी पैकेजिंग।',
|
|
},
|
|
},
|
|
|
|
locations: {
|
|
badge: 'गॉथेनबर्ग में दो घर',
|
|
title: 'मेहमान बनकर आएं।\nपरिवार बनकर जाएं।',
|
|
},
|
|
|
|
footer: {
|
|
tagline: '2016 से गॉथेनबर्ग में असली भारतीय और पाकिस्तानी खाना।',
|
|
locations: 'हमारे स्थान',
|
|
explore: 'एक्सप्लोर करें',
|
|
follow: 'हमें फॉलो करें',
|
|
},
|
|
|
|
add: 'ऐड करें',
|
|
viewCart: 'कार्ट देखें',
|
|
},
|
|
|
|
ur: {
|
|
nav: {
|
|
home: 'ہوم',
|
|
menu: 'مینو',
|
|
locations: 'مقامات',
|
|
experience: 'تجربہ',
|
|
contact: 'رابطہ',
|
|
},
|
|
reserve: 'ٹیبل بک کریں',
|
|
cart: 'کارٹ',
|
|
|
|
hero: {
|
|
badge: '2016 سے شاہی انڈین اور پاکستانی',
|
|
welcome: 'خوش آمدید',
|
|
title: 'ShahiKitchen Online',
|
|
subtitle: 'شاہی مہمان نوازی کی گرمی اور اصلی انڈین پاکستانی ذائقوں کی دولت کا تجربہ کریں — اب گوٹنبرگ کے دل سے، شان و شوکت کے ساتھ۔',
|
|
exploreMenu: 'مینو دیکھیں',
|
|
viewExperience: 'شاہی تجربہ',
|
|
},
|
|
|
|
signatureMenu: {
|
|
title: 'سگنیچر مینو',
|
|
subtitle: 'ہمارے سب سے پسندیدہ پکوانوں کا منتخب انتخاب۔',
|
|
filterAll: 'سب',
|
|
filterCurry: 'کری',
|
|
filterRice: 'چاول',
|
|
filterGrill: 'گرل',
|
|
filterSweet: 'میٹھی',
|
|
addToTable: 'شامل کریں',
|
|
viewFullMenu: 'مکمل مینو دیکھیں — 40+ پکوان',
|
|
},
|
|
|
|
// Full Menu Page (fallback to English for now)
|
|
menu: {
|
|
title: 'Our Menu',
|
|
subtitle: 'Traditional recipes. Generous portions. Made with heart.',
|
|
searchPlaceholder: 'Search dishes...',
|
|
showVegetarian: 'Show Vegetarian',
|
|
vegetarianOnly: 'Vegetarian Only',
|
|
clearFilters: 'Clear filters',
|
|
noResults: 'No dishes found matching your filters.',
|
|
dishes: 'dishes',
|
|
},
|
|
|
|
experience: {
|
|
badge: 'شاہی طریقہ',
|
|
title: 'دعوت جیسی گرمی۔\nمحل جیسا سکون۔',
|
|
heritage: {
|
|
title: 'شاہی وراثت',
|
|
text: 'نسلوں سے چلے آ رہے نسخے۔ ہر پکوان پنجاب اور برصغیر کی شاہی رasoئیوں کی کہانی سناتا ہے۔',
|
|
},
|
|
generous: {
|
|
title: 'سخی اور ایماندار',
|
|
text: 'بڑی سرونگ۔ کوئی شارٹ کٹ نہیں۔ ہم ہر مہمان کو خاندان کی طرح مانتے ہیں — جیسے مہمان نوازی ہونی چاہیے۔',
|
|
},
|
|
grace: {
|
|
title: 'جدید شان',
|
|
text: 'اسکیم اور بیکاپلان میں خوبصورت جگہیں۔ تیز اور سوچ سمجھ کر کی گئی سروس۔ تحفے جیسی پیکنگ۔',
|
|
},
|
|
},
|
|
|
|
locations: {
|
|
badge: 'گوٹنبرگ میں دو گھر',
|
|
title: 'مہمان بن کر آئیں۔\nخاندان بن کر جائیں۔',
|
|
},
|
|
|
|
footer: {
|
|
tagline: '2016 سے گوٹنبرگ میں اصلی انڈین اور پاکستانی کھانا۔',
|
|
locations: 'ہمارے مقامات',
|
|
explore: 'دریافت کریں',
|
|
follow: 'ہمیں فالو کریں',
|
|
},
|
|
|
|
add: 'شامل کریں',
|
|
viewCart: 'کارٹ دیکھیں',
|
|
},
|
|
} as const;
|
|
|
|
export function getTranslation(lang: Language) {
|
|
return translations[lang];
|
|
}
|