mirror of
https://github.com/Xevion/paperless-mobile.git
synced 2025-12-07 20:07:48 -06:00
110 lines
3.7 KiB
Dart
110 lines
3.7 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
import 'package:flutter_form_builder/flutter_form_builder.dart';
|
|
import 'package:go_router/go_router.dart';
|
|
import 'package:paperless_api/paperless_api.dart';
|
|
import 'package:paperless_mobile/features/saved_view/cubit/saved_view_cubit.dart';
|
|
import 'package:paperless_mobile/generated/l10n/app_localizations.dart';
|
|
|
|
const _fkName = 'name';
|
|
const _fkShowOnDashboard = 'show_on_dashboard';
|
|
const _fkShowInSidebar = 'show_in_sidebar';
|
|
|
|
class AddSavedViewPage extends StatefulWidget {
|
|
final DocumentFilter? initialFilter;
|
|
const AddSavedViewPage({
|
|
super.key,
|
|
this.initialFilter,
|
|
});
|
|
|
|
@override
|
|
State<AddSavedViewPage> createState() => _AddSavedViewPageState();
|
|
}
|
|
|
|
class _AddSavedViewPageState extends State<AddSavedViewPage> {
|
|
final _savedViewFormKey = GlobalKey<FormBuilderState>();
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Scaffold(
|
|
appBar: AppBar(
|
|
title: Text(S.of(context)!.newView),
|
|
),
|
|
floatingActionButton: FloatingActionButton.extended(
|
|
heroTag: "fab_add_saved_view_page",
|
|
icon: const Icon(Icons.add),
|
|
onPressed: () => _onCreate(context),
|
|
label: Text(S.of(context)!.create),
|
|
),
|
|
body: Padding(
|
|
padding: const EdgeInsets.all(8.0),
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
children: [
|
|
FormBuilder(
|
|
key: _savedViewFormKey,
|
|
child: Column(
|
|
children: [
|
|
FormBuilderTextField(
|
|
name: _fkName,
|
|
validator: (value) {
|
|
if (value?.trim().isEmpty ?? true) {
|
|
return S.of(context)!.thisFieldIsRequired;
|
|
}
|
|
return null;
|
|
},
|
|
decoration: InputDecoration(
|
|
label: Text(S.of(context)!.name),
|
|
),
|
|
),
|
|
FormBuilderField<bool>(
|
|
name: _fkShowOnDashboard,
|
|
initialValue: false,
|
|
builder: (field) {
|
|
return CheckboxListTile(
|
|
value: field.value,
|
|
title: Text(S.of(context)!.showOnDashboard),
|
|
onChanged: (value) => field.didChange(value),
|
|
);
|
|
},
|
|
),
|
|
FormBuilderField<bool>(
|
|
name: _fkShowInSidebar,
|
|
initialValue: false,
|
|
builder: (field) {
|
|
return CheckboxListTile(
|
|
value: field.value,
|
|
title: Text(S.of(context)!.showInSidebar),
|
|
onChanged: (value) => field.didChange(value),
|
|
);
|
|
},
|
|
),
|
|
],
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
void _onCreate(BuildContext context) async {
|
|
if (_savedViewFormKey.currentState?.saveAndValidate() ?? false) {
|
|
final cubit = context.read<SavedViewCubit>();
|
|
var savedView = SavedView.fromDocumentFilter(
|
|
widget.initialFilter ?? const DocumentFilter(),
|
|
name: _savedViewFormKey.currentState?.value[_fkName] as String,
|
|
showOnDashboard:
|
|
_savedViewFormKey.currentState?.value[_fkShowOnDashboard] as bool,
|
|
showInSidebar:
|
|
_savedViewFormKey.currentState?.value[_fkShowInSidebar] as bool,
|
|
);
|
|
final router = GoRouter.of(context);
|
|
await cubit.add(
|
|
savedView,
|
|
);
|
|
router.pop();
|
|
}
|
|
}
|
|
}
|