V podstate jazyky ready

This commit is contained in:
Matyáš Caras 2022-05-15 16:59:55 +02:00
parent 887900c627
commit 60033b4c45
17 changed files with 432 additions and 191 deletions

82
.gitignore vendored
View file

@ -1,6 +1,6 @@
# Created by https://www.toptal.com/developers/gitignore/api/flutter,visualstudiocode,windows # Created by https://www.toptal.com/developers/gitignore/api/flutter,linux,macos,visualstudiocode
# Edit at https://www.toptal.com/developers/gitignore?templates=flutter,visualstudiocode,windows # Edit at https://www.toptal.com/developers/gitignore?templates=flutter,linux,macos,visualstudiocode
### Flutter ### ### Flutter ###
# Flutter/Dart/Pub related # Flutter/Dart/Pub related
@ -66,6 +66,54 @@ lib/generated_plugin_registrant.dart
!**/ios/**/default.perspectivev3 !**/ios/**/default.perspectivev3
!/packages/flutter_tools/test/data/dart_dependencies_test/**/.packages !/packages/flutter_tools/test/data/dart_dependencies_test/**/.packages
### Linux ###
*~
# temporary files which can be created if a process still has a handle open of a deleted file
.fuse_hidden*
# KDE directory preferences
.directory
# Linux trash folder which might appear on any partition or disk
.Trash-*
# .nfs files are created when an open file is removed but is still being accessed
.nfs*
### macOS ###
# General
.DS_Store
.AppleDouble
.LSOverride
# Icon must end with two \r
Icon
# Thumbnails
._*
# Files that might appear in the root of a volume
.DocumentRevisions-V100
.fseventsd
.Spotlight-V100
.TemporaryItems
.Trashes
.VolumeIcon.icns
.com.apple.timemachine.donotpresent
# Directories potentially created on remote AFP share
.AppleDB
.AppleDesktop
Network Trash Folder
Temporary Items
.apdisk
### macOS Patch ###
# iCloud generated files
*.icloud
### VisualStudioCode ### ### VisualStudioCode ###
.vscode/* .vscode/*
!.vscode/settings.json !.vscode/settings.json
@ -86,31 +134,9 @@ lib/generated_plugin_registrant.dart
.ionide .ionide
# Support for Project snippet scope # Support for Project snippet scope
.vscode/*.code-snippets
### Windows ### # Ignore code-workspaces
# Windows thumbnail cache files *.code-workspace
Thumbs.db
Thumbs.db:encryptable
ehthumbs.db
ehthumbs_vista.db
# Dump file # End of https://www.toptal.com/developers/gitignore/api/flutter,linux,macos,visualstudiocode
*.stackdump
# Folder config file
[Dd]esktop.ini
# Recycle Bin used on file shares
$RECYCLE.BIN/
# Windows Installer files
*.cab
*.msi
*.msix
*.msm
*.msp
# Windows shortcuts
*.lnk
# End of https://www.toptal.com/developers/gitignore/api/flutter,visualstudiocode,windows

View file

@ -1 +1,2 @@
#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"
#include "Generated.xcconfig" #include "Generated.xcconfig"

View file

@ -1 +1,2 @@
#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"
#include "Generated.xcconfig" #include "Generated.xcconfig"

41
ios/Podfile Normal file
View file

@ -0,0 +1,41 @@
# Uncomment this line to define a global platform for your project
# platform :ios, '9.0'
# CocoaPods analytics sends network stats synchronously affecting flutter build latency.
ENV['COCOAPODS_DISABLE_STATS'] = 'true'
project 'Runner', {
'Debug' => :debug,
'Profile' => :release,
'Release' => :release,
}
def flutter_root
generated_xcode_build_settings_path = File.expand_path(File.join('..', 'Flutter', 'Generated.xcconfig'), __FILE__)
unless File.exist?(generated_xcode_build_settings_path)
raise "#{generated_xcode_build_settings_path} must exist. If you're running pod install manually, make sure flutter pub get is executed first"
end
File.foreach(generated_xcode_build_settings_path) do |line|
matches = line.match(/FLUTTER_ROOT\=(.*)/)
return matches[1].strip if matches
end
raise "FLUTTER_ROOT not found in #{generated_xcode_build_settings_path}. Try deleting Generated.xcconfig, then run flutter pub get"
end
require File.expand_path(File.join('packages', 'flutter_tools', 'bin', 'podhelper'), flutter_root)
flutter_ios_podfile_setup
target 'Runner' do
use_frameworks!
use_modular_headers!
flutter_install_all_ios_pods File.dirname(File.realpath(__FILE__))
end
post_install do |installer|
installer.pods_project.targets.each do |target|
flutter_additional_ios_build_settings(target)
end
end

53
ios/Podfile.lock Normal file
View file

@ -0,0 +1,53 @@
PODS:
- connectivity_plus (0.0.1):
- Flutter
- ReachabilitySwift
- Flutter (1.0.0)
- flutter_secure_storage (3.3.1):
- Flutter
- path_provider_ios (0.0.1):
- Flutter
- ReachabilitySwift (5.0.0)
- shared_preferences_ios (0.0.1):
- Flutter
- url_launcher_ios (0.0.1):
- Flutter
DEPENDENCIES:
- connectivity_plus (from `.symlinks/plugins/connectivity_plus/ios`)
- Flutter (from `Flutter`)
- flutter_secure_storage (from `.symlinks/plugins/flutter_secure_storage/ios`)
- path_provider_ios (from `.symlinks/plugins/path_provider_ios/ios`)
- shared_preferences_ios (from `.symlinks/plugins/shared_preferences_ios/ios`)
- url_launcher_ios (from `.symlinks/plugins/url_launcher_ios/ios`)
SPEC REPOS:
trunk:
- ReachabilitySwift
EXTERNAL SOURCES:
connectivity_plus:
:path: ".symlinks/plugins/connectivity_plus/ios"
Flutter:
:path: Flutter
flutter_secure_storage:
:path: ".symlinks/plugins/flutter_secure_storage/ios"
path_provider_ios:
:path: ".symlinks/plugins/path_provider_ios/ios"
shared_preferences_ios:
:path: ".symlinks/plugins/shared_preferences_ios/ios"
url_launcher_ios:
:path: ".symlinks/plugins/url_launcher_ios/ios"
SPEC CHECKSUMS:
connectivity_plus: 413a8857dd5d9f1c399a39130850d02fe0feaf7e
Flutter: 50d75fe2f02b26cc09d224853bb45737f8b3214a
flutter_secure_storage: 7953c38a04c3fdbb00571bcd87d8e3b5ceb9daec
path_provider_ios: 14f3d2fd28c4fdb42f44e0f751d12861c43cee02
ReachabilitySwift: 985039c6f7b23a1da463388634119492ff86c825
shared_preferences_ios: 548a61f8053b9b8a49ac19c1ffbc8b92c50d68ad
url_launcher_ios: 839c58cdb4279282219f5e248c3321761ff3c4de
PODFILE CHECKSUM: aafe91acc616949ddb318b77800a7f51bffa2a4c
COCOAPODS: 1.11.3

View file

@ -13,6 +13,7 @@
97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; }; 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; };
97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; }; 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; };
97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; }; 97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; };
ECEF07EFF70219039EC91A16 /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = E7322157B64E41A54727F1B5 /* Pods_Runner.framework */; };
/* End PBXBuildFile section */ /* End PBXBuildFile section */
/* Begin PBXCopyFilesBuildPhase section */ /* Begin PBXCopyFilesBuildPhase section */
@ -42,6 +43,10 @@
97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; }; 97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; }; 97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; }; 97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
B2721B88A12E59F3457F19ED /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = "<group>"; };
BC9FB05A1DCF7C7EFD0E5EBB /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = "<group>"; };
DBABB66BE912BBC3B3B3D706 /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = "<group>"; };
E7322157B64E41A54727F1B5 /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; };
/* End PBXFileReference section */ /* End PBXFileReference section */
/* Begin PBXFrameworksBuildPhase section */ /* Begin PBXFrameworksBuildPhase section */
@ -49,12 +54,32 @@
isa = PBXFrameworksBuildPhase; isa = PBXFrameworksBuildPhase;
buildActionMask = 2147483647; buildActionMask = 2147483647;
files = ( files = (
ECEF07EFF70219039EC91A16 /* Pods_Runner.framework in Frameworks */,
); );
runOnlyForDeploymentPostprocessing = 0; runOnlyForDeploymentPostprocessing = 0;
}; };
/* End PBXFrameworksBuildPhase section */ /* End PBXFrameworksBuildPhase section */
/* Begin PBXGroup section */ /* Begin PBXGroup section */
1CA2C3BE126DAC67B3E72712 /* Pods */ = {
isa = PBXGroup;
children = (
B2721B88A12E59F3457F19ED /* Pods-Runner.debug.xcconfig */,
DBABB66BE912BBC3B3B3D706 /* Pods-Runner.release.xcconfig */,
BC9FB05A1DCF7C7EFD0E5EBB /* Pods-Runner.profile.xcconfig */,
);
name = Pods;
path = Pods;
sourceTree = "<group>";
};
8E9103B40D6588B574AD43FA /* Frameworks */ = {
isa = PBXGroup;
children = (
E7322157B64E41A54727F1B5 /* Pods_Runner.framework */,
);
name = Frameworks;
sourceTree = "<group>";
};
9740EEB11CF90186004384FC /* Flutter */ = { 9740EEB11CF90186004384FC /* Flutter */ = {
isa = PBXGroup; isa = PBXGroup;
children = ( children = (
@ -72,6 +97,8 @@
9740EEB11CF90186004384FC /* Flutter */, 9740EEB11CF90186004384FC /* Flutter */,
97C146F01CF9000F007C117D /* Runner */, 97C146F01CF9000F007C117D /* Runner */,
97C146EF1CF9000F007C117D /* Products */, 97C146EF1CF9000F007C117D /* Products */,
1CA2C3BE126DAC67B3E72712 /* Pods */,
8E9103B40D6588B574AD43FA /* Frameworks */,
); );
sourceTree = "<group>"; sourceTree = "<group>";
}; };
@ -105,12 +132,14 @@
isa = PBXNativeTarget; isa = PBXNativeTarget;
buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */; buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */;
buildPhases = ( buildPhases = (
3A5C4CD1EE7C597400A4EF9C /* [CP] Check Pods Manifest.lock */,
9740EEB61CF901F6004384FC /* Run Script */, 9740EEB61CF901F6004384FC /* Run Script */,
97C146EA1CF9000F007C117D /* Sources */, 97C146EA1CF9000F007C117D /* Sources */,
97C146EB1CF9000F007C117D /* Frameworks */, 97C146EB1CF9000F007C117D /* Frameworks */,
97C146EC1CF9000F007C117D /* Resources */, 97C146EC1CF9000F007C117D /* Resources */,
9705A1C41CF9048500538489 /* Embed Frameworks */, 9705A1C41CF9048500538489 /* Embed Frameworks */,
3B06AD1E1E4923F5004D2608 /* Thin Binary */, 3B06AD1E1E4923F5004D2608 /* Thin Binary */,
C63F8C1A7AF68913C333DE72 /* [CP] Embed Pods Frameworks */,
); );
buildRules = ( buildRules = (
); );
@ -169,6 +198,28 @@
/* End PBXResourcesBuildPhase section */ /* End PBXResourcesBuildPhase section */
/* Begin PBXShellScriptBuildPhase section */ /* Begin PBXShellScriptBuildPhase section */
3A5C4CD1EE7C597400A4EF9C /* [CP] Check Pods Manifest.lock */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
);
inputFileListPaths = (
);
inputPaths = (
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
"${PODS_ROOT}/Manifest.lock",
);
name = "[CP] Check Pods Manifest.lock";
outputFileListPaths = (
);
outputPaths = (
"$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt",
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
showEnvVarsInLog = 0;
};
3B06AD1E1E4923F5004D2608 /* Thin Binary */ = { 3B06AD1E1E4923F5004D2608 /* Thin Binary */ = {
isa = PBXShellScriptBuildPhase; isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647; buildActionMask = 2147483647;
@ -197,6 +248,23 @@
shellPath = /bin/sh; shellPath = /bin/sh;
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build"; shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build";
}; };
C63F8C1A7AF68913C333DE72 /* [CP] Embed Pods Frameworks */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
);
inputFileListPaths = (
"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-input-files.xcfilelist",
);
name = "[CP] Embed Pods Frameworks";
outputFileListPaths = (
"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-output-files.xcfilelist",
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks.sh\"\n";
showEnvVarsInLog = 0;
};
/* End PBXShellScriptBuildPhase section */ /* End PBXShellScriptBuildPhase section */
/* Begin PBXSourcesBuildPhase section */ /* Begin PBXSourcesBuildPhase section */

View file

@ -4,4 +4,7 @@
<FileRef <FileRef
location = "group:Runner.xcodeproj"> location = "group:Runner.xcodeproj">
</FileRef> </FileRef>
<FileRef
location = "group:Pods/Pods.xcodeproj">
</FileRef>
</Workspace> </Workspace>

View file

@ -2,6 +2,11 @@
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0"> <plist version="1.0">
<dict> <dict>
<key>CFBundleLocalizations</key>
<array>
<string>Czech</string>
<string>en</string>
</array>
<key>CFBundleDevelopmentRegion</key> <key>CFBundleDevelopmentRegion</key>
<string>$(DEVELOPMENT_LANGUAGE)</string> <string>$(DEVELOPMENT_LANGUAGE)</string>
<key>CFBundleDisplayName</key> <key>CFBundleDisplayName</key>
@ -43,5 +48,7 @@
</array> </array>
<key>UIViewControllerBasedStatusBarAppearance</key> <key>UIViewControllerBasedStatusBarAppearance</key>
<false/> <false/>
<key>CADisableMinimumFrameDurationOnPhone</key>
<true/>
</dict> </dict>
</plist> </plist>

View file

@ -7,6 +7,8 @@ abstract class Languages {
String get appName; String get appName;
String get home;
// Login // Login
String get errorContacting; String get errorContacting;
@ -37,6 +39,8 @@ abstract class Languages {
String get loginFailed; String get loginFailed;
String get warning;
// Jídelníček // Jídelníček
String get loading; String get loading;
@ -99,6 +103,10 @@ abstract class Languages {
String get order; String get order;
// About
String get usedLibs;
// Settings // Settings
String get settings; String get settings;

View file

@ -38,6 +38,9 @@ class LanguageCz extends Languages {
@override @override
String get friday => "Pátek"; String get friday => "Pátek";
@override
String get home => "Domů";
@override @override
String get httpLogin => String get httpLogin =>
"Snažíte se přihlásit přes nešifrované spojení HTTP, jste si jisti, že tak chcete učinit?"; "Snažíte se přihlásit přes nešifrované spojení HTTP, jste si jisti, že tak chcete učinit?";
@ -130,12 +133,18 @@ class LanguageCz extends Languages {
@override @override
String get tuesday => "Úterý"; String get tuesday => "Úterý";
@override
String get usedLibs => "Použité knihovny:";
@override @override
String get username => "Uživatelské jméno"; String get username => "Uživatelské jméno";
@override @override
String get verifyExchange => "Opravdu chcete vložit jídlo na burzu?"; String get verifyExchange => "Opravdu chcete vložit jídlo na burzu?";
@override
String get warning => "Pozor!";
@override @override
String get wednesday => "Středa"; String get wednesday => "Středa";

View file

@ -2,143 +2,153 @@ import 'package:opencanteen/lang/lang.dart';
class LanguageEn extends Languages { class LanguageEn extends Languages {
@override @override
String get about => "O Aplikaci"; String get about => "About";
@override @override
String get agree => "Souhlasím"; String get agree => "I agree";
@override @override
String get appName => "OpenCanteen"; String get appName => "OpenCanteen";
@override @override
String get balance => "Kredit: "; String get balance => "Balance: ";
@override @override
String get cannotOrder => "Nelze objednat"; String get cannotOrder => "Cannot order";
@override @override
String get close => "Zavřít"; String get close => "Close";
@override @override
String get disagree => "Nesouhlasím"; String get disagree => "I disagree";
@override @override
String get errorContacting => String get errorContacting =>
"Nastala chyba při kontaktování serveru, zkontrolujte připojení"; "Failed to contact the server, check your connection.";
@override @override
String get errorOrdering => "Jídlo se nepodařilo objednat"; String get errorOrdering => "Could not order food.";
@override @override
String get exchange => "Burza"; String get exchange => "Exchange";
@override @override
String get exchangeError => "Nepodařilo se vložit jídlo na burzu"; String get exchangeError => "Could not put food on exchange.";
@override @override
String get friday => "Pátek"; String get friday => "Friday";
@override
String get home => "Home";
@override @override
String get httpLogin => String get httpLogin =>
"Snažíte se přihlásit přes nešifrované spojení HTTP, jste si jisti, že tak chcete učinit?"; "You are trying to sign in using an insecure HTTP connection, are you sure you want to continue?";
@override @override
String get iCanteenUrl => "iCanteen URL"; String get iCanteenUrl => "iCanteen URL";
@override @override
String get inExchange => "V BURZE"; String get inExchange => "ON EXCHANGE";
@override @override
String get loading => "Načítání..."; String get loading => "Loading...";
@override @override
String get logIn => "Přihlášení"; String get logIn => "Sign in";
@override @override
String get loggingIn => "Přihlašuji vás..."; String get loggingIn => "Signing you in...";
@override @override
String get loginFailed => "Přihlášení se nezdařilo"; String get loginFailed => "Sign in failed";
@override @override
String get menu => "Jídelníček"; String get menu => "Food Menu";
@override @override
String get monday => "Pondělí"; String get monday => "Monday";
@override @override
String get no => "Ne"; String get no => "No";
@override @override
String get noChange => "Ne, změnit"; String get noChange => "No, change";
@override @override
String get noExchange => "Žádné jídlo v burze"; String get noExchange => "No meal in exchange";
@override @override
String get noFood => "Žádné jídlo pro tento den"; String get noFood => "No meal for this day";
@override @override
String get notOfficial => String get notOfficial =>
"Toto není oficiální aplikace k ovládání iCanteen. Autor neručí za ztráty nebo nefunkčnost v souvislosti s používáním této aplikace. Tato zpráva se znovu neukáže."; "This is not an official app for accessing iCanteen. The author is not responsible for non-functionality or losses while using this app. This message will not appear again.";
@override @override
String get ok => "OK"; String get ok => "OK";
@override @override
String get order => "Objednat"; String get order => "Order";
@override @override
String get orderSuccess => "Jídlo bylo úspěšně objednáno"; String get orderSuccess => "Meal ordered succesfully";
@override @override
String get ordered => "Objednáno"; String get ordered => "Ordered";
@override @override
String get ordering => "Objednávám..."; String get ordering => "Ordering...";
@override @override
String get password => "Heslo"; String get password => "Password";
@override @override
String get pullToReload => "Potáhněte zvrchu pro načtení"; String get pullToReload => "Pull to reload";
@override @override
String get rememberMe => "Zapamatovat si mě"; String get rememberMe => "Remember me";
@override @override
String get reportBugs => "Nahlásit chybu"; String get reportBugs => "Report bug";
@override @override
String get saturday => "Sobota"; String get saturday => "Saturday";
@override @override
String get saveOffline => "Ukládat jídelníček na dnešní den offline"; String get saveOffline => "Save today`s menu offline";
@override @override
String get settings => "Nastavení"; String get settings => "Settings";
@override @override
String get signOut => "Odhlásit se"; String get signOut => "Sign out";
@override @override
String get sunday => "Neděle"; String get sunday => "Sunday";
@override @override
String get thursday => "Čtvrtek"; String get thursday => "Thursday";
@override @override
String get tuesday => "Úterý"; String get tuesday => "Tuesday";
@override @override
String get username => "Uživatelské jméno"; String get usedLibs => "Used libraries:";
@override @override
String get verifyExchange => "Opravdu chcete vložit jídlo na burzu?"; String get username => "Username";
@override @override
String get wednesday => "Středa"; String get verifyExchange =>
"Are you sure you want to put this meal on exchange?";
@override @override
String get yes => "Ano"; String get warning => "Warning!";
@override
String get wednesday => "Wednesday";
@override
String get yes => "Yes";
} }

View file

@ -43,8 +43,8 @@ class MyApp extends StatelessWidget {
AppLocalizationsDelegate(), AppLocalizationsDelegate(),
...GlobalMaterialLocalizations.delegates ...GlobalMaterialLocalizations.delegates
], ],
supportedLocales: const [Locale("cs"), Locale("en")], supportedLocales: const [Locale("cs", ""), Locale("en", "")],
title: 'OpenCanteen', title: "OpenCanteen",
theme: ThemeData( theme: ThemeData(
primarySwatch: Colors.purple, primarySwatch: Colors.purple,
), ),
@ -78,9 +78,8 @@ class _LoginPageState extends State<LoginPage> {
if (connectivityResult == ConnectivityResult.none) { if (connectivityResult == ConnectivityResult.none) {
ScaffoldMessenger.of(context).hideCurrentSnackBar(); ScaffoldMessenger.of(context).hideCurrentSnackBar();
ScaffoldMessenger.of(context).showSnackBar( ScaffoldMessenger.of(context).showSnackBar(
const SnackBar( SnackBar(
content: Text( content: Text(Languages.of(context)!.errorContacting),
"Nastala chyba při kontaktování serveru, zkontrolujte připojení"),
), ),
); );
} }
@ -92,12 +91,12 @@ class _LoginPageState extends State<LoginPage> {
builder: (_) => Dialog( builder: (_) => Dialog(
child: SizedBox( child: SizedBox(
height: 100, height: 100,
child: Row(children: const [ child: Row(children: [
Padding( const Padding(
padding: EdgeInsets.all(10), padding: EdgeInsets.all(10),
child: CircularProgressIndicator(), child: CircularProgressIndicator(),
), ),
Text("Přihlašuji vás") Text(Languages.of(context)!.loggingIn)
]), ]),
), ),
)); ));
@ -106,8 +105,8 @@ class _LoginPageState extends State<LoginPage> {
if (!l) { if (!l) {
ScaffoldMessenger.of(context).hideCurrentSnackBar(); ScaffoldMessenger.of(context).hideCurrentSnackBar();
ScaffoldMessenger.of(context).showSnackBar( ScaffoldMessenger.of(context).showSnackBar(
const SnackBar( SnackBar(
content: Text("Přihlášení se nezdařilo, zkontrolujte údaje"), content: Text(Languages.of(context)!.loginFailed),
), ),
); );
return; return;
@ -128,7 +127,7 @@ class _LoginPageState extends State<LoginPage> {
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Scaffold( return Scaffold(
appBar: AppBar( appBar: AppBar(
title: const Text("Přihlášení"), title: Text(Languages.of(context)!.logIn),
automaticallyImplyLeading: false, automaticallyImplyLeading: false,
), ),
body: Center( body: Center(
@ -138,31 +137,33 @@ class _LoginPageState extends State<LoginPage> {
child: Column( child: Column(
mainAxisAlignment: MainAxisAlignment.center, mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[ children: <Widget>[
const Text( Text(
'OpenCanteen', Languages.of(context)!.logIn,
textAlign: TextAlign.center, textAlign: TextAlign.center,
style: TextStyle(fontWeight: FontWeight.bold, fontSize: 40), style: const TextStyle(
fontWeight: FontWeight.bold, fontSize: 40),
), ),
const Text( Text(
'Přihlášení', Languages.of(context)!.logIn,
textAlign: TextAlign.center, textAlign: TextAlign.center,
), ),
TextField( TextField(
controller: userControl, controller: userControl,
autofillHints: const [AutofillHints.username], autofillHints: const [AutofillHints.username],
decoration: decoration: InputDecoration(
const InputDecoration(labelText: 'Uživatelské jméno'), labelText: Languages.of(context)!.username),
), ),
TextField( TextField(
autofillHints: const [AutofillHints.password], autofillHints: const [AutofillHints.password],
decoration: const InputDecoration(labelText: 'Heslo'), decoration: InputDecoration(
labelText: Languages.of(context)!.password),
controller: passControl, controller: passControl,
obscureText: true, obscureText: true,
), ),
TextField( TextField(
autofillHints: const [AutofillHints.url], autofillHints: const [AutofillHints.url],
decoration: decoration: InputDecoration(
const InputDecoration(labelText: 'iCanteen URL'), labelText: Languages.of(context)!.iCanteenUrl),
keyboardType: TextInputType.url, keyboardType: TextInputType.url,
controller: canteenControl, controller: canteenControl,
), ),
@ -174,7 +175,7 @@ class _LoginPageState extends State<LoginPage> {
rememberMe = value; rememberMe = value;
}); });
}), }),
const Text("Zapamatovat si mě") Text(Languages.of(context)!.rememberMe)
]), ]),
TextButton( TextButton(
onPressed: () async { onPressed: () async {
@ -183,19 +184,21 @@ class _LoginPageState extends State<LoginPage> {
var d = await showDialog<bool>( var d = await showDialog<bool>(
context: context, context: context,
builder: (c) => AlertDialog( builder: (c) => AlertDialog(
title: const Text("Varování!"), title: Text(Languages.of(context)!.warning),
content: const SingleChildScrollView( content: SingleChildScrollView(
child: Text( child: Text(
"Snažíte se přihlásit přes nešifrované spojení HTTP, jste si jisti, že tak chcete učinit?")), Languages.of(context)!.httpLogin)),
actions: [ actions: [
TextButton( TextButton(
onPressed: () => onPressed: () =>
Navigator.pop(c, true), Navigator.pop(c, true),
child: const Text("Ano")), child:
Text(Languages.of(context)!.yes)),
TextButton( TextButton(
onPressed: () => onPressed: () =>
Navigator.pop(c, false), Navigator.pop(c, false),
child: const Text("Ne, změnit")) child: Text(
Languages.of(context)!.noChange))
], ],
)); ));
if (!d!) return; if (!d!) return;
@ -208,19 +211,21 @@ class _LoginPageState extends State<LoginPage> {
var d = await showDialog<bool>( var d = await showDialog<bool>(
context: context, context: context,
builder: (c) => AlertDialog( builder: (c) => AlertDialog(
title: const Text("Pozor"), title: Text(Languages.of(context)!.warning),
content: const SingleChildScrollView( content: SingleChildScrollView(
child: Text( child: Text(Languages.of(context)!
"Toto není oficiální aplikace k ovládání iCanteen. Autor neručí za ztráty nebo nefunkčnost v souvislosti s používáním této aplikace. Tato zpráva se znovu neukáže.")), .notOfficial)),
actions: [ actions: [
TextButton( TextButton(
onPressed: () => onPressed: () =>
Navigator.pop(c, true), Navigator.pop(c, true),
child: const Text("Souhlasím")), child: Text(
Languages.of(context)!.agree)),
TextButton( TextButton(
onPressed: () => onPressed: () =>
Navigator.pop(c, false), Navigator.pop(c, false),
child: const Text("Nesouhlasím")) child: Text(
Languages.of(context)!.disagree))
], ],
)); ));
if (!d!) return; if (!d!) return;
@ -237,9 +242,8 @@ class _LoginPageState extends State<LoginPage> {
if (!l) { if (!l) {
ScaffoldMessenger.of(context).hideCurrentSnackBar(); ScaffoldMessenger.of(context).hideCurrentSnackBar();
ScaffoldMessenger.of(context).showSnackBar( ScaffoldMessenger.of(context).showSnackBar(
const SnackBar( SnackBar(
content: Text( content: Text(Languages.of(context)!.loginFailed),
"Přihlášení se nezdařilo, zkontrolujte údaje"),
), ),
); );
return; return;
@ -257,7 +261,7 @@ class _LoginPageState extends State<LoginPage> {
)), )),
); );
}, },
child: const Text("Přihlásit se")), child: Text(Languages.of(context)!.logIn)),
], ],
), ),
), ),
@ -276,6 +280,7 @@ class AppLocalizationsDelegate extends LocalizationsDelegate<Languages> {
Future<Languages> load(Locale locale) => _load(locale); Future<Languages> load(Locale locale) => _load(locale);
static Future<Languages> _load(Locale locale) async { static Future<Languages> _load(Locale locale) async {
debugPrint(locale.countryCode);
switch (locale.languageCode) { switch (locale.languageCode) {
case 'cs': case 'cs':
return LanguageCz(); return LanguageCz();

View file

@ -1,6 +1,8 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:url_launcher/url_launcher.dart'; import 'package:url_launcher/url_launcher.dart';
import '../lang/lang.dart';
class AboutPage extends StatefulWidget { class AboutPage extends StatefulWidget {
const AboutPage({Key? key}) : super(key: key); const AboutPage({Key? key}) : super(key: key);
@ -13,7 +15,7 @@ class _AboutPageState extends State<AboutPage> {
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Scaffold( return Scaffold(
appBar: AppBar( appBar: AppBar(
title: const Text("O Aplikaci"), title: Text(Languages.of(context)!.about),
), ),
body: SingleChildScrollView( body: SingleChildScrollView(
child: SizedBox( child: SizedBox(
@ -26,7 +28,8 @@ class _AboutPageState extends State<AboutPage> {
"https://github.com/hernikplays/opencanteen/blob/main/LICENSE"), "https://github.com/hernikplays/opencanteen/blob/main/LICENSE"),
child: const Text("Vydáno pod licencí GNU GPLv3")), child: const Text("Vydáno pod licencí GNU GPLv3")),
const SizedBox(height: 15), const SizedBox(height: 15),
const Text("Použité knihovny:", style: TextStyle(fontSize: 19)), Text(Languages.of(context)!.usedLibs,
style: const TextStyle(fontSize: 19)),
const SizedBox(height: 10), const SizedBox(height: 10),
cudlik( cudlik(
"Flutter", "Flutter",

View file

@ -2,6 +2,7 @@ import 'package:canteenlib/canteenlib.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:opencanteen/util.dart'; import 'package:opencanteen/util.dart';
import '../lang/lang.dart';
import '../main.dart'; import '../main.dart';
class BurzaPage extends StatefulWidget { class BurzaPage extends StatefulWidget {
@ -16,7 +17,7 @@ class BurzaPage extends StatefulWidget {
class _BurzaPageState extends State<BurzaPage> { class _BurzaPageState extends State<BurzaPage> {
List<Widget> obsah = []; List<Widget> obsah = [];
double kredit = 0.0; double kredit = 0.0;
Future<void> nactiBurzu() async { Future<void> nactiBurzu(BuildContext context) async {
obsah = [const CircularProgressIndicator()]; obsah = [const CircularProgressIndicator()];
widget.canteen.ziskejUzivatele().then((kr) { widget.canteen.ziskejUzivatele().then((kr) {
kredit = kr.kredit; kredit = kr.kredit;
@ -25,11 +26,11 @@ class _BurzaPageState extends State<BurzaPage> {
obsah = []; obsah = [];
if (burza.isEmpty) { if (burza.isEmpty) {
obsah = [ obsah = [
const Text( Text(
"Žádné jídlo v burze.", Languages.of(context)!.noExchange,
style: TextStyle(fontSize: 20), style: const TextStyle(fontSize: 20),
), ),
const Text("Potáhněte zvrchu pro načtení.") Text(Languages.of(context)!.pullToReload)
]; ];
} else { } else {
for (var b in burza) { for (var b in burza) {
@ -54,12 +55,12 @@ class _BurzaPageState extends State<BurzaPage> {
showDialog( showDialog(
context: context, context: context,
builder: (context) => AlertDialog( builder: (context) => AlertDialog(
title: const Text("Objednáno"), title: Text(Languages.of(context)!.ordered),
content: const Text( content: Text(
"Jídlo bylo úspěšně objednáno."), Languages.of(context)!.orderSuccess),
actions: [ actions: [
TextButton( TextButton(
child: const Text("OK"), child: Text(Languages.of(context)!.ok),
onPressed: () => onPressed: () =>
Navigator.of(context).pop(), Navigator.of(context).pop(),
) )
@ -70,12 +71,13 @@ class _BurzaPageState extends State<BurzaPage> {
showDialog( showDialog(
context: context, context: context,
builder: (context) => AlertDialog( builder: (context) => AlertDialog(
title: const Text("Nelze objednat"), title: Text(
content: const Text( Languages.of(context)!.cannotOrder),
"Jídlo se nepodařilo objednat."), content: Text(
Languages.of(context)!.errorOrdering),
actions: [ actions: [
TextButton( TextButton(
child: const Text("OK"), child: Text(Languages.of(context)!.ok),
onPressed: () => onPressed: () =>
Navigator.of(context).pop(), Navigator.of(context).pop(),
) )
@ -83,10 +85,10 @@ class _BurzaPageState extends State<BurzaPage> {
), ),
); );
} }
nactiBurzu(); nactiBurzu(context);
}); });
}, },
child: const Text("Objednat")), child: Text(Languages.of(context)!.order)),
], ],
), ),
), ),
@ -106,7 +108,7 @@ class _BurzaPageState extends State<BurzaPage> {
@override @override
void initState() { void initState() {
super.initState(); super.initState();
nactiBurzu(); nactiBurzu(context);
} }
@override @override
@ -114,14 +116,14 @@ class _BurzaPageState extends State<BurzaPage> {
return Scaffold( return Scaffold(
drawer: drawerGenerator(context, widget.canteen, widget.user, 3), drawer: drawerGenerator(context, widget.canteen, widget.user, 3),
appBar: AppBar( appBar: AppBar(
title: const Text('Burza'), title: Text(Languages.of(context)!.exchange),
), ),
body: RefreshIndicator( body: RefreshIndicator(
child: Center( child: Center(
child: Column( child: Column(
children: [ children: [
const SizedBox(height: 10), const SizedBox(height: 10),
Text("Kredit: $kredit"), Text("${Languages.of(context)!.balance}$kredit"),
const SizedBox(height: 10), const SizedBox(height: 10),
SingleChildScrollView( SingleChildScrollView(
physics: const AlwaysScrollableScrollPhysics(), physics: const AlwaysScrollableScrollPhysics(),
@ -133,7 +135,7 @@ class _BurzaPageState extends State<BurzaPage> {
], ],
), ),
), ),
onRefresh: () => nactiBurzu()), onRefresh: () => nactiBurzu(context)),
); );
} }
} }

View file

@ -9,6 +9,7 @@ import 'package:path_provider/path_provider.dart';
import 'package:shared_preferences/shared_preferences.dart'; import 'package:shared_preferences/shared_preferences.dart';
import 'package:url_launcher/url_launcher.dart'; import 'package:url_launcher/url_launcher.dart';
import '../lang/lang.dart';
import '../main.dart'; import '../main.dart';
import 'about.dart'; import 'about.dart';
@ -22,7 +23,7 @@ class JidelnicekPage extends StatefulWidget {
} }
class _JidelnicekPageState extends State<JidelnicekPage> { class _JidelnicekPageState extends State<JidelnicekPage> {
List<Widget> obsah = [const Text("Načítám...")]; List<Widget> obsah = [const CircularProgressIndicator()];
DateTime den = DateTime.now(); DateTime den = DateTime.now();
String denTydne = ""; String denTydne = "";
double kredit = 0.0; double kredit = 0.0;
@ -30,25 +31,25 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
obsah = [const CircularProgressIndicator()]; obsah = [const CircularProgressIndicator()];
switch (den.weekday) { switch (den.weekday) {
case 2: case 2:
denTydne = "Úterý"; denTydne = Languages.of(context)!.tuesday;
break; break;
case 3: case 3:
denTydne = "Středa"; denTydne = Languages.of(context)!.wednesday;
break; break;
case 4: case 4:
denTydne = "Čtvrtek"; denTydne = Languages.of(context)!.thursday;
break; break;
case 5: case 5:
denTydne = "Pátek"; denTydne = Languages.of(context)!.friday;
break; break;
case 6: case 6:
denTydne = "Sobota"; denTydne = Languages.of(context)!.saturday;
break; break;
case 7: case 7:
denTydne = "Neděle"; denTydne = Languages.of(context)!.sunday;
break; break;
default: default:
denTydne = "Pondělí"; denTydne = Languages.of(context)!.monday;
} }
widget.canteen.ziskejUzivatele().then((kr) { widget.canteen.ziskejUzivatele().then((kr) {
kredit = kr.kredit; kredit = kr.kredit;
@ -56,9 +57,9 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
setState(() { setState(() {
obsah = []; obsah = [];
if (jd.jidla.isEmpty) { if (jd.jidla.isEmpty) {
obsah.add(const Text( obsah.add(Text(
"Žádné jídlo pro tento den", Languages.of(context)!.noFood,
style: TextStyle(fontSize: 15), style: const TextStyle(fontSize: 15),
)); ));
} else { } else {
for (var j in jd.jidla) { for (var j in jd.jidla) {
@ -76,7 +77,9 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
j.nazev, j.nazev,
), ),
), ),
Text((j.naBurze) ? "V BURZE" : "${j.cena}"), Text((j.naBurze)
? Languages.of(context)!.inExchange
: "${j.cena}"),
Checkbox( Checkbox(
value: j.objednano, value: j.objednano,
fillColor: (j.lzeObjednat) fillColor: (j.lzeObjednat)
@ -95,12 +98,12 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
builder: (_) => Dialog( builder: (_) => Dialog(
child: SizedBox( child: SizedBox(
height: 100, height: 100,
child: Row(children: const [ child: Row(children: [
Padding( const Padding(
padding: EdgeInsets.all(10), padding: EdgeInsets.all(10),
child: CircularProgressIndicator(), child: CircularProgressIndicator(),
), ),
Text("Objednávám...") Text(Languages.of(context)!.ordering)
]), ]),
), ),
)); ));
@ -112,12 +115,12 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
showDialog( showDialog(
context: context, context: context,
builder: (bc) => AlertDialog( builder: (bc) => AlertDialog(
title: const Text( title: Text(
"Jídlo se nepodařilo objednat."), Languages.of(context)!.errorOrdering),
content: Text(o.toString()), content: Text(o.toString()),
actions: [ actions: [
TextButton( TextButton(
child: const Text("Zavřít"), child: Text(Languages.of(context)!.close),
onPressed: () { onPressed: () {
Navigator.pop(bc); Navigator.pop(bc);
}, },
@ -133,20 +136,20 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
var d = await showDialog( var d = await showDialog(
context: context, context: context,
builder: (bc) => SimpleDialog( builder: (bc) => SimpleDialog(
title: const Text( title: Text(
"Opravdu chcete vložit jídlo na burzu?"), Languages.of(context)!.verifyExchange),
children: [ children: [
SimpleDialogOption( SimpleDialogOption(
onPressed: () { onPressed: () {
Navigator.pop(bc, true); Navigator.pop(bc, true);
}, },
child: const Text("Ano"), child: Text(Languages.of(context)!.yes),
), ),
SimpleDialogOption( SimpleDialogOption(
onPressed: () { onPressed: () {
Navigator.pop(bc, false); Navigator.pop(bc, false);
}, },
child: const Text("Ne"), child: Text(Languages.of(context)!.no),
), ),
], ],
)); ));
@ -158,12 +161,13 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
showDialog( showDialog(
context: context, context: context,
builder: (bc) => AlertDialog( builder: (bc) => AlertDialog(
title: const Text( title: Text(
"Nepodařilo se vložit jídlo na burzu"), Languages.of(context)!.exchangeError),
content: Text(o.toString()), content: Text(o.toString()),
actions: [ actions: [
TextButton( TextButton(
child: const Text("Zavřít"), child: Text(
Languages.of(context)!.close),
onPressed: () { onPressed: () {
Navigator.pop(bc); Navigator.pop(bc);
}, },
@ -192,21 +196,17 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
}); });
} }
void kliknuti(String value) { void kliknuti(String value, BuildContext context) {
switch (value) { if (value == Languages.of(context)!.signOut) {
case 'Odhlásit se':
const storage = FlutterSecureStorage(); const storage = FlutterSecureStorage();
storage.deleteAll(); storage.deleteAll();
Navigator.pushReplacement( Navigator.pushReplacement(
context, MaterialPageRoute(builder: (c) => const LoginPage())); context, MaterialPageRoute(builder: (c) => const LoginPage()));
break; } else if (value == Languages.of(context)!.reportBugs) {
case 'Nahlásit chybu':
launch("https://github.com/hernikplays/opencanteen/issues/new/choose"); launch("https://github.com/hernikplays/opencanteen/issues/new/choose");
break; } else if (value == Languages.of(context)!.about) {
case 'O Aplikaci':
Navigator.push( Navigator.push(
context, MaterialPageRoute(builder: (c) => const AboutPage())); context, MaterialPageRoute(builder: (c) => const AboutPage()));
break;
} }
} }
@ -241,8 +241,8 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
} }
@override @override
void initState() { void didChangeDependencies() {
super.initState(); super.didChangeDependencies();
ulozitDnesekOffline(); ulozitDnesekOffline();
nactiJidlo(); nactiJidlo();
} }
@ -252,13 +252,16 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
return Scaffold( return Scaffold(
drawer: drawerGenerator(context, widget.canteen, widget.user, 1), drawer: drawerGenerator(context, widget.canteen, widget.user, 1),
appBar: AppBar( appBar: AppBar(
title: const Text('Jídelníček'), title: Text(Languages.of(context)!.menu),
actions: [ actions: [
PopupMenuButton( PopupMenuButton(
onSelected: kliknuti, onSelected: ((String value) => kliknuti(value, context)),
itemBuilder: (BuildContext context) { itemBuilder: (BuildContext context) {
return {'Nahlásit chybu', 'O Aplikaci', 'Odhlásit se'} return {
.map((String choice) { Languages.of(context)!.reportBugs,
Languages.of(context)!.about,
Languages.of(context)!.signOut
}.map((String choice) {
return PopupMenuItem<String>( return PopupMenuItem<String>(
value: choice, value: choice,
child: Text(choice), child: Text(choice),
@ -274,7 +277,7 @@ class _JidelnicekPageState extends State<JidelnicekPage> {
child: Column( child: Column(
children: [ children: [
const SizedBox(height: 10), const SizedBox(height: 10),
Text("Kredit: $kredit"), Text("${Languages.of(context)!.balance}$kredit"),
Row(mainAxisAlignment: MainAxisAlignment.center, children: [ Row(mainAxisAlignment: MainAxisAlignment.center, children: [
IconButton( IconButton(
onPressed: () { onPressed: () {

View file

@ -2,6 +2,7 @@ import 'package:canteenlib/canteenlib.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:opencanteen/okna/burza.dart'; import 'package:opencanteen/okna/burza.dart';
import 'lang/lang.dart';
import 'okna/jidelnicek.dart'; import 'okna/jidelnicek.dart';
Drawer drawerGenerator( Drawer drawerGenerator(
@ -13,18 +14,18 @@ Drawer drawerGenerator(
drawer = Drawer( drawer = Drawer(
child: ListView( child: ListView(
children: [ children: [
const DrawerHeader( DrawerHeader(
child: Text("OpenCanteen"), child: Text(Languages.of(context)!.appName),
), ),
ListTile( ListTile(
selected: true, selected: true,
title: const Text("Domů"), title: Text(Languages.of(context)!.home),
leading: const Icon(Icons.home), leading: const Icon(Icons.home),
onTap: () => Navigator.pop(context), onTap: () => Navigator.pop(context),
), ),
ListTile( ListTile(
leading: const Icon(Icons.store), leading: const Icon(Icons.store),
title: const Text('Burza'), title: Text(Languages.of(context)!.exchange),
onTap: () => Navigator.push( onTap: () => Navigator.push(
context, context,
MaterialPageRoute( MaterialPageRoute(
@ -41,12 +42,12 @@ Drawer drawerGenerator(
drawer = Drawer( drawer = Drawer(
child: ListView( child: ListView(
children: [ children: [
const DrawerHeader( DrawerHeader(
child: Text("OpenCanteen"), child: Text(Languages.of(context)!.appName),
), ),
ListTile( ListTile(
leading: const Icon(Icons.home), leading: const Icon(Icons.home),
title: const Text("Domů"), title: Text(Languages.of(context)!.home),
onTap: () => Navigator.push( onTap: () => Navigator.push(
context, context,
MaterialPageRoute( MaterialPageRoute(
@ -56,7 +57,7 @@ Drawer drawerGenerator(
ListTile( ListTile(
leading: const Icon(Icons.store), leading: const Icon(Icons.store),
selected: true, selected: true,
title: const Text('Burza'), title: Text(Languages.of(context)!.exchange),
onTap: () => Navigator.pop(context), onTap: () => Navigator.pop(context),
), ),
], ],

View file

@ -56,7 +56,7 @@ packages:
name: collection name: collection
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.15.0" version: "1.16.0"
connectivity_plus: connectivity_plus:
dependency: "direct main" dependency: "direct main"
description: description:
@ -232,7 +232,7 @@ packages:
name: js name: js
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "0.6.3" version: "0.6.4"
lints: lints:
dependency: transitive dependency: transitive
description: description:
@ -246,7 +246,7 @@ packages:
name: material_color_utilities name: material_color_utilities
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "0.1.3" version: "0.1.4"
meta: meta:
dependency: transitive dependency: transitive
description: description:
@ -267,7 +267,7 @@ packages:
name: path name: path
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.8.0" version: "1.8.1"
path_provider: path_provider:
dependency: "direct main" dependency: "direct main"
description: description:
@ -496,7 +496,7 @@ packages:
name: vector_math name: vector_math
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.1" version: "2.1.2"
win32: win32:
dependency: transitive dependency: transitive
description: description:
@ -526,5 +526,5 @@ packages:
source: hosted source: hosted
version: "3.1.0" version: "3.1.0"
sdks: sdks:
dart: ">=2.16.1 <3.0.0" dart: ">=2.17.0-0 <3.0.0"
flutter: ">=2.10.0" flutter: ">=2.10.0"