Cadastrar
Login
Novo texto
Português
English
Português
Cadastrar
Login
Novo Texto
Importar Arquivo
import 'dart:async'; import 'dart:convert'; import 'dart:developer'; import 'package:assessment/services/database_helper.dart'; import 'package:assessment/services/weather_api_client.dart'; import 'package:assessment/views/additional_information.dart'; import 'package:assessment/views/current_weather.dart'; import 'package:assessment/views/current_weather_daily.dart'; import 'package:assessment/widgets/nav_drawer.dart'; import 'package:assessment/widgets/search_place.dart'; import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; import 'package:geolocator/geolocator.dart'; import 'package:provider/provider.dart'; import 'package:shared_preferences/shared_preferences.dart'; import 'model/weather_forecast_model.dart'; import 'model/weather_model.dart'; import 'package:intl/intl.dart'; void main() { WidgetsFlutterBinding.ensureInitialized(); runApp(const MyApp()); } class Test { String tempUnit = "Celsius"; String tempSymbol = 'C'; bool tempBool = true; double? locLat; double? locLng; String? locationQuery; } class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); static final ValueNotifier<ThemeMode> themeNotifier = ValueNotifier(ThemeMode.light); @override Widget build(BuildContext context) { SystemChrome.setPreferredOrientations([ DeviceOrientation.portraitUp, DeviceOrientation.portraitDown, ]); return Provider( create: (_) => Test(), child: ValueListenableBuilder<ThemeMode>( valueListenable: themeNotifier, builder: (_, ThemeMode currentMode, __) { return MaterialApp( // Remove the debug banner debugShowCheckedModeBanner: false, title: 'WeatherApp', theme: ThemeData(primarySwatch: Colors.amber), darkTheme: ThemeData.dark(), themeMode: currentMode, home: HomePage(), ); }, ), ); } } class HomePage extends StatefulWidget { const HomePage({Key? key, String? locationName}) : super(key: key); @override _HomePageState createState() => _HomePageState(); } class _HomePageState extends State<HomePage> { late WeatherApiClient client = WeatherApiClient(); late WeatherForecast? data = WeatherForecast(); late WeatherForecast? searchedData = WeatherForecast(); late SharedPreferences sharedPreferences; var currentLat; var currentLng; Future<WeatherForecast?> getCurrentLocation(BuildContext context) async { sharedPreferences = await SharedPreferences.getInstance(); //Permission LocationPermission permission = await Geolocator.checkPermission(); if (permission == LocationPermission.denied || permission == LocationPermission.deniedForever) { Geolocator.requestPermission(); } else { Position currentPosition = await Geolocator.getCurrentPosition( desiredAccuracy: LocationAccuracy.best); currentLat = currentPosition.latitude; currentLng = currentPosition.longitude; String? locationQuery = sharedPreferences.getString("test"); bool? isRefreshCurrentLoc = sharedPreferences.getBool("isRefreshUserLoc"); if (locationQuery != null && isRefreshCurrentLoc == false) { searchedData = await client.getCurrentWeather(locationQuery); return searchedData; } else { sharedPreferences.setBool("isRefreshCurrentLoc", false); sharedPreferences.setDouble("currentLat", currentLat); sharedPreferences.setDouble("currentLng", currentLng); data = await client.getCurrentWeatherLocation(currentLat, currentLng); return data; } } } Future<WeatherForecast?> getUserLocation(BuildContext context) async { sharedPreferences = await SharedPreferences.getInstance(); //Permission LocationPermission permission = await Geolocator.checkPermission(); if (permission == LocationPermission.denied || permission == LocationPermission.deniedForever) { Geolocator.requestPermission(); } else { Position currentPosition = await Geolocator.getCurrentPosition( desiredAccuracy: LocationAccuracy.best); currentLat = currentPosition.latitude; currentLng = currentPosition.longitude; sharedPreferences.setDouble("currentLat", currentLat); sharedPreferences.setDouble("currentLng", currentLng); data = await client.getCurrentWeatherLocation(currentLat, currentLng); return data; } } Future<WeatherForecast?> getSearchedPlaceData(String locationName) async { searchedData = await client.getCurrentWeather(locationName); return searchedData; } @override Widget build(BuildContext context) { // TODO: implement build var status = false; final test = Provider.of<Test>(context); final test2 = context.watch<Test>(); return Scaffold( appBar: AppBar( elevation: 0.0, title: Text( "Weather App", ), centerTitle: true, // leading: IconButton( // onPressed: () {}, // icon: Icon(Icons.menu), // color: Colors.yellow, // ), actions: [ IconButton( icon: Icon(Icons.search), onPressed: () { Navigator.push( context, MaterialPageRoute(builder: (context) => SearchPlace()), ); }, ), IconButton( icon: Icon(MyApp.themeNotifier.value == ThemeMode.light ? Icons.dark_mode : Icons.light_mode), onPressed: () { MyApp.themeNotifier.value = MyApp.themeNotifier.value == ThemeMode.light ? ThemeMode.dark : ThemeMode.light; }, ), ], ), drawer: NavDrawer(), body: FutureBuilder( future: getCurrentLocation(context), builder: (context, AsyncSnapshot<WeatherForecast?> snapshot) { if (snapshot.connectionState == ConnectionState.done) { if (snapshot.data == null) { return const Center( child: Text('no data'), ); } else { return Container( height: MediaQuery.of(context).size.height, width: MediaQuery.of(context).size.width, child: Column( crossAxisAlignment: CrossAxisAlignment.center, children: [ currentWeather( snapshot.data!.list![0].weather![0].icon as String, snapshot.data!.list![0].main!.temp as double, snapshot.data!.city!.name as String, test2.tempSymbol, ), SizedBox(height: 20.0), FloatingActionButton( onPressed: () { setState(() { DatabaseHelper.instance.createItem( snapshot.data!.list![0].dt, snapshot.data!.list![0].main!.temp, snapshot.data!.list![0].wind!.speed, snapshot.data!.list![0].main!.humidity as int, snapshot.data!.list![0].main!.pressure as int, snapshot.data!.list![0].main!.feelsLike, snapshot.data!.city!.name.toString(), snapshot.data!.list![0].weather![0].icon as String, test2.tempSymbol); }); }, child: const Icon(Icons.favorite), backgroundColor: Colors.green, ), SizedBox( height: 60.0, ), Expanded( child: ListView.builder( shrinkWrap: true, itemCount: 5, itemBuilder: (context, index) { if (snapshot.data!.list!.isNotEmpty) { return ListTile( title: // Text(convertUnixToReadable(data!.list![index].dt)), currentWeatherDaily( snapshot.data!.list![index *= 8].dt as int, snapshot.data!.list![index].weather![0] .icon as String, snapshot.data!.list![index].main!.temp as double, test.tempSymbol), subtitle: additionalInformation( snapshot.data!.list![index].wind!.speed as double, snapshot.data!.list![index].main!.humidity as int, snapshot.data!.list![index].main!.pressure as int, snapshot.data!.list![index].main!.feelsLike as double), ); } else { return CircularProgressIndicator(); } }, ), ), FloatingActionButton( onPressed: () { setState(() { sharedPreferences.setBool("isRefreshUserLoc", true); getUserLocation(context); }); }, child: const Icon(Icons.refresh), backgroundColor: Colors.green, ), ], ), ); } // } } else if (snapshot.connectionState == ConnectionState.waiting) { return const Center(child: CircularProgressIndicator()); } return Container(); }, ), ); } String convertUnixToReadable(timestamp) { var converted_timestamp = timestamp * 1000; var date = new DateTime.fromMillisecondsSinceEpoch(converted_timestamp); String dateFormat = 'MM/dd/yy mm:hh:ss'; final DateTime docDateTime = DateTime.parse(date.toString()); var formatted_date = DateFormat(dateFormat).format(docDateTime); var formmated_date_day = DateFormat('EEEE').format(docDateTime); return formmated_date_day + "\n " + formatted_date; } }
Configurações do Texto
Título do Texto :
[Opcional]
Guardar na Pasta :
[Opcional]
Selecionar
Syntax Highlighting :
[Opcional]
Selecionar
Markup
CSS
JavaScript
Bash
C
C#
C++
Java
JSON
Lua
Plaintext
C-like
ABAP
ActionScript
Ada
Apache Configuration
APL
AppleScript
Arduino
ARFF
AsciiDoc
6502 Assembly
ASP.NET (C#)
AutoHotKey
AutoIt
Basic
Batch
Bison
Brainfuck
Bro
CoffeeScript
Clojure
Crystal
Content-Security-Policy
CSS Extras
D
Dart
Diff
Django/Jinja2
Docker
Eiffel
Elixir
Elm
ERB
Erlang
F#
Flow
Fortran
GEDCOM
Gherkin
Git
GLSL
GameMaker Language
Go
GraphQL
Groovy
Haml
Handlebars
Haskell
Haxe
HTTP
HTTP Public-Key-Pins
HTTP Strict-Transport-Security
IchigoJam
Icon
Inform 7
INI
IO
J
Jolie
Julia
Keyman
Kotlin
LaTeX
Less
Liquid
Lisp
LiveScript
LOLCODE
Makefile
Markdown
Markup templating
MATLAB
MEL
Mizar
Monkey
N4JS
NASM
nginx
Nim
Nix
NSIS
Objective-C
OCaml
OpenCL
Oz
PARI/GP
Parser
Pascal
Perl
PHP
PHP Extras
PL/SQL
PowerShell
Processing
Prolog
.properties
Protocol Buffers
Pug
Puppet
Pure
Python
Q (kdb+ database)
Qore
R
React JSX
React TSX
Ren'py
Reason
reST (reStructuredText)
Rip
Roboconf
Ruby
Rust
SAS
Sass (Sass)
Sass (Scss)
Scala
Scheme
Smalltalk
Smarty
SQL
Soy (Closure Template)
Stylus
Swift
TAP
Tcl
Textile
Template Toolkit 2
Twig
TypeScript
VB.Net
Velocity
Verilog
VHDL
vim
Visual Basic
WebAssembly
Wiki markup
Xeora
Xojo (REALbasic)
XQuery
YAML
HTML
Expiração do Texto :
[Opcional]
Nunca
Auto Destruir
10 Minutos
1 Hora
1 Dia
1 Semana
2 Semanas
1 Mês
6 Meses
1 Ano
Status do Texto :
[Opcional]
Público
Não Listado
Privado (somente membros)
Senha :
[Opcional]
Descrição:
[Opcional]
Tags:
[Opcional]
Criptografar Texto
(
?
)
Criar Novo Texto
No momento você não está logado, isso significa que você não pode editar ou excluir nada que você poste.
Cadastre-se
ou faça o
Login
Idiomas do site
×
English
Português
Você gosta de cookies?
🍪 Usamos cookies para garantir que você obtenha a melhor experiência em nosso site.
Saber mais
Concordo