Update sharing dialog
This commit is contained in:
parent
6721d22c97
commit
22f879d8d9
|
@ -1,8 +1,12 @@
|
||||||
|
import 'dart:developer';
|
||||||
|
|
||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
import 'package:photos/folder_service.dart';
|
import 'package:photos/folder_service.dart';
|
||||||
import 'package:photos/models/folder.dart';
|
import 'package:photos/models/folder.dart';
|
||||||
import 'package:photos/ui/loading_widget.dart';
|
import 'package:photos/ui/loading_widget.dart';
|
||||||
|
import 'package:photos/utils/dialog_util.dart';
|
||||||
import 'package:photos/utils/toast_util.dart';
|
import 'package:photos/utils/toast_util.dart';
|
||||||
|
|
||||||
class ShareFolderWidget extends StatefulWidget {
|
class ShareFolderWidget extends StatefulWidget {
|
||||||
|
@ -44,32 +48,125 @@ class _ShareFolderWidgetState extends State<ShareFolderWidget> {
|
||||||
|
|
||||||
Widget _getSharingDialog(Map<int, bool> sharingStatus) {
|
Widget _getSharingDialog(Map<int, bool> sharingStatus) {
|
||||||
return AlertDialog(
|
return AlertDialog(
|
||||||
title: Text('Share "' + widget.title + '" with'),
|
title: Text('Sharing'),
|
||||||
content: SingleChildScrollView(
|
content: SingleChildScrollView(
|
||||||
child: ListBody(
|
child: ListBody(
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
SharingCheckboxWidget(sharingStatus),
|
// SharingCheckboxWidget(sharingStatus),
|
||||||
|
SharingWidget(["vishnu@ente.io", "shanthy@ente.io"]),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
actions: <Widget>[
|
// actions: <Widget>[
|
||||||
FlatButton(
|
// FlatButton(
|
||||||
child: Text("Share"),
|
// child: Text("Save"),
|
||||||
onPressed: () async {
|
// onPressed: () async {
|
||||||
var sharedWith = Set<int>();
|
// var sharedWith = Set<int>();
|
||||||
for (var user in sharingStatus.keys) {
|
// for (var user in sharingStatus.keys) {
|
||||||
if (sharingStatus[user]) {
|
// if (sharingStatus[user]) {
|
||||||
sharedWith.add(user);
|
// sharedWith.add(user);
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
_folder.sharedWith.clear();
|
// _folder.sharedWith.clear();
|
||||||
_folder.sharedWith.addAll(sharedWith);
|
// _folder.sharedWith.addAll(sharedWith);
|
||||||
await FolderSharingService.instance.updateFolder(_folder);
|
// await FolderSharingService.instance.updateFolder(_folder);
|
||||||
showToast("Sharing configuration updated successfully.");
|
// showToast("Sharing configuration updated successfully.");
|
||||||
Navigator.of(context).pop();
|
// Navigator.of(context).pop();
|
||||||
},
|
// },
|
||||||
|
// ),
|
||||||
|
// ],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class SharingWidget extends StatefulWidget {
|
||||||
|
final List<String> emails;
|
||||||
|
SharingWidget(this.emails, {Key key}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_SharingWidgetState createState() => _SharingWidgetState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _SharingWidgetState extends State<SharingWidget> {
|
||||||
|
bool _showEntryField = false;
|
||||||
|
List<String> _emails;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
_emails = widget.emails;
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final children = List<Widget>();
|
||||||
|
for (final email in _emails) {
|
||||||
|
children.add(EmailItemWidget(email));
|
||||||
|
}
|
||||||
|
if (_showEntryField) {
|
||||||
|
children.add(TextField(
|
||||||
|
keyboardType: TextInputType.emailAddress,
|
||||||
|
autofocus: true,
|
||||||
|
onSubmitted: (s) {
|
||||||
|
final progressDialog = createProgressDialog(context, "Sharing...");
|
||||||
|
progressDialog.show();
|
||||||
|
Future.delayed(Duration(milliseconds: 1000), () {
|
||||||
|
progressDialog.hide();
|
||||||
|
setState(() {
|
||||||
|
_emails.add(s);
|
||||||
|
_showEntryField = false;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
));
|
||||||
|
}
|
||||||
|
children.add(Padding(
|
||||||
|
padding: EdgeInsets.all(8),
|
||||||
|
));
|
||||||
|
children.add(Container(
|
||||||
|
width: 220,
|
||||||
|
child: OutlineButton(
|
||||||
|
child: Icon(
|
||||||
|
Icons.add,
|
||||||
),
|
),
|
||||||
],
|
onPressed: () {
|
||||||
|
setState(() {
|
||||||
|
_showEntryField = true;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
),
|
||||||
|
));
|
||||||
|
var column = Column(
|
||||||
|
children: children,
|
||||||
|
);
|
||||||
|
return column;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class EmailItemWidget extends StatelessWidget {
|
||||||
|
final String email;
|
||||||
|
const EmailItemWidget(
|
||||||
|
this.email, {
|
||||||
|
Key key,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Padding(
|
||||||
|
padding: const EdgeInsets.all(4.0),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
email,
|
||||||
|
style: TextStyle(fontSize: 14),
|
||||||
|
),
|
||||||
|
Icon(
|
||||||
|
Icons.remove_circle_outline,
|
||||||
|
color: Colors.redAccent,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue