123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- import 'package:flutter/material.dart';
- import 'package:flutter_datetime_picker/flutter_datetime_picker.dart';
- import 'package:photos/ente_theme_data.dart';
- import 'package:photos/models/collection.dart';
- import 'package:photos/services/collections_service.dart';
- import 'package:photos/theme/ente_theme.dart';
- import 'package:photos/ui/components/captioned_text_widget.dart';
- import 'package:photos/ui/components/divider_widget.dart';
- import 'package:photos/ui/components/menu_item_widget/menu_item_widget.dart';
- import 'package:photos/ui/components/title_bar_title_widget.dart';
- import 'package:photos/ui/components/title_bar_widget.dart';
- import 'package:photos/utils/dialog_util.dart';
- import 'package:photos/utils/separators_util.dart';
- import 'package:tuple/tuple.dart';
- class LinkExpiryPickerPage extends StatelessWidget {
- final Collection collection;
- const LinkExpiryPickerPage(this.collection, {super.key});
- @override
- Widget build(BuildContext context) {
- return Scaffold(
- body: CustomScrollView(
- primary: false,
- slivers: <Widget>[
- const TitleBarWidget(
- flexibleSpaceTitle: TitleBarTitleWidget(
- title: "Link expiry",
- ),
- ),
- SliverList(
- delegate: SliverChildBuilderDelegate(
- (context, index) {
- return Padding(
- padding: const EdgeInsets.symmetric(
- horizontal: 16,
- vertical: 20,
- ),
- child: Column(
- mainAxisSize: MainAxisSize.min,
- children: [
- ClipRRect(
- borderRadius:
- const BorderRadius.all(Radius.circular(8)),
- child: ItemsWidget(collection),
- ),
- ],
- ),
- );
- },
- childCount: 1,
- ),
- ),
- const SliverPadding(padding: EdgeInsets.symmetric(vertical: 12)),
- ],
- ),
- );
- }
- }
- class ItemsWidget extends StatelessWidget {
- final Collection collection;
- ItemsWidget(this.collection, {super.key});
- // index, title, milliseconds in future post which link should expire (when >0)
- final List<Tuple2<String, int>> _expiryOptions = [
- const Tuple2("Never", 0),
- Tuple2("After 1 hour", const Duration(hours: 1).inMicroseconds),
- Tuple2("After 1 day", const Duration(days: 1).inMicroseconds),
- Tuple2("After 1 week", const Duration(days: 7).inMicroseconds),
- // todo: make this time calculation perfect
- Tuple2("After 1 month", const Duration(days: 30).inMicroseconds),
- Tuple2("After 1 year", const Duration(days: 365).inMicroseconds),
- const Tuple2("Custom", -1),
- ];
- @override
- Widget build(BuildContext context) {
- List<Widget> items = [];
- for (Tuple2<String, int> expiryOpiton in _expiryOptions) {
- items.add(
- _menuItemForPicker(context, expiryOpiton),
- );
- }
- items = addSeparators(
- items,
- DividerWidget(
- dividerType: DividerType.menuNoIcon,
- bgColor: getEnteColorScheme(context).fillFaint,
- ),
- );
- return Column(
- mainAxisSize: MainAxisSize.min,
- children: items,
- );
- }
- Widget _menuItemForPicker(
- BuildContext context,
- Tuple2<String, int> expiryOpiton,
- ) {
- return MenuItemWidget(
- menuItemColor: getEnteColorScheme(context).fillFaint,
- captionedTextWidget: CaptionedTextWidget(
- title: expiryOpiton.item1,
- ),
- alignCaptionedTextToLeft: true,
- isTopBorderRadiusRemoved: true,
- isBottomBorderRadiusRemoved: true,
- alwaysShowSuccessState: true,
- surfaceExecutionStates: expiryOpiton.item2 == -1 ? false : true,
- onTap: () async {
- int newValidTill = -1;
- final int expireAfterInMicroseconds = expiryOpiton.item2;
- // need to manually select time
- if (expireAfterInMicroseconds < 0) {
- final timeInMicrosecondsFromEpoch =
- await _showDateTimePicker(context);
- if (timeInMicrosecondsFromEpoch != null) {
- newValidTill = timeInMicrosecondsFromEpoch;
- }
- } else if (expireAfterInMicroseconds == 0) {
- // no expiry
- newValidTill = 0;
- } else {
- newValidTill =
- DateTime.now().microsecondsSinceEpoch + expireAfterInMicroseconds;
- }
- if (newValidTill >= 0) {
- debugPrint("Setting expirty $newValidTill");
- await updateTime(newValidTill, context);
- }
- },
- );
- }
- // _showDateTimePicker return null if user doesn't select date-time
- Future<int?> _showDateTimePicker(BuildContext context) async {
- final dateResult = await DatePicker.showDatePicker(
- context,
- minTime: DateTime.now(),
- currentTime: DateTime.now(),
- locale: LocaleType.en,
- theme: Theme.of(context).colorScheme.dateTimePickertheme,
- );
- if (dateResult == null) {
- return null;
- }
- final dateWithTimeResult = await DatePicker.showTime12hPicker(
- context,
- showTitleActions: true,
- currentTime: dateResult,
- locale: LocaleType.en,
- theme: Theme.of(context).colorScheme.dateTimePickertheme,
- );
- if (dateWithTimeResult == null) {
- return null;
- } else {
- return dateWithTimeResult.microsecondsSinceEpoch;
- }
- }
- Future<void> updateTime(int newValidTill, BuildContext context) async {
- await _updateUrlSettings(
- context,
- {'validTill': newValidTill},
- );
- }
- Future<void> _updateUrlSettings(
- BuildContext context,
- Map<String, dynamic> prop,
- ) async {
- try {
- await CollectionsService.instance.updateShareUrl(collection, prop);
- } catch (e) {
- showGenericErrorDialog(context: context);
- rethrow;
- }
- }
- }
|