Skip to content

Commit 7df2085

Browse files
authored
[web] Removes a few deprecated API usages. (flutter#6177)
This PR removes a bunch of deprecated APIs from the following packages: * `web_benchmarks` * `file_selector_web` * `cross_file` * `image_picker_platform_interface` ## Issues * Fixes flutter#143113 * Fixes flutter#143399 * Fixes flutter#143878 * Fixes flutter#143892 * Closes flutter/packages#5248
1 parent 67470fc commit 7df2085

File tree

17 files changed

+67
-43
lines changed

17 files changed

+67
-43
lines changed

packages/cross_file/CHANGELOG.md

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,7 @@
1+
## 0.3.4+1
2+
3+
* Removes a few deprecated API usages.
4+
15
## 0.3.4
26

37
* Updates to web code to package `web: ^0.5.0`.

packages/cross_file/lib/src/types/html.dart

Lines changed: 20 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@ import 'dart:js_interop';
88
import 'dart:typed_data';
99

1010
import 'package:meta/meta.dart';
11-
import 'package:web/helpers.dart';
11+
import 'package:web/web.dart';
1212

1313
import '../web_helpers/web_helpers.dart';
1414
import 'base.dart';
@@ -133,22 +133,26 @@ class XFile extends XFileBase {
133133
throw Exception('Safari cannot handle XFiles larger than 4GB.');
134134
}
135135

136-
late XMLHttpRequest request;
137-
try {
138-
request = await HttpRequest.request(path, responseType: 'blob');
139-
} on ProgressEvent catch (e) {
140-
if (e.type == 'error') {
141-
throw Exception(
142-
'Could not load Blob from its URL. Has it been revoked?');
143-
}
144-
rethrow;
145-
}
146-
147-
_browserBlob = request.response as Blob?;
136+
final Completer<Blob> blobCompleter = Completer<Blob>();
148137

149-
assert(_browserBlob != null, 'The Blob backing this XFile cannot be null!');
150-
151-
return _browserBlob!;
138+
late XMLHttpRequest request;
139+
request = XMLHttpRequest()
140+
..open('get', path, true)
141+
..responseType = 'blob'
142+
..onLoad.listen((ProgressEvent e) {
143+
assert(request.response != null,
144+
'The Blob backing this XFile cannot be null!');
145+
blobCompleter.complete(request.response! as Blob);
146+
})
147+
..onError.listen((ProgressEvent e) {
148+
if (e.type == 'error') {
149+
blobCompleter.completeError(Exception(
150+
'Could not load Blob from its URL. Has it been revoked?'));
151+
}
152+
})
153+
..send();
154+
155+
return blobCompleter.future;
152156
}
153157

154158
@override

packages/cross_file/lib/src/web_helpers/web_helpers.dart

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
// Use of this source code is governed by a BSD-style license that can be
33
// found in the LICENSE file.
44

5-
import 'package:web/helpers.dart';
5+
import 'package:web/web.dart';
66

