change: Sign in button according to apples HIG

This commit is contained in:
Christian Pauly 2021-07-08 18:09:19 +02:00
parent 8fef28ae87
commit 3601e40a82
3 changed files with 69 additions and 41 deletions

View File

@ -2044,7 +2044,7 @@
"type": "text", "type": "text",
"placeholders": {} "placeholders": {}
}, },
"loginWith": "Login with {brand}", "loginWith": "Sign in with {brand}",
"@loginWith": { "@loginWith": {
"type": "text", "type": "text",
"placeholders": { "placeholders": {

View File

@ -149,9 +149,13 @@ class HomeserverPickerController extends State<HomeserverPicker> {
final rawProviders = _rawLoginTypes.tryGetList('flows').singleWhere( final rawProviders = _rawLoginTypes.tryGetList('flows').singleWhere(
(flow) => (flow) =>
flow['type'] == AuthenticationTypes.sso)['identity_providers']; flow['type'] == AuthenticationTypes.sso)['identity_providers'];
return (rawProviders as List) final list = (rawProviders as List)
.map((json) => IdentityProvider.fromJson(json)) .map((json) => IdentityProvider.fromJson(json))
.toList(); .toList();
if (!PlatformInfos.isCupertinoStyle) {
list.sort((a, b) => a.brand == 'apple' ? -1 : 1);
}
return list;
} }
bool get passwordLoginSupported => bool get passwordLoginSupported =>

View File

@ -85,24 +85,26 @@ class HomeserverPickerView extends StatelessWidget {
if (controller.ssoLoginSupported) ...{ if (controller.ssoLoginSupported) ...{
for (final identityProvider for (final identityProvider
in controller.identityProviders) in controller.identityProviders)
OutlinedButton.icon( Center(
onPressed: () => controller child: _LoginButton(
.ssoLoginAction(identityProvider.id), onPressed: () => controller
icon: identityProvider.icon == null .ssoLoginAction(identityProvider.id),
? Icon(Icons.web_outlined) icon: identityProvider.icon == null
: CachedNetworkImage( ? Icon(Icons.web_outlined)
imageUrl: Uri.parse( : CachedNetworkImage(
identityProvider.icon) imageUrl: Uri.parse(
.getDownloadLink( identityProvider.icon)
Matrix.of(context).client) .getDownloadLink(
.toString(), Matrix.of(context).client)
width: 24, .toString(),
height: 24, width: 24,
), height: 24,
label: Text(L10n.of(context).loginWith( ),
identityProvider.brand ?? labelText: L10n.of(context).loginWith(
identityProvider.name ?? identityProvider.name ??
L10n.of(context).singlesignon)), identityProvider.brand ??
L10n.of(context).singlesignon),
),
), ),
if (controller.registrationSupported || if (controller.registrationSupported ||
controller.passwordLoginSupported) controller.passwordLoginSupported)
@ -119,14 +121,11 @@ class HomeserverPickerView extends StatelessWidget {
children: [ children: [
if (controller.passwordLoginSupported) if (controller.passwordLoginSupported)
Expanded( Expanded(
child: Container( child: _LoginButton(
height: 64, onPressed: () =>
child: OutlinedButton.icon( VRouter.of(context).to('/login'),
onPressed: () => icon: Icon(Icons.login_outlined),
VRouter.of(context).to('/login'), labelText: L10n.of(context).login,
icon: Icon(Icons.login_outlined),
label: Text(L10n.of(context).login),
),
), ),
), ),
if (controller.registrationSupported && if (controller.registrationSupported &&
@ -134,14 +133,10 @@ class HomeserverPickerView extends StatelessWidget {
SizedBox(width: 12), SizedBox(width: 12),
if (controller.registrationSupported) if (controller.registrationSupported)
Expanded( Expanded(
child: Container( child: _LoginButton(
height: 64, onPressed: controller.signUpAction,
child: OutlinedButton.icon( icon: Icon(Icons.add_box_outlined),
onPressed: controller.signUpAction, labelText: L10n.of(context).register,
icon: Icon(Icons.add_box_outlined),
label:
Text(L10n.of(context).register),
),
), ),
), ),
], ],
@ -157,11 +152,7 @@ class HomeserverPickerView extends StatelessWidget {
), ),
); );
}), }),
]), Wrap(
bottomNavigationBar: Material(
elevation: 7,
color: Theme.of(context).scaffoldBackgroundColor,
child: Wrap(
alignment: WrapAlignment.center, alignment: WrapAlignment.center,
children: [ children: [
TextButton( TextButton(
@ -186,6 +177,39 @@ class HomeserverPickerView extends StatelessWidget {
), ),
], ],
), ),
]),
),
);
}
}
class _LoginButton extends StatelessWidget {
final String labelText;
final Widget icon;
final void Function() onPressed;
const _LoginButton({
Key key,
this.labelText,
this.icon,
this.onPressed,
}) : super(key: key);
@override
Widget build(BuildContext context) {
return OutlinedButton.icon(
style: OutlinedButton.styleFrom(
minimumSize: Size(256, 56),
side: BorderSide(
color: Theme.of(context).textTheme.bodyText1.color,
),
shape:
RoundedRectangleBorder(borderRadius: BorderRadius.circular(90))),
onPressed: onPressed,
icon: icon,
label: Text(
labelText,
style: TextStyle(
color: Theme.of(context).textTheme.bodyText1.color,
), ),
), ),
); );