2022-02-03 10:06:44 -06:00
|
|
|
import 'package:auto_route/auto_route.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_hooks/flutter_hooks.dart';
|
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
2022-02-07 23:42:35 -06:00
|
|
|
import 'package:immich_mobile/modules/home/providers/asset.provider.dart';
|
2022-02-03 10:06:44 -06:00
|
|
|
import 'package:immich_mobile/modules/login/providers/authentication.provider.dart';
|
2022-02-07 23:42:35 -06:00
|
|
|
import 'package:immich_mobile/shared/providers/backup.provider.dart';
|
2022-02-04 17:20:23 -06:00
|
|
|
import 'package:immich_mobile/shared/ui/immich_toast.dart';
|
2022-02-03 10:06:44 -06:00
|
|
|
|
|
|
|
class LoginForm extends HookConsumerWidget {
|
|
|
|
const LoginForm({Key? key}) : super(key: key);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
2022-03-11 13:38:52 -06:00
|
|
|
final usernameController = useTextEditingController(text: 'testuser@email.com');
|
|
|
|
final passwordController = useTextEditingController(text: 'password');
|
2022-04-05 10:16:15 -05:00
|
|
|
final serverEndpointController = useTextEditingController(text: 'http://192.168.1.103:2283');
|
2022-02-03 10:06:44 -06:00
|
|
|
|
|
|
|
return Center(
|
|
|
|
child: ConstrainedBox(
|
|
|
|
constraints: const BoxConstraints(maxWidth: 300),
|
2022-02-13 15:10:42 -06:00
|
|
|
child: SingleChildScrollView(
|
|
|
|
child: Wrap(
|
|
|
|
spacing: 32,
|
|
|
|
runSpacing: 32,
|
|
|
|
alignment: WrapAlignment.center,
|
|
|
|
children: [
|
|
|
|
const Image(
|
|
|
|
image: AssetImage('assets/immich-logo-no-outline.png'),
|
|
|
|
width: 128,
|
|
|
|
filterQuality: FilterQuality.high,
|
|
|
|
),
|
|
|
|
Text(
|
|
|
|
'IMMICH',
|
2022-04-04 09:08:53 -05:00
|
|
|
style: TextStyle(
|
|
|
|
fontFamily: 'SnowburstOne',
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
fontSize: 48,
|
|
|
|
color: Theme.of(context).primaryColor,
|
|
|
|
),
|
2022-02-13 15:10:42 -06:00
|
|
|
),
|
|
|
|
EmailInput(controller: usernameController),
|
|
|
|
PasswordInput(controller: passwordController),
|
|
|
|
ServerEndpointInput(controller: serverEndpointController),
|
|
|
|
LoginButton(
|
|
|
|
emailController: usernameController,
|
|
|
|
passwordController: passwordController,
|
|
|
|
serverEndpointController: serverEndpointController,
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
2022-02-03 10:06:44 -06:00
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class ServerEndpointInput extends StatelessWidget {
|
|
|
|
final TextEditingController controller;
|
|
|
|
|
|
|
|
const ServerEndpointInput({Key? key, required this.controller}) : super(key: key);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return TextFormField(
|
|
|
|
controller: controller,
|
|
|
|
decoration: const InputDecoration(
|
|
|
|
labelText: 'Server Endpoint URL', border: OutlineInputBorder(), hintText: 'http://your-server-ip:port'),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class EmailInput extends StatelessWidget {
|
|
|
|
final TextEditingController controller;
|
|
|
|
|
|
|
|
const EmailInput({Key? key, required this.controller}) : super(key: key);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return TextFormField(
|
|
|
|
controller: controller,
|
|
|
|
decoration:
|
2022-03-27 15:47:49 -05:00
|
|
|
const InputDecoration(labelText: 'Email', border: OutlineInputBorder(), hintText: 'youremail@email.com'),
|
2022-02-03 10:06:44 -06:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class PasswordInput extends StatelessWidget {
|
|
|
|
final TextEditingController controller;
|
|
|
|
|
|
|
|
const PasswordInput({Key? key, required this.controller}) : super(key: key);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return TextFormField(
|
|
|
|
obscureText: true,
|
|
|
|
controller: controller,
|
|
|
|
decoration: const InputDecoration(labelText: 'Password', border: OutlineInputBorder(), hintText: 'password'),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class LoginButton extends ConsumerWidget {
|
|
|
|
final TextEditingController emailController;
|
|
|
|
final TextEditingController passwordController;
|
|
|
|
final TextEditingController serverEndpointController;
|
|
|
|
|
|
|
|
const LoginButton(
|
|
|
|
{Key? key,
|
|
|
|
required this.emailController,
|
|
|
|
required this.passwordController,
|
|
|
|
required this.serverEndpointController})
|
|
|
|
: super(key: key);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
|
|
return ElevatedButton(
|
|
|
|
onPressed: () async {
|
2022-02-07 23:42:35 -06:00
|
|
|
// This will remove current cache asset state of previous user login.
|
|
|
|
ref.watch(assetProvider.notifier).clearAllAsset();
|
|
|
|
|
2022-02-03 10:06:44 -06:00
|
|
|
var isAuthenicated = await ref
|
|
|
|
.read(authenticationProvider.notifier)
|
|
|
|
.login(emailController.text, passwordController.text, serverEndpointController.text);
|
|
|
|
|
|
|
|
if (isAuthenicated) {
|
2022-02-07 23:42:35 -06:00
|
|
|
// Resume backup (if enable) then navigate
|
|
|
|
ref.watch(backupProvider.notifier).resumeBackup();
|
2022-02-27 12:43:29 -06:00
|
|
|
// AutoRouter.of(context).pushNamed("/home-page");
|
|
|
|
AutoRouter.of(context).pushNamed("/tab-controller-page");
|
2022-02-03 10:06:44 -06:00
|
|
|
} else {
|
2022-02-04 17:20:23 -06:00
|
|
|
ImmichToast.show(
|
2022-04-02 12:31:53 -05:00
|
|
|
context: context,
|
|
|
|
msg: "Error logging you in, check server url, email and password!",
|
|
|
|
toastType: ToastType.error,
|
|
|
|
);
|
2022-02-03 10:06:44 -06:00
|
|
|
}
|
|
|
|
},
|
|
|
|
child: const Text("Login"));
|
|
|
|
}
|
|
|
|
}
|