77
/// Create anchor element with download attribute
88
HTMLAnchorElement createAnchorElement(String href, String? suggestedName) =>
@@ -20,11 +20,11 @@ void addElementToContainerAndClick(Element container, HTMLElement element) {
2020

2121
/// Initializes a DOM container where elements can be injected.
2222
Element ensureInitialized(String id) {
23-
Element? target = querySelector('#$id');
23+
Element? target = document.querySelector('#$id');
2424
if (target == null) {
2525
final Element targetElement = document.createElement('flt-x-file')..id = id;
2626

27-
querySelector('body')!.appendChild(targetElement);
27+
document.body!.appendChild(targetElement);
2828
target = targetElement;
2929
}
3030
return target;

packages/cross_file/pubspec.yaml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ name: cross_file
22
description: An abstraction to allow working with files across multiple platforms.
33
repository: https://github.com/flutter/packages/tree/main/packages/cross_file
44
issue_tracker: https://github.com/flutter/flutter/issues?q=is%3Aissue+is%3Aopen+label%3A%22p%3A+cross_file%22
5-
version: 0.3.4
5+
version: 0.3.4+1
66

77
environment:
88
sdk: ^3.3.0

packages/cross_file/test/x_file_html_test.dart

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@ import 'dart:typed_data';
1111

1212
import 'package:cross_file/cross_file.dart';
1313
import 'package:test/test.dart';
14-
import 'package:web/helpers.dart' as html;
14+
import 'package:web/web.dart' as html;
1515

1616
const String expectedStringContents = 'Hello, world! I ❤ ñ! 空手';
1717
final Uint8List bytes = Uint8List.fromList(utf8.encode(expectedStringContents));
@@ -95,7 +95,7 @@ void main() {
9595
await file.saveTo('');
9696

9797
final html.Element? container =
98-
html.querySelector('#$crossFileDomElementId');
98+
html.document.querySelector('#$crossFileDomElementId');
9999

100100
expect(container, isNotNull);
101101
});
@@ -106,7 +106,7 @@ void main() {
106106
await file.saveTo('path');
107107

108108
final html.Element container =
109-
html.querySelector('#$crossFileDomElementId')!;
109+
html.document.querySelector('#$crossFileDomElementId')!;
110110

111111
late html.HTMLAnchorElement element;
112112
for (int i = 0; i < container.childNodes.length; i++) {

packages/file_selector/file_selector_web/CHANGELOG.md

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,7 @@
1+
## 0.9.4+1
2+
3+
* Removes a few deprecated API usages.
4+
15
## 0.9.4
26

37
* Updates web code to package `web: ^0.5.0`.

packages/file_selector/file_selector_web/example/integration_test/dom_helper_test.dart

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@ import 'package:file_selector_platform_interface/file_selector_platform_interfac
88
import 'package:file_selector_web/src/dom_helper.dart';
99
import 'package:flutter_test/flutter_test.dart';
1010
import 'package:integration_test/integration_test.dart';
11-
import 'package:web/helpers.dart';
11+
import 'package:web/web.dart';
1212

1313
void main() {
1414
group('dom_helper', () {
@@ -41,7 +41,8 @@ void main() {
4141

4242
setUp(() {
4343
domHelper = DomHelper();
44-
input = (createElementTag('input') as HTMLInputElement)..type = 'file';
44+
input = (document.createElement('input') as HTMLInputElement)
45+
..type = 'file';
4546
});
4647

4748
group('getFiles', () {

packages/file_selector/file_selector_web/example/integration_test/file_selector_web_test.dart

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ import 'package:file_selector_web/file_selector_web.dart';
99
import 'package:file_selector_web/src/dom_helper.dart';
1010
import 'package:flutter_test/flutter_test.dart';
1111
import 'package:integration_test/integration_test.dart';
12-
import 'package:web/helpers.dart';
12+
import 'package:web/web.dart';
1313

1414
void main() {
1515
group('FileSelectorWeb', () {

packages/file_selector/file_selector_web/lib/src/dom_helper.dart

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@ import 'dart:js_interop';
88
import 'package:file_selector_platform_interface/file_selector_platform_interface.dart';
99
import 'package:flutter/foundation.dart' show visibleForTesting;
1010
import 'package:flutter/services.dart';
11-
import 'package:web/helpers.dart';
11+
import 'package:web/web.dart';
1212

1313
/// Class to manipulate the DOM with the intention of reading files from it.
1414
class DomHelper {

packages/file_selector/file_selector_web/pubspec.yaml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ name: file_selector_web
22
description: Web platform implementation of file_selector
33
repository: https://github.com/flutter/packages/tree/main/packages/file_selector/file_selector_web
44
issue_tracker: https://github.com/flutter/flutter/issues?q=is%3Aissue+is%3Aopen+label%3A%22p%3A+file_selector%22
5-
version: 0.9.4
5+
version: 0.9.4+1
66

77
environment:
88
sdk: ^3.3.0

0 commit comments

Comments
 (0)