A framework for building convergent cross-platform Nextcloud clients using Flutter.
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.

101 lines
3.0 KiB

part of '../neon_notes.dart';
2 years ago
class NotesView extends StatelessWidget {
const NotesView({
required this.bloc,
this.category,
super.key,
});
final NotesBloc bloc;
final String? category;
@override
Widget build(final BuildContext context) => ResultBuilder<List<NotesNote>>.behaviorSubject(
stream: bloc.notes,
builder: (final context, final notes) => SortBoxBuilder<NotesSortProperty, NotesNote>(
sortBox: notesSortBox,
presort: const {
(NotesSortProperty.favorite, SortBoxOrder.ascending),
},
sortPropertyOption: bloc.options.notesSortPropertyOption,
sortBoxOrderOption: bloc.options.notesSortBoxOrderOption,
input: category != null ? notes.data?.where((final note) => note.category == category).toList() : notes.data,
builder: (final context, final sorted) => NeonListView<NotesNote>(
scrollKey: 'notes-notes',
withFloatingActionButton: true,
items: sorted,
isLoading: notes.isLoading,
error: notes.error,
onRefresh: bloc.refresh,
builder: _buildNote,
2 years ago
),
),
);
Widget _buildNote(
final BuildContext context,
final NotesNote note,
2 years ago
) =>
ListTile(
title: Text(note.title),
2 years ago
subtitle: Row(
children: [
RelativeTime(
date: DateTime.fromMillisecondsSinceEpoch(note.modified * 1000),
2 years ago
),
if (note.category.isNotEmpty) ...[
2 years ago
const SizedBox(
width: 8,
),
Icon(
MdiIcons.tag,
size: 14,
color: NotesCategoryColor.compute(note.category),
2 years ago
),
const SizedBox(
width: 2,
),
Text(note.category),
2 years ago
],
],
),
trailing: IconButton(
onPressed: () {
bloc.updateNote(
note.id,
note.etag,
favorite: !note.favorite,
2 years ago
);
},
tooltip: note.favorite ? AppLocalizations.of(context).noteUnstar : AppLocalizations.of(context).noteStar,
icon: Icon(
note.favorite ? Icons.star : Icons.star_outline,
color: Theme.of(context).colorScheme.primary,
),
2 years ago
),
onTap: () async {
await Navigator.of(context).push(
MaterialPageRoute(
builder: (final context) => NotesNotePage(
bloc: NotesNoteBloc(
bloc,
note,
),
notesBloc: bloc,
2 years ago
),
),
);
},
onLongPress: () async {
final result = await showConfirmationDialog(
context,
AppLocalizations.of(context).noteDeleteConfirm(note.title),
2 years ago
);
if (result) {
bloc.deleteNote(note.id);
2 years ago
}
},
);
}