You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

247 lines
8.4 KiB

3 years ago
import 'package:camera/camera.dart';
import 'package:teso/Pages/PageWidgets/Settings/privacy.dart';
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:teso/Classes/TesoUser.dart';
import 'package:teso/Pages/PageWidgets/Settings/AccountSettings.dart';
import 'package:teso/Pages/PageWidgets/Settings/EditProfile.dart';
import 'package:teso/Pages/PageWidgets/Settings/terms.dart';
import 'package:teso/Pages/Sub_Pages/AccountSettings/BlockedUser.dart';
import 'package:teso/Pages/Sub_Pages/PersonalSub/Referral.dart';
import 'package:teso/providers/app_provider.dart';
import 'package:teso/providers/pageAnimations.dart';
import 'package:teso/providers/user_provider.dart';
import 'package:teso/providers/device_provider.dart';
import 'package:teso/util/consts.dart';
class Setting extends StatefulWidget {
final Function logOut;
final List<CameraDescription> connectedCameras;
const Setting({Key key, this.logOut, this.connectedCameras})
: super(key: key);
@override
_SettingState createState() => _SettingState(logOut: this.logOut);
}
class _SettingState extends State<Setting> {
Function logOut;
_SettingState({this.logOut});
bool enabled = true;
TesoUser currentUser;
@override
void initState() {
super.initState();
}
void editProfileDialog(context, TesoUser user) {
showModalBottomSheet(
context: context,
isScrollControlled: true,
enableDrag: true,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.vertical(top: Radius.circular(30.0)),
),
builder: (BuildContext bc) {
return EditProfile(
userProfile: user,
// connectedCameras: widget.connectedCameras,
);
});
}
void accountSettingsDialog(context) {
showModalBottomSheet(
context: context,
isScrollControlled: true,
enableDrag: true,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.vertical(top: Radius.circular(30.0)),
),
builder: (BuildContext bc) {
return AccountSettings();
});
}
@override
Widget build(BuildContext context) {
return Container(
height: MediaQuery.of(context).size.height * 0.9,
child: SingleChildScrollView(
scrollDirection: Axis.vertical,
child: new Wrap(
children: <Widget>[
new Container(
margin: EdgeInsets.only(
left: 20.0,
top: 20.0,
bottom: 12.0,
),
child: Row(
children: [
Container(
child: InkWell(
onTap: () => Navigator.pop(context),
child: Icon(Icons.close),
),
),
Expanded(
child: Container(
width: double.infinity,
child: Center(
child: Text(
"Settings",
style: TextStyle(
fontSize: 20.0,
),
),
),
),
),
],
)),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: Divider(),
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: Text(
"Personnal Information",
style: TextStyle(fontSize: 15),
),
),
new Consumer<UserProvider>(
builder: (BuildContext context, UserProvider user, Widget child) {
if (user.currentUser == null) {
return Container();
} else {
return new ListTile(
trailing: new Icon(Icons.arrow_forward_ios),
title: new Text('Edit Profile'),
onTap: () => editProfileDialog(context, user.currentUser),
);
}
},
),
new ListTile(
trailing: new Icon(Icons.arrow_forward_ios),
title: new Text('Account settings'),
onTap: () => accountSettingsDialog(context),
),
new ListTile(
trailing: new Icon(Icons.arrow_forward_ios),
title: new Text('Refer and Earn'),
onTap: () {
Navigator.push(
context,
PageTransition(
type: PageTransitionType.rightToLeft,
child: Referrals(),
),
);
},
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: Divider(),
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: Text("Connections"),
),
new ListTile(
trailing: new Icon(Icons.arrow_forward_ios),
title: new Text('Blocked accounts'),
onTap: () => Navigator.push(
context,
PageTransition(
child: BlockAccounts(),
type: PageTransitionType.leftToRight)),
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: Divider(),
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: Text("Support"),
),
new ListTile(
trailing: new Icon(Icons.arrow_forward_ios),
title: new Text('Terms of use'),
onTap: () => Navigator.push(
context,
PageTransition(
child: TermsUse(), type: PageTransitionType.leftToRight)),
),
new ListTile(
trailing: new Icon(Icons.arrow_forward_ios),
title: new Text('See Privacy Policy'),
onTap: () => Navigator.push(
context,
PageTransition(
child: Privacy(), type: PageTransitionType.leftToRight)),
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: Divider(),
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: Text("Actions"),
),
new Consumer<DeviceProvider>(builder:
(BuildContext context, DeviceProvider value, Widget child) {
return SwitchListTile(
secondary: Icon(Icons.camera),
title: Text(
"Coupon Alerts",
),
subtitle: Text(
"Enabling coupon alerts would you allow receive proximity coupons"),
value:
value.serviceEnabled == null ? false : value.serviceEnabled,
onChanged: (v) {
Provider.of<DeviceProvider>(context, listen: false)
.toggleBackgroundMode(context);
},
);
}),
new Consumer<UserProvider>(builder:
(BuildContext context, UserProvider value, Widget child) {
return SwitchListTile(
secondary: Icon(
Icons.dark_mode_outlined,
),
title: Text(
"Dark Mode",
),
value: Provider.of<AppProvider>(context).theme ==
Constants.lightTheme
? false
: true,
onChanged: (v) {
if (v) {
Provider.of<AppProvider>(context, listen: false)
.setTheme(Constants.darkTheme, "dark");
} else {
Provider.of<AppProvider>(context, listen: false)
.setTheme(Constants.lightTheme, "light");
}
},
);
}),
new ListTile(
title: new Text('Log out'),
onTap: () => logOut(),
),
],
),
),
);
}
}