| Index: sdk/lib/indexed_db/dartium/indexed_db_dartium.dart
|
| diff --git a/sdk/lib/indexed_db/dartium/indexed_db_dartium.dart b/sdk/lib/indexed_db/dartium/indexed_db_dartium.dart
|
| index 445f2febef3652cf7d2dabdf9d19447b82e402d2..0b72733c5c67cd9b3a4f1d52676c63b2bdbe7d6d 100644
|
| --- a/sdk/lib/indexed_db/dartium/indexed_db_dartium.dart
|
| +++ b/sdk/lib/indexed_db/dartium/indexed_db_dartium.dart
|
| @@ -1,5 +1,6 @@
|
| library indexed_db;
|
|
|
| +import 'dart:async';
|
| import 'dart:html';
|
| import 'dart:html_common';
|
| import 'dart:nativewrappers';
|
| @@ -119,6 +120,12 @@ class CursorWithValue extends Cursor {
|
| class Database extends EventTarget {
|
| Database.internal() : super.internal();
|
|
|
| + static const HtmlStreamProvider<Event> abortEvent = const HtmlStreamProvider<Event>('abort');
|
| +
|
| + static const HtmlStreamProvider<Event> errorEvent = const HtmlStreamProvider<Event>('error');
|
| +
|
| + static const HtmlStreamProvider<UpgradeNeededEvent> versionChangeEvent = const HtmlStreamProvider<UpgradeNeededEvent>('versionchange');
|
| +
|
| /// @domName EventTarget.addEventListener, EventTarget.removeEventListener, EventTarget.dispatchEvent; @docsEditable true
|
| DatabaseEvents get on =>
|
| new DatabaseEvents(this);
|
| @@ -184,6 +191,12 @@ class Database extends EventTarget {
|
| /** @domName IDBDatabase.transaction_3 */
|
| Transaction _transaction_3(storeName_OR_storeNames, mode) native "IDBDatabase_transaction_3_Callback";
|
|
|
| + Stream<Event> get onAbort => abortEvent.forTarget(this);
|
| +
|
| + Stream<Event> get onError => errorEvent.forTarget(this);
|
| +
|
| + Stream<UpgradeNeededEvent> get onVersionChange => versionChangeEvent.forTarget(this);
|
| +
|
| }
|
|
|
| /// @docsEditable true
|
| @@ -742,10 +755,18 @@ class ObjectStore extends NativeFieldWrapperClass1 {
|
| class OpenDBRequest extends Request implements EventTarget {
|
| OpenDBRequest.internal() : super.internal();
|
|
|
| + static const HtmlStreamProvider<Event> blockedEvent = const HtmlStreamProvider<Event>('blocked');
|
| +
|
| + static const HtmlStreamProvider<VersionChangeEvent> upgradeNeededEvent = const HtmlStreamProvider<VersionChangeEvent>('upgradeneeded');
|
| +
|
| /// @domName EventTarget.addEventListener, EventTarget.removeEventListener, EventTarget.dispatchEvent; @docsEditable true
|
| OpenDBRequestEvents get on =>
|
| new OpenDBRequestEvents(this);
|
|
|
| + Stream<Event> get onBlocked => blockedEvent.forTarget(this);
|
| +
|
| + Stream<VersionChangeEvent> get onUpgradeNeeded => upgradeNeededEvent.forTarget(this);
|
| +
|
| }
|
|
|
| /// @docsEditable true
|
| @@ -770,6 +791,10 @@ class OpenDBRequestEvents extends RequestEvents {
|
| class Request extends EventTarget {
|
| Request.internal() : super.internal();
|
|
|
| + static const HtmlStreamProvider<Event> errorEvent = const HtmlStreamProvider<Event>('error');
|
| +
|
| + static const HtmlStreamProvider<Event> successEvent = const HtmlStreamProvider<Event>('success');
|
| +
|
| /// @domName EventTarget.addEventListener, EventTarget.removeEventListener, EventTarget.dispatchEvent; @docsEditable true
|
| RequestEvents get on =>
|
| new RequestEvents(this);
|
| @@ -810,6 +835,10 @@ class Request extends EventTarget {
|
| /** @domName IDBRequest.removeEventListener */
|
| void $dom_removeEventListener(String type, EventListener listener, [bool useCapture]) native "IDBRequest_removeEventListener_Callback";
|
|
|
| + Stream<Event> get onError => errorEvent.forTarget(this);
|
| +
|
| + Stream<Event> get onSuccess => successEvent.forTarget(this);
|
| +
|
| }
|
|
|
| /// @docsEditable true
|
| @@ -834,6 +863,12 @@ class RequestEvents extends Events {
|
| class Transaction extends EventTarget {
|
| Transaction.internal() : super.internal();
|
|
|
| + static const HtmlStreamProvider<Event> abortEvent = const HtmlStreamProvider<Event>('abort');
|
| +
|
| + static const HtmlStreamProvider<Event> completeEvent = const HtmlStreamProvider<Event>('complete');
|
| +
|
| + static const HtmlStreamProvider<Event> errorEvent = const HtmlStreamProvider<Event>('error');
|
| +
|
| /// @domName EventTarget.addEventListener, EventTarget.removeEventListener, EventTarget.dispatchEvent; @docsEditable true
|
| TransactionEvents get on =>
|
| new TransactionEvents(this);
|
| @@ -874,6 +909,12 @@ class Transaction extends EventTarget {
|
| /** @domName IDBTransaction.removeEventListener */
|
| void $dom_removeEventListener(String type, EventListener listener, [bool useCapture]) native "IDBTransaction_removeEventListener_Callback";
|
|
|
| + Stream<Event> get onAbort => abortEvent.forTarget(this);
|
| +
|
| + Stream<Event> get onComplete => completeEvent.forTarget(this);
|
| +
|
| + Stream<Event> get onError => errorEvent.forTarget(this);
|
| +
|
| }
|
|
|
| /// @docsEditable true
|
| @@ -937,10 +978,14 @@ class VersionChangeEvent extends Event {
|
| class VersionChangeRequest extends Request implements EventTarget {
|
| VersionChangeRequest.internal() : super.internal();
|
|
|
| + static const HtmlStreamProvider<Event> blockedEvent = const HtmlStreamProvider<Event>('blocked');
|
| +
|
| /// @domName EventTarget.addEventListener, EventTarget.removeEventListener, EventTarget.dispatchEvent; @docsEditable true
|
| VersionChangeRequestEvents get on =>
|
| new VersionChangeRequestEvents(this);
|
|
|
| + Stream<Event> get onBlocked => blockedEvent.forTarget(this);
|
| +
|
| }
|
|
|
| /// @docsEditable true
|
|
|