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.
fluffychat/lib/pangea/pages/connect/p_sso_button.dart

110 lines
2.6 KiB
Dart

import 'package:fluffychat/pages/homeserver_picker/homeserver_picker.dart';
import 'package:fluffychat/pangea/pages/sign_up/full_width_button.dart';
import 'package:fluffychat/pangea/utils/error_handler.dart';
import 'package:fluffychat/pangea/utils/sso_login_action.dart';
import 'package:fluffychat/widgets/matrix.dart';
import 'package:flutter/material.dart';
import 'package:flutter_gen/gen_l10n/l10n.dart';
import 'package:flutter_svg/flutter_svg.dart';
import 'package:matrix/matrix_api_lite/model/matrix_exception.dart';
enum SSOProvider { google, apple }
extension on SSOProvider {
String get id {
switch (this) {
case SSOProvider.google:
return "oidc-google";
case SSOProvider.apple:
return "oidc-apple";
}
}
String get name {
switch (this) {
case SSOProvider.google:
return "Google";
case SSOProvider.apple:
return "Apple";
}
}
String get asset {
switch (this) {
case SSOProvider.google:
return "assets/pangea/google.svg";
case SSOProvider.apple:
return "assets/pangea/apple.svg";
}
}
}
class PangeaSsoButton extends StatefulWidget {
final String title;
final SSOProvider provider;
const PangeaSsoButton({
required this.title,
required this.provider,
super.key,
});
@override
PangeaSsoButtonState createState() => PangeaSsoButtonState();
}
class PangeaSsoButtonState extends State<PangeaSsoButton> {
bool _loading = false;
String? _error;
Future<void> _runSSOLogin() async {
try {
setState(() {
_loading = true;
_error = null;
});
await pangeaSSOLoginAction(
IdentityProvider(
id: widget.provider.id,
name: widget.provider.name,
),
Matrix.of(context).getLoginClient(),
context,
);
} catch (err, s) {
ErrorHandler.logError(
e: err,
s: s,
data: {},
);
if (err is MatrixException) {
_error = err.errorMessage;
} else {
_error = L10n.of(context).oopsSomethingWentWrong;
}
_error = err.toString();
} finally {
if (mounted) setState(() => _loading = false);
}
}
@override
Widget build(BuildContext context) {
return FullWidthButton(
depressed: _loading,
error: _error,
loading: _loading,
title: widget.title,
icon: SvgPicture.asset(
widget.provider.asset,
height: 20,
width: 20,
colorFilter: ColorFilter.mode(
Theme.of(context).colorScheme.onPrimary,
BlendMode.srcIn,
),
),
onPressed: _runSSOLogin,
);
}
}