Commit 60c0bef0 authored by Sai Srinivas's avatar Sai Srinivas
Browse files

ios pubspec

parent ed1a2aea
...@@ -16,7 +16,7 @@ import '../../Utils/app_colors.dart'; ...@@ -16,7 +16,7 @@ import '../../Utils/app_colors.dart';
class Fileviewer extends StatefulWidget { class Fileviewer extends StatefulWidget {
final String fileName; final String fileName;
final String fileUrl; final String fileUrl;
const Fileviewer({super.key,required this.fileName,required this.fileUrl}); const Fileviewer({super.key, required this.fileName, required this.fileUrl});
@override @override
State<Fileviewer> createState() => _FileviewerState(); State<Fileviewer> createState() => _FileviewerState();
...@@ -24,7 +24,7 @@ class Fileviewer extends StatefulWidget { ...@@ -24,7 +24,7 @@ class Fileviewer extends StatefulWidget {
class _FileviewerState extends State<Fileviewer> { class _FileviewerState extends State<Fileviewer> {
final Completer<InAppWebViewController> _controller = final Completer<InAppWebViewController> _controller =
Completer<InAppWebViewController>(); Completer<InAppWebViewController>();
var empId = ""; var empId = "";
var sessionId = ""; var sessionId = "";
bool isLoading = true; bool isLoading = true;
...@@ -49,39 +49,42 @@ class _FileviewerState extends State<Fileviewer> { ...@@ -49,39 +49,42 @@ class _FileviewerState extends State<Fileviewer> {
throw 'Could not launch $url'; throw 'Could not launch $url';
} }
} }
var Finalurl; var Finalurl;
@override @override
void initState() { void initState() {
// loadData(); // loadData();
pullToRefreshController = kIsWeb pullToRefreshController =
? null kIsWeb
: PullToRefreshController( ? null
settings: pullToRefreshSettings, : PullToRefreshController(
onRefresh: () async { settings: pullToRefreshSettings,
if (defaultTargetPlatform == TargetPlatform.android) { onRefresh: () async {
webViewController?.reload(); if (defaultTargetPlatform == TargetPlatform.android) {
} else if (defaultTargetPlatform == TargetPlatform.iOS) { webViewController?.reload();
webViewController?.loadUrl( } else if (defaultTargetPlatform == TargetPlatform.iOS) {
urlRequest: webViewController?.loadUrl(
URLRequest(url: await webViewController?.getUrl())); urlRequest: URLRequest(
} url: await webViewController?.getUrl(),
}, ),
); );
}
},
);
// print("URL:${widget.url}"); // print("URL:${widget.url}");
super.initState(); super.initState();
} }
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Scaffold( return Scaffold(
resizeToAvoidBottomInset: true, resizeToAvoidBottomInset: true,
appBar: appbar(context, "File Viewer"), appBar: appbar(context, "File Viewer"),
body: fileWidget(context), body: fileWidget(context),
); );
} }
Widget fileWidget(BuildContext context){ Widget fileWidget(BuildContext context) {
final extension = getFileExtension(widget.fileName); final extension = getFileExtension(widget.fileName);
switch (extension) { switch (extension) {
case 'jpg': case 'jpg':
...@@ -90,29 +93,31 @@ class _FileviewerState extends State<Fileviewer> { ...@@ -90,29 +93,31 @@ class _FileviewerState extends State<Fileviewer> {
case 'gif': case 'gif':
return CachedNetworkImage( return CachedNetworkImage(
imageUrl: widget.fileUrl, imageUrl: widget.fileUrl,
placeholder: (context, url) => const Center(child: CircularProgressIndicator()), placeholder:
(context, url) =>
const Center(child: CircularProgressIndicator()),
errorWidget: (context, url, error) => const Icon(Icons.error), errorWidget: (context, url, error) => const Icon(Icons.error),
fit: BoxFit.contain, fit: BoxFit.contain,
); );
case 'pdf': case 'pdf':
return SfPdfViewer.network( return SfPdfViewer.network(widget.fileUrl, key: GlobalKey());
widget.fileUrl,
key: GlobalKey(),
);
case 'doc': case 'doc':
case 'docx': case 'docx':
case 'xls': case 'xls':
case 'xlsx': case 'xlsx':
return InAppWebView( return InAppWebView(
initialUrlRequest: URLRequest( initialUrlRequest: URLRequest(url: WebUri(widget.fileUrl)),
url: WebUri(widget.fileUrl), androidOnGeolocationPermissionsShowPrompt: (
), InAppWebViewController controller,
androidOnGeolocationPermissionsShowPrompt: String origin,
(InAppWebViewController controller, String origin) async { ) async {
return GeolocationPermissionShowPromptResponse( return GeolocationPermissionShowPromptResponse(
origin: origin, allow: true, retain: true); origin: origin,
allow: true,
retain: true,
);
}, },
initialOptions: InAppWebViewGroupOptions( initialOptions: InAppWebViewGroupOptions(
android: AndroidInAppWebViewOptions( android: AndroidInAppWebViewOptions(
...@@ -123,24 +128,23 @@ class _FileviewerState extends State<Fileviewer> { ...@@ -123,24 +128,23 @@ class _FileviewerState extends State<Fileviewer> {
allowFileAccess: true, allowFileAccess: true,
databaseEnabled: true, // Enables the WebView database databaseEnabled: true, // Enables the WebView database
domStorageEnabled: true, // Enables DOM storage domStorageEnabled: true, // Enables DOM storage
builtInZoomControls: builtInZoomControls: true, // Enables the built-in zoom controls
true, // Enables the built-in zoom controls displayZoomControls: false, // Disables displaying zoom controls
displayZoomControls:
false, // Disables displaying zoom controls
safeBrowsingEnabled: true, // Enables Safe Browsing safeBrowsingEnabled: true, // Enables Safe Browsing
clearSessionCache: true, clearSessionCache: true,
), ),
ios: IOSInAppWebViewOptions( ios: IOSInAppWebViewOptions(allowsInlineMediaPlayback: true),
allowsInlineMediaPlayback: true,
),
), ),
androidOnPermissionRequest: (
androidOnPermissionRequest: (InAppWebViewController controller, InAppWebViewController controller,
String origin, List<String> resources) async { String origin,
List<String> resources,
) async {
return PermissionRequestResponse( return PermissionRequestResponse(
resources: resources, resources: resources,
action: PermissionRequestResponseAction.GRANT); action: PermissionRequestResponseAction.GRANT,
);
}, },
onWebViewCreated: (controller) { onWebViewCreated: (controller) {
webViewController = controller; webViewController = controller;
...@@ -170,27 +174,23 @@ class _FileviewerState extends State<Fileviewer> { ...@@ -170,27 +174,23 @@ class _FileviewerState extends State<Fileviewer> {
if (kDebugMode) { if (kDebugMode) {
debugPrint("consoleMessage${consoleMessage}"); debugPrint("consoleMessage${consoleMessage}");
} }
debugPrint( debugPrint("JavaScript console message: ${consoleMessage.message}");
"JavaScript console message: ${consoleMessage.message}");
}, },
); );
default: default:
return Container(); return Container();
} }
} }
Future<Uint8List?> _loadPdf(String url) async { Future<Uint8List?> _loadPdf(String url) async {
try { try {
final response = await http.get(Uri.parse(url)); final response = await http.get(Uri.parse(url));
if(response!=null){ if (response != null) {
if (response.statusCode == 200) { if (response.statusCode == 200) {
print(response.bodyBytes); print(response.bodyBytes);
return response.bodyBytes; return response.bodyBytes;
} }
} }
} catch (e) { } catch (e) {
print('Error loading PDF: $e'); print('Error loading PDF: $e');
} }
......
...@@ -37,10 +37,10 @@ packages: ...@@ -37,10 +37,10 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: async name: async
sha256: d2872f9c19731c2e5f10444b14686eb7cc85c76274bd6c16e1816bff9a3bab63 sha256: "758e6d74e971c3e5aceb4110bfd6698efc7f501675bcfe0c775459a8140750eb"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "2.12.0" version: "2.13.0"
barcode: barcode:
dependency: transitive dependency: transitive
description: description:
...@@ -285,10 +285,10 @@ packages: ...@@ -285,10 +285,10 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: fake_async name: fake_async
sha256: "6a95e56b2449df2273fd8c45a662d6947ce1ebb7aafe80e550a3f68297f3cacc" sha256: "5368f224a74523e8d2e7399ea1638b37aecfca824a3cc4dfdf77bf1fa905ac44"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "1.3.2" version: "1.3.3"
ffi: ffi:
dependency: transitive dependency: transitive
description: description:
...@@ -924,26 +924,26 @@ packages: ...@@ -924,26 +924,26 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: leak_tracker name: leak_tracker
sha256: c35baad643ba394b40aac41080300150a4f08fd0fd6a10378f8f7c6bc161acec sha256: "8dcda04c3fc16c14f48a7bb586d4be1f0d1572731b6d81d51772ef47c02081e0"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "10.0.8" version: "11.0.1"
leak_tracker_flutter_testing: leak_tracker_flutter_testing:
dependency: transitive dependency: transitive
description: description:
name: leak_tracker_flutter_testing name: leak_tracker_flutter_testing
sha256: f8b613e7e6a13ec79cfdc0e97638fddb3ab848452eff057653abd3edba760573 sha256: "1dbc140bb5a23c75ea9c4811222756104fbcd1a27173f0c34ca01e16bea473c1"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "3.0.9" version: "3.0.10"
leak_tracker_testing: leak_tracker_testing:
dependency: transitive dependency: transitive
description: description:
name: leak_tracker_testing name: leak_tracker_testing
sha256: "6ba465d5d76e67ddf503e1161d1f4a6bc42306f9d66ca1e8f079a47290fb06d3" sha256: "8d5a2d49f4a66b49744b23b018848400d23e54caf9463f4eb20df3eb8acb2eb1"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "3.0.1" version: "3.0.2"
lints: lints:
dependency: transitive dependency: transitive
description: description:
...@@ -1641,10 +1641,10 @@ packages: ...@@ -1641,10 +1641,10 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: vm_service name: vm_service
sha256: "0968250880a6c5fe7edc067ed0a13d4bae1577fe2771dcf3010d52c4a9d3ca14" sha256: ddfa8d30d89985b96407efce8acbdd124701f96741f2d981ca860662f1c0dc02
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "14.3.1" version: "15.0.0"
web: web:
dependency: transitive dependency: transitive
description: description:
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment