summaryrefslogtreecommitdiffstats
path: root/lib/presentation/screens/weather
diff options
context:
space:
mode:
authorLisandro Pérez Meyer <lpmeyer@ics.com>2023-11-14 17:20:58 -0300
committerLisandro Pérez Meyer <lpmeyer@ics.com>2023-11-14 17:31:12 -0300
commit70ec8a79a121471a004e7e4c23157d10157e136f (patch)
treea4f9c0a4fac4e4274ec4324a289b6ef62e1c5653 /lib/presentation/screens/weather
Initial cleanup push.
Based on agldemo2024 on commit 2a5dc04d801134338150c3f6afc67eaa65599763 Disable device preview. Disable Lottie animation. The original commit was b3c493c340fcb4bb0a937692838fc830bec3e9ea but I am just keeping this change, because the json did not really needed to change. I think. Signed-off-by: Lisandro Pérez Meyer <lpmeyer@ics.com>
Diffstat (limited to 'lib/presentation/screens/weather')
-rw-r--r--lib/presentation/screens/weather/hourly_forecast.dart152
-rw-r--r--lib/presentation/screens/weather/weather.dart91
2 files changed, 243 insertions, 0 deletions
diff --git a/lib/presentation/screens/weather/hourly_forecast.dart b/lib/presentation/screens/weather/hourly_forecast.dart
new file mode 100644
index 0000000..aed8a6c
--- /dev/null
+++ b/lib/presentation/screens/weather/hourly_forecast.dart
@@ -0,0 +1,152 @@
+import 'package:flutter_ics_homescreen/export.dart';
+
+class HourlyForecast extends StatefulWidget {
+ const HourlyForecast({super.key});
+
+ @override
+ State<HourlyForecast> createState() => _HourlyForecastState();
+}
+
+class _HourlyForecastState extends State<HourlyForecast> {
+ String selectedForescastTime = "13:00";
+ List<ForecastModel> foreCastList = [
+ ForecastModel(
+ time: "13:00", image: "assets/weatherStat.svg", weather: "29.1°"),
+ ForecastModel(
+ time: "14:00", image: "assets/weatherStat.svg", weather: "28.1°"),
+ ForecastModel(
+ time: "15:00", image: "assets/weatherStat.svg", weather: "27.1°"),
+ ForecastModel(
+ time: "16:00", image: "assets/weatherStat.svg", weather: "29.1°"),
+ ForecastModel(
+ time: "13:00", image: "assets/weatherStat.svg", weather: "29.1°"),
+ ForecastModel(
+ time: "14:00", image: "assets/weatherStat.svg", weather: "28.1°"),
+ ForecastModel(
+ time: "15:00", image: "assets/weatherStat.svg", weather: "27.1°"),
+ ForecastModel(
+ time: "16:00", image: "assets/weatherStat.svg", weather: "29.1°"),
+ ];
+ @override
+ Widget build(BuildContext context) {
+ double weatherIconSize = 126;
+ return Container(
+ padding: const EdgeInsets.all(1),
+ decoration: BoxDecoration(
+ gradient: LinearGradient(colors: [
+ AGLDemoColors.periwinkleColor.withOpacity(0.2),
+ AGLDemoColors.periwinkleColor
+ ]),
+ boxShadow: [
+ BoxShadow(
+ offset: const Offset(1, 2),
+ blurRadius: 16,
+ color: Colors.black.withOpacity(0.5))
+ ],
+ borderRadius: BorderRadius.circular(40),
+ // border: Border.all(color: Colors.white12),
+ ),
+ child: Container(
+ padding: const EdgeInsets.only(top: 5, bottom: 20, left: 5, right: 5),
+ decoration: BoxDecoration(
+ borderRadius: BorderRadius.circular(40),
+ // border: Border.all(color: AGLDemoColors.periwinkleColor),
+ // boxShadow: [
+ // BoxShadow(
+ // offset: const Offset(1, 2),
+ // blurRadius: 16,
+ // color: Colors.black.withOpacity(0.5))
+ // ],
+ gradient: const RadialGradient(
+ //center: Alignment(0.7, -0.6), // near the top right
+ radius: 1,
+ colors: <Color>[
+ Color.fromARGB(255, 12, 16, 57), // yellow sun
+ Color.fromARGB(255, 0, 0, 0), // blue sky
+ ],
+ ),
+ ),
+ child:
+ Column(crossAxisAlignment: CrossAxisAlignment.stretch, children: [
+ Padding(
+ padding: const EdgeInsets.symmetric(horizontal: 25, vertical: 10),
+ child: Row(
+ mainAxisAlignment: MainAxisAlignment.spaceBetween,
+ children: [
+ const Text(
+ "Hourly Forecast",
+ style: TextStyle(
+ color: Colors.white,
+ fontWeight: FontWeight.w500,
+ fontSize: 44),
+ ),
+ Text(
+ "March 9",
+ style: GoogleFonts.firaSans(
+ color: Colors.white,
+ fontWeight: FontWeight.w200,
+ fontSize: 44),
+ ),
+ ]),
+ ),
+ const SizedBox(
+ height: 20,
+ ),
+ SizedBox(
+ height: 320,
+ child: ListView.builder(
+ itemCount: foreCastList.length,
+ shrinkWrap: true,
+ padding: EdgeInsets.zero,
+ scrollDirection: Axis.horizontal,
+ itemBuilder: (context, index) {
+ return Container(
+ margin: const EdgeInsets.symmetric(horizontal: 32),
+ decoration: BoxDecoration(
+ borderRadius: BorderRadius.circular(32),
+ color: foreCastList[index].time == selectedForescastTime
+ ? AGLDemoColors.resolutionBlueColor
+ : Colors.transparent),
+ padding: const EdgeInsets.symmetric(
+ horizontal: 18, vertical: 10),
+ child: Column(
+ mainAxisAlignment: MainAxisAlignment.center,
+ children: [
+ Text(
+ foreCastList[index].time,
+ style: GoogleFonts.firaSans(
+ fontWeight: FontWeight.w100,
+ color: Colors.white,
+ fontSize: 40),
+ ),
+ Padding(
+ padding: const EdgeInsets.symmetric(vertical: 30),
+ child: SvgPicture.asset(
+ "assets/weatherStat.svg",
+ width: weatherIconSize,
+ height: weatherIconSize,
+ ),
+ ),
+ Text(
+ foreCastList[index].weather,
+ style: const TextStyle(
+ color: Colors.white, fontSize: 40),
+ ),
+ ]),
+ );
+ }),
+ )
+ ]),
+ ),
+ );
+ }
+}
+
+class ForecastModel {
+ final String time;
+ final String image;
+ final String weather;
+
+ ForecastModel(
+ {required this.time, required this.image, required this.weather});
+}
diff --git a/lib/presentation/screens/weather/weather.dart b/lib/presentation/screens/weather/weather.dart
new file mode 100644
index 0000000..7231700
--- /dev/null
+++ b/lib/presentation/screens/weather/weather.dart
@@ -0,0 +1,91 @@
+import 'package:flutter_ics_homescreen/export.dart';
+
+class WeatherPage extends ConsumerWidget {
+ const WeatherPage({super.key});
+
+ static Page<void> page() => const MaterialPage<void>(child: WeatherPage());
+ @override
+ Widget build(BuildContext context, WidgetRef ref) {
+ double weatherIconSize = MediaQuery.sizeOf(context).width * 0.278;
+ return Column(
+ crossAxisAlignment: CrossAxisAlignment.stretch,
+ children: [
+ CommonTitle(
+ title: "Weather",
+ hasBackButton: true,
+ onPressed: () {
+ context.flow<AppState>().update((state) => AppState.apps);
+ },
+ ),
+ const SizedBox(
+ height: 25,
+ ),
+ Expanded(
+ child: Padding(
+ padding: const EdgeInsets.symmetric(horizontal: 144),
+ child: SingleChildScrollView(
+ child: Column(
+ children: [
+ const Row(
+ mainAxisAlignment: MainAxisAlignment.center,
+ children: [
+ Icon(
+ Icons.location_on_outlined,
+ color: Colors.white,
+ size: 48,
+ ),
+ SizedBox(
+ width: 7,
+ ),
+ Text(
+ "Fortaleza",
+ style: TextStyle(
+ color: Colors.white,
+ fontSize: 40,
+ fontWeight: FontWeight.w500),
+ ),
+ ],
+ ),
+ const SizedBox(
+ height: 80,
+ ),
+ SvgPicture.asset(
+ "assets/weatherStat.svg",
+ width: weatherIconSize,
+ height: weatherIconSize,
+ ),
+ const SizedBox(
+ height: 60,
+ ),
+ Text(
+ "28.3°C",
+ style: GoogleFonts.brunoAce(
+ color: Colors.white, fontSize: 128),
+ ),
+ const Padding(
+ padding: EdgeInsets.all(30.0),
+ child: Text(
+ "Partially Cloudy",
+ style: TextStyle(color: Colors.white, fontSize: 44),
+ ),
+ ),
+ const SizedBox(
+ height: 5,
+ ),
+ const Text(
+ "Max: 31° Min: 25°",
+ style: TextStyle(color: Colors.white, fontSize: 40),
+ ),
+ const SizedBox(
+ height: 80,
+ ),
+ const HourlyForecast()
+ ],
+ ),
+ ),
+ ),
+ )
+ ],
+ );
+ }
+}