2016-06-23 12:47:54 -04:00
|
|
|
/**
|
|
|
|
* @license
|
2020-05-19 15:08:49 -04:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2016-06-23 12:47:54 -04:00
|
|
|
*
|
|
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
|
|
* found in the LICENSE file at https://angular.io/license
|
|
|
|
*/
|
|
|
|
|
2016-09-27 20:12:25 -04:00
|
|
|
import {Component} from '@angular/core';
|
2018-02-27 17:06:06 -05:00
|
|
|
import {Observable, Observer} from 'rxjs';
|
2015-11-02 18:46:59 -05:00
|
|
|
|
2016-05-31 21:23:29 -04:00
|
|
|
// #docregion AsyncPipePromise
|
2015-11-02 18:46:59 -05:00
|
|
|
@Component({
|
2016-09-09 00:41:09 -04:00
|
|
|
selector: 'async-promise-pipe',
|
2015-11-02 18:46:59 -05:00
|
|
|
template: `<div>
|
2020-05-19 15:08:49 -04:00
|
|
|
<code>promise|async</code>:
|
2015-12-10 11:28:29 -05:00
|
|
|
<button (click)="clicked()">{{ arrived ? 'Reset' : 'Resolve' }}</button>
|
2016-09-09 00:41:09 -04:00
|
|
|
<span>Wait for it... {{ greeting | async }}</span>
|
2015-11-02 18:46:59 -05:00
|
|
|
</div>`
|
|
|
|
})
|
2016-09-09 00:41:09 -04:00
|
|
|
export class AsyncPromisePipeComponent {
|
2017-03-24 12:57:05 -04:00
|
|
|
greeting: Promise<string>|null = null;
|
2015-11-19 18:17:35 -05:00
|
|
|
arrived: boolean = false;
|
|
|
|
|
2017-03-24 12:57:05 -04:00
|
|
|
private resolve: Function|null = null;
|
2015-11-02 18:46:59 -05:00
|
|
|
|
2020-04-13 19:40:21 -04:00
|
|
|
constructor() {
|
|
|
|
this.reset();
|
|
|
|
}
|
2015-11-02 18:46:59 -05:00
|
|
|
|
|
|
|
reset() {
|
2015-11-19 18:17:35 -05:00
|
|
|
this.arrived = false;
|
2020-04-13 19:40:21 -04:00
|
|
|
this.greeting = new Promise<string>((resolve, reject) => {
|
|
|
|
this.resolve = resolve;
|
|
|
|
});
|
2015-11-02 18:46:59 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
clicked() {
|
2015-11-19 18:17:35 -05:00
|
|
|
if (this.arrived) {
|
2015-11-02 18:46:59 -05:00
|
|
|
this.reset();
|
|
|
|
} else {
|
2020-04-13 19:40:21 -04:00
|
|
|
this.resolve!('hi there!');
|
2015-11-19 18:17:35 -05:00
|
|
|
this.arrived = true;
|
2015-11-02 18:46:59 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// #enddocregion
|
|
|
|
|
|
|
|
// #docregion AsyncPipeObservable
|
2016-09-09 00:41:09 -04:00
|
|
|
@Component({
|
|
|
|
selector: 'async-observable-pipe',
|
|
|
|
template: '<div><code>observable|async</code>: Time: {{ time | async }}</div>'
|
|
|
|
})
|
|
|
|
export class AsyncObservablePipeComponent {
|
2018-02-27 17:06:06 -05:00
|
|
|
time = new Observable<string>((observer: Observer<string>) => {
|
2016-09-09 00:41:09 -04:00
|
|
|
setInterval(() => observer.next(new Date().toString()), 1000);
|
2016-02-11 20:01:17 -05:00
|
|
|
});
|
2015-11-02 18:46:59 -05:00
|
|
|
}
|
|
|
|
// #enddocregion
|
2016-09-09 00:41:09 -04:00
|
|
|
|
|
|
|
// For some reason protractor hangs on setInterval. So we will run outside of angular zone so that
|
|
|
|
// protractor will not see us. Also we want to have this outside the docregion so as not to confuse
|
|
|
|
// the reader.
|
|
|
|
function setInterval(fn: Function, delay: number) {
|
2019-01-28 15:59:25 -05:00
|
|
|
const zone = (window as any)['Zone'].current;
|
2016-11-12 08:08:58 -05:00
|
|
|
let rootZone = zone;
|
2016-09-09 00:41:09 -04:00
|
|
|
while (rootZone.parent) {
|
|
|
|
rootZone = rootZone.parent;
|
|
|
|
}
|
2019-06-14 03:29:04 -04:00
|
|
|
rootZone.run(() => {
|
2020-04-13 19:40:21 -04:00
|
|
|
window.setInterval(function(this: unknown) {
|
|
|
|
zone.run(fn, this, arguments as any);
|
|
|
|
}, delay);
|
2019-06-14 03:29:04 -04:00
|
|
|
});
|
2016-09-09 00:41:09 -04:00
|
|
|
}
|