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
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,
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|