// SPDX-License-Identifier: Apache-2.0

import 'dart:io';

import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_hvac/vehicle-signals/vss_client.dart';
import 'package:flutter_hvac/vehicle-signals/vss_provider.dart';
import 'package:flutter_hvac/Buttons/fresh_air.dart';
import 'package:flutter_svg_provider/flutter_svg_provider.dart';
import 'package:flutter_hvac/Buttons/AC.dart';
import 'package:flutter_hvac/Buttons/ac_on_face.dart';
import 'package:flutter_hvac/Buttons/ac_on_foot.dart';
import 'package:flutter_hvac/Buttons/defrost_recirculate.dart';
import 'package:flutter_hvac/size.dart';

import 'Buttons/auto.dart';
import 'widgets/left_climate.dart';
import 'widgets/right_climate.dart';
import 'widgets/slider.dart';

class HomePage extends ConsumerStatefulWidget {
  const HomePage({Key? key}) : super(key: key);

  @override
  _HomePageState createState() => _HomePageState();
}

class _HomePageState extends ConsumerState<HomePage> {
  late VssClient vss;

  initState() {
    vss = ref.read(vssClientProvider);
    vss.run();

    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    SizeConfig().init(context);

    return Scaffold(
        backgroundColor: Colors.black,
        body: Theme(
          data: Theme.of(context).copyWith(
            // Disable splash animations
            splashFactory: NoSplash.splashFactory,
            hoverColor: Colors.transparent,
          ),
          child: Flex(
            direction: Axis.vertical,
            children: [
              Container(height: SizeConfig.screenHeight * 0.0125),
              Flexible(
                  flex: 4,
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                    children: [
                      Column(
                        children: [
                          Text(
                            'Left',
                            style: TextStyle(
                              fontSize: SizeConfig.fontsize * 4,
                              fontWeight: FontWeight.w700,
                              color: Colors.lightBlueAccent,
                            ),
                          ),
                          SizedBox(
                            height: SizeConfig.screenHeight / 10,
                            width: SizeConfig.screenWidth / 10,
                            child: Image.asset('images/left_climate.PNG')),
                          LeftClimateScrollWidget(),
                        ],
                      ),
                      Column(
                        children: [
                          Text(
                            'Right',
                            style: TextStyle(
                              fontSize: SizeConfig.fontsize * 4,
                              fontWeight: FontWeight.w700,
                              color: Colors.lightBlueAccent,
                            ),
                          ),
                          SizedBox(
                            height: SizeConfig.screenHeight / 10,
                            width: SizeConfig.screenWidth / 10,
                            child: Image.asset('images/right_climate.PNG')),
                          RightClimateScrollWidget(),
                        ],
                      ),
                    ],
                  )),
              Flexible(
                  flex: 2,
                  child: Row(
                    crossAxisAlignment: CrossAxisAlignment.center,
                    mainAxisAlignment: MainAxisAlignment.center,
                    children: [
                      Container(
                          height: SizeConfig.screenHeight * 0.20,
                          child: Image(
                              width: SizeConfig.screenWidth * 0.20,
                              height: SizeConfig.screenHeight * 0.25,
                              image: Svg('images/fan.svg'),
                              color: Colors.lightBlueAccent,
                              fit: BoxFit.fitWidth)),
                      SliderControl(),
                    ],
                  )),
              Flexible(
                  flex: 3,
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                    children: [
                      Column(
                        children: [
                          AC(),
                          SizedBox(
                            height: SizeConfig.safeBlockVertical,
                          ),
                          AcOnFoot(img: 'images/ac_on_foot.svg'),
                          SizedBox(
                            height: SizeConfig.safeBlockVertical,
                          ),
                          AcOnFace(img: 'images/ac_on_face.svg'),
                        ],
                      ),
                      Row(
                        children: [
                          Auto(),
                          SizedBox(
                            width: SizeConfig.safeBlockHorizontal,
                          ),
                          FreshAir(img: 'images/wind_in.svg'),
                        ],
                      ),
                      Column(
                        children: [
                          CustomButton(
                            img: 'images/in_out.svg',
                            type: 'Recirculation'),
                          SizedBox(
                            height: SizeConfig.safeBlockVertical,
                          ),
                          CustomButton(
                            img: 'images/rear_ws.svg',
                            type: 'Rear_defrost'),
                          SizedBox(
                            height: SizeConfig.safeBlockVertical,
                          ),
                          CustomButton(
                            img: 'images/wind_shield.svg',
                            type: 'Front_defrost'),
                        ],
                      ),
                    ],
                  )),
            ],
          ),
        ));
  }
}