You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
3.1 KiB
Dart
76 lines
3.1 KiB
Dart
import 'dart:io';
|
|
|
|
import 'package:flutter/material.dart';
|
|
import 'package:fluttertoast/fluttertoast.dart';
|
|
import 'package:open_file/open_file.dart';
|
|
import 'package:test_sa/extensions/int_extensions.dart';
|
|
import 'package:test_sa/extensions/widget_extensions.dart';
|
|
import 'package:test_sa/views/app_style/sizing.dart';
|
|
import 'package:test_sa/views/widgets/buttons/app_back_button.dart';
|
|
import 'package:test_sa/views/widgets/loaders/image_loader.dart';
|
|
import 'package:url_launcher/url_launcher.dart';
|
|
|
|
import 'image_item.dart';
|
|
import 'images_viewer.dart';
|
|
|
|
class FilesList extends StatelessWidget {
|
|
final List<String> images;
|
|
final EdgeInsets padding;
|
|
|
|
const FilesList({Key key, this.images, this.padding}) : super(key: key);
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return ListView.separated(
|
|
padding: padding ?? EdgeInsets.symmetric(horizontal: 32 * AppStyle.getScaleFactor(context)),
|
|
scrollDirection: Axis.horizontal,
|
|
itemCount: images.length,
|
|
separatorBuilder: (context, itemIndex) => 8.width,
|
|
itemBuilder: (context, itemIndex) {
|
|
var isImage =
|
|
images[itemIndex].split(".").last.toLowerCase() == "png" || images[itemIndex].split(".").last.toLowerCase() == "jpg" || images[itemIndex].split(".").last.toLowerCase() == "jpeg";
|
|
var isPdf = images[itemIndex].split(".").last.toLowerCase() == "pdf";
|
|
var isExcel = images[itemIndex].split(".").last.toLowerCase() == "xlsx";
|
|
|
|
return (isImage
|
|
? (_isLocalUrl(images[itemIndex])
|
|
? Image.file(File(images[itemIndex]))
|
|
: ImageLoader(
|
|
url: images[itemIndex],
|
|
boxFit: BoxFit.cover,
|
|
))
|
|
: Image.asset("assets/images/${isPdf ? "pdf" : isExcel ? "excel" : "doc"}.png"))
|
|
.onPress(() async {
|
|
if (isImage) {
|
|
Navigator.of(context).push(
|
|
MaterialPageRoute(
|
|
builder: (_) => Scaffold(
|
|
body: SafeArea(
|
|
child: Stack(
|
|
children: [
|
|
InteractiveViewer(child: Image(image: (_isLocalUrl(images[itemIndex]) ? FileImage(File(images[itemIndex])) : NetworkImage(images[itemIndex])))).center,
|
|
const ABackButton(),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
} else if (_isLocalUrl(images[itemIndex])) {
|
|
OpenFile.open(images[itemIndex]);
|
|
} else {
|
|
if (!await launchUrl(Uri.parse(images[itemIndex]), mode: LaunchMode.externalApplication)) {
|
|
Fluttertoast.showToast(msg: "UnExpected Error with file.");
|
|
throw Exception('Could not launch ');
|
|
}
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
bool _isLocalUrl(String url) {
|
|
if (url?.isEmpty != false) return false;
|
|
return url.startsWith("/") || url.startsWith("file://") || url.substring(1).startsWith(':\\');
|
|
}
|
|
}
|