2022-03-30 22:39:49 +02:00
|
|
|
import 'package:desktopapp/widgets/components/link.dart';
|
|
|
|
import 'package:desktopapp/widgets/components/row_input.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:shared_preferences/shared_preferences.dart';
|
|
|
|
|
|
|
|
class Step2 extends StatelessWidget {
|
2022-03-31 21:34:28 +02:00
|
|
|
Step2({Key? key, required this.onPrevious, required this.onNext})
|
|
|
|
: super(key: key);
|
|
|
|
|
|
|
|
final VoidCallback onPrevious;
|
|
|
|
final VoidCallback onNext;
|
2022-03-30 22:39:49 +02:00
|
|
|
|
|
|
|
final TextEditingController _clientIdController = TextEditingController();
|
|
|
|
final TextEditingController _clientSecretController = TextEditingController();
|
|
|
|
|
|
|
|
Widget buildContent(BuildContext context) {
|
|
|
|
return Column(children: [
|
|
|
|
const Padding(
|
|
|
|
padding: EdgeInsets.symmetric(vertical: 20),
|
|
|
|
child: Text('Étape 2: Récupération des cléfs Client',
|
|
|
|
style: TextStyle(fontSize: 20)),
|
|
|
|
),
|
|
|
|
const Text(
|
|
|
|
'Pour pouvoir utiliser l\'application, il faut récupérer les clefs associées à l\'application créée juste avant.'),
|
|
|
|
const Text(
|
|
|
|
'Normalement, vous devez voir apparaître une page avec les champs comme dans l\'image ci-dessous.'),
|
|
|
|
const Text('Sinon vous pouvez le retrouver avec le lien ci-dessous:'),
|
|
|
|
const SizedBox(height: 10),
|
|
|
|
const Link(
|
|
|
|
uri: 'https://streamlabs.com/dashboard#/settings/api-settings'),
|
|
|
|
const SizedBox(height: 20),
|
|
|
|
Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(horizontal: 24.0),
|
|
|
|
child: Image.asset('assets/images/client_app_keys.png'),
|
|
|
|
),
|
|
|
|
const SizedBox(height: 20),
|
|
|
|
const Text(
|
|
|
|
'Pour récupérer les clefs, il faut remplir le formulaire ci-dessous avec les valeurs correspondantes à ceux sur le site:'),
|
|
|
|
RowInput(label: 'Client ID', controller: _clientIdController),
|
|
|
|
RowInput(label: 'Client Secret', controller: _clientSecretController),
|
|
|
|
TextButton(
|
|
|
|
onPressed: () async {
|
|
|
|
final prefs = await SharedPreferences.getInstance();
|
|
|
|
prefs.setString('client_id', _clientIdController.text.trim());
|
|
|
|
prefs.setString(
|
|
|
|
'client_secret', _clientSecretController.text.trim());
|
|
|
|
showDialog(
|
|
|
|
context: context,
|
|
|
|
builder: (_) => AlertDialog(
|
|
|
|
title: const Text('Information'),
|
|
|
|
content: const Text(
|
|
|
|
'Les informations ont été correctement enregistrée.'),
|
|
|
|
actions: [
|
|
|
|
TextButton(
|
|
|
|
onPressed: () => Navigator.pop(context),
|
|
|
|
child: const Text('OK'))
|
|
|
|
],
|
|
|
|
));
|
|
|
|
},
|
|
|
|
child: const Text('Appliquer les changements')),
|
|
|
|
const SizedBox(height: 20),
|
|
|
|
const Text(
|
|
|
|
'Une fois les données enregistrées, vous pouvez passez à l\'étape suivante.'),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Column(
|
|
|
|
children: [
|
|
|
|
Expanded(
|
|
|
|
child: FutureBuilder(
|
|
|
|
future: SharedPreferences.getInstance(),
|
|
|
|
builder: (BuildContext context,
|
|
|
|
AsyncSnapshot<SharedPreferences> snapshot) {
|
|
|
|
if (snapshot.hasData) {
|
|
|
|
final prefs = snapshot.data!;
|
|
|
|
_clientIdController.text =
|
|
|
|
prefs.getString('client_id') ?? '';
|
|
|
|
_clientSecretController.text =
|
|
|
|
prefs.getString('client_secret') ?? '';
|
|
|
|
return buildContent(context);
|
|
|
|
} else {
|
|
|
|
return const Center(child: CircularProgressIndicator());
|
|
|
|
}
|
|
|
|
})),
|
|
|
|
Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: 20),
|
|
|
|
child: Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceAround,
|
|
|
|
children: [
|
|
|
|
TextButton(
|
2022-03-31 21:34:28 +02:00
|
|
|
onPressed: onPrevious, child: const Text('Étape précédente')),
|
|
|
|
TextButton(onPressed: onNext, child: const Text('Étape suivante'))
|
2022-03-30 22:39:49 +02:00
|
|
|
],
|
|
|
|
),
|
|
|
|
)
|
|
|
|
],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|