84 lines
2.7 KiB
Dart
Executable File
84 lines
2.7 KiB
Dart
Executable File
import 'dart:io';
|
|
|
|
import 'package:filcnaplo_kreta_api/models/attachment.dart';
|
|
import 'package:filcnaplo/helpers/attachment_helper.dart';
|
|
import 'package:filcnaplo_mobile_ui/common/widgets/message/image_view.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_feather_icons/flutter_feather_icons.dart';
|
|
|
|
class AttachmentTile extends StatelessWidget {
|
|
const AttachmentTile(this.attachment, {super.key});
|
|
|
|
final Attachment attachment;
|
|
|
|
Widget buildImage(BuildContext context) {
|
|
return FutureBuilder<String>(
|
|
future: attachment.download(context),
|
|
builder: (context, snapshot) {
|
|
if (snapshot.hasData) {
|
|
return Padding(
|
|
padding: const EdgeInsets.symmetric(vertical: 4.0),
|
|
child: ClipRRect(
|
|
borderRadius: BorderRadius.circular(12.0),
|
|
child: Material(
|
|
child: InkWell(
|
|
onTap: () {
|
|
showModalBottomSheet(
|
|
useRootNavigator: true,
|
|
isScrollControlled: true,
|
|
context: context,
|
|
builder: (context) {
|
|
return ImageView(snapshot.data!);
|
|
},
|
|
);
|
|
},
|
|
borderRadius: BorderRadius.circular(12.0),
|
|
child: Ink.image(
|
|
image: FileImage(File(snapshot.data ?? "")),
|
|
height: 200.0,
|
|
width: double.infinity,
|
|
fit: BoxFit.cover,
|
|
),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
} else {
|
|
return Center(
|
|
child: Padding(
|
|
padding: const EdgeInsets.all(12.0),
|
|
child: CircularProgressIndicator(color: Theme.of(context).colorScheme.secondary),
|
|
));
|
|
}
|
|
},
|
|
);
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
if (attachment.isImage) return buildImage(context);
|
|
|
|
return Padding(
|
|
padding: const EdgeInsets.symmetric(vertical: 4.0),
|
|
child: InkWell(
|
|
borderRadius: BorderRadius.circular(12.0),
|
|
onTap: () {
|
|
attachment.open(context);
|
|
},
|
|
child: Padding(
|
|
padding: const EdgeInsets.all(8.0),
|
|
child: Row(children: [
|
|
const Icon(FeatherIcons.paperclip),
|
|
Expanded(
|
|
child: Padding(
|
|
padding: const EdgeInsets.symmetric(horizontal: 12.0),
|
|
child: Text(attachment.name, maxLines: 2, overflow: TextOverflow.ellipsis),
|
|
),
|
|
),
|
|
]),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|