You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

80 lines
1.8 KiB
Dart

import 'package:flutter/material.dart';
import 'package:adv_basics/start_screen.dart';
import 'package:adv_basics/questions_screen.dart';
import 'package:adv_basics/data/questions.dart';
import 'package:adv_basics/results_screen.dart';
class Quiz extends StatefulWidget {
const Quiz({super.key});
@override
State<Quiz> createState() {
return _QuizState();
}
}
class _QuizState extends State<Quiz> {
List<String> _selectedAnswers = [];
var _activeScreen = 'start-screen';
void _switchScreen() {
setState(() {
_activeScreen = 'questions-screen';
});
}
void _chooseAnswer(String answer) {
_selectedAnswers.add(answer);
if (_selectedAnswers.length == questions.length) {
setState(() {
_activeScreen = 'results-screen';
});
}
}
void restartQuiz() {
setState(() {
_selectedAnswers.clear();
_activeScreen = 'questions-screen';
});
}
@override
Widget build(context) {
Widget screenWidget = StartScreen(_switchScreen);
if (_activeScreen == 'questions-screen') {
screenWidget = QuestionsScreen(
onSelectAnswer: _chooseAnswer,
);
}
if (_activeScreen == 'results-screen') {
screenWidget = ResultsScreen(
chosenAnswers: _selectedAnswers,
onRestart: restartQuiz,
);
}
return MaterialApp(
home: Scaffold(
body: Container(
decoration: const BoxDecoration(
gradient: LinearGradient(
colors: [
Color.fromARGB(255, 78, 13, 151),
Color.fromARGB(255, 107, 15, 168),
],
begin: Alignment.topLeft,
end: Alignment.bottomRight,
),
),
child: screenWidget,
),
),
);
}
}