404

[ Avaa Bypassed ]




Upload:

Command:

botdev@3.139.60.67: ~ $
import { Observable } from '../Observable';
import { Operator } from '../Operator';
import { Subscriber } from '../Subscriber';
import { MonoTypeOperatorFunction, TeardownLogic } from '../types';
import { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';

/**
 * Returns an Observable that emits all items emitted by the source Observable that are distinct by comparison from previous items.
 *
 * If a keySelector function is provided, then it will project each value from the source observable into a new value that it will
 * check for equality with previously projected values. If a keySelector function is not provided, it will use each value from the
 * source observable directly with an equality check against previous values.
 *
 * In JavaScript runtimes that support `Set`, this operator will use a `Set` to improve performance of the distinct value checking.
 *
 * In other runtimes, this operator will use a minimal implementation of `Set` that relies on an `Array` and `indexOf` under the
 * hood, so performance will degrade as more values are checked for distinction. Even in newer browsers, a long-running `distinct`
 * use might result in memory leaks. To help alleviate this in some scenarios, an optional `flushes` parameter is also provided so
 * that the internal `Set` can be "flushed", basically clearing it of values.
 *
 * ## Examples
 * A simple example with numbers
 * ```ts
 * import { of } from 'rxjs';
 * import { distinct } from 'rxjs/operators';
 *
 * of(1, 1, 2, 2, 2, 1, 2, 3, 4, 3, 2, 1).pipe(
 *     distinct(),
 *   )
 *   .subscribe(x => console.log(x)); // 1, 2, 3, 4
 * ```
 *
 * An example using a keySelector function
 * ```typescript
 * import { of } from 'rxjs';
 * import { distinct } from 'rxjs/operators';
 *
 * interface Person {
 *    age: number,
 *    name: string
 * }
 *
 * of<Person>(
 *     { age: 4, name: 'Foo'},
 *     { age: 7, name: 'Bar'},
 *     { age: 5, name: 'Foo'},
 *   ).pipe(
 *     distinct((p: Person) => p.name),
 *   )
 *   .subscribe(x => console.log(x));
 *
 * // displays:
 * // { age: 4, name: 'Foo' }
 * // { age: 7, name: 'Bar' }
 * ```
 * @see {@link distinctUntilChanged}
 * @see {@link distinctUntilKeyChanged}
 *
 * @param {function} [keySelector] Optional function to select which value you want to check as distinct.
 * @param {Observable} [flushes] Optional Observable for flushing the internal HashSet of the operator.
 * @return {Observable} An Observable that emits items from the source Observable with distinct values.
 * @method distinct
 * @owner Observable
 */
export function distinct<T, K>(keySelector?: (value: T) => K,
                               flushes?: Observable<any>): MonoTypeOperatorFunction<T> {
  return (source: Observable<T>) => source.lift(new DistinctOperator(keySelector, flushes));
}

class DistinctOperator<T, K> implements Operator<T, T> {
  constructor(private keySelector?: (value: T) => K, private flushes?: Observable<any>) {
  }

  call(subscriber: Subscriber<T>, source: any): TeardownLogic {
    return source.subscribe(new DistinctSubscriber(subscriber, this.keySelector, this.flushes));
  }
}

/**
 * We need this JSDoc comment for affecting ESDoc.
 * @ignore
 * @extends {Ignored}
 */
export class DistinctSubscriber<T, K> extends SimpleOuterSubscriber<T, T> {
  private values = new Set<K>();

  constructor(destination: Subscriber<T>, private keySelector?: (value: T) => K, flushes?: Observable<any>) {
    super(destination);

    if (flushes) {
      this.add(innerSubscribe(flushes, new SimpleInnerSubscriber(this)));
    }
  }

  notifyNext(): void {
    this.values.clear();
  }

  notifyError(error: any): void {
    this._error(error);
  }

  protected _next(value: T): void {
    if (this.keySelector) {
      this._useKeySelector(value);
    } else {
      this._finalizeNext(value, value);
    }
  }

  private _useKeySelector(value: T): void {
    let key: K;
    const { destination } = this;
    try {
      key = this.keySelector!(value);
    } catch (err) {
      destination.error!(err);
      return;
    }
    this._finalizeNext(key, value);
  }

  private _finalizeNext(key: K|T, value: T) {
    const { values } = this;
    if (!values.has(<K>key)) {
      values.add(<K>key);
      this.destination.next!(value);
    }
  }

}

Filemanager

Name Type Size Permission Actions
audit.ts File 4.14 KB 0644
auditTime.ts File 2.38 KB 0644
buffer.ts File 2.54 KB 0644
bufferCount.ts File 4.46 KB 0644
bufferTime.ts File 8.51 KB 0644
bufferToggle.ts File 5.6 KB 0644
bufferWhen.ts File 3.89 KB 0644
catchError.ts File 4.72 KB 0644
combineAll.ts File 2.44 KB 0644
combineLatest.ts File 4.32 KB 0644
concat.ts File 2.18 KB 0644
concatAll.ts File 2.26 KB 0644
concatMap.ts File 3.4 KB 0644
concatMapTo.ts File 3.05 KB 0644
count.ts File 3.78 KB 0644
debounce.ts File 4.88 KB 0644
debounceTime.ts File 4.54 KB 0644
defaultIfEmpty.ts File 2.69 KB 0644
delay.ts File 5.09 KB 0644
delayWhen.ts File 7.7 KB 0644
dematerialize.ts File 2.58 KB 0644
distinct.ts File 4.22 KB 0644
distinctUntilChanged.ts File 3.76 KB 0644
distinctUntilKeyChanged.ts File 2.79 KB 0644
elementAt.ts File 2.56 KB 0644
endWith.ts File 4.06 KB 0644
every.ts File 2.54 KB 0644
exhaust.ts File 3.2 KB 0644
exhaustMap.ts File 5.64 KB 0644
expand.ts File 6.18 KB 0644
filter.ts File 3.69 KB 0644
finalize.ts File 1.3 KB 0644
find.ts File 3.81 KB 0644
findIndex.ts File 1.86 KB 0644
first.ts File 3.36 KB 0644
groupBy.ts File 9.95 KB 0644
ignoreElements.ts File 1.49 KB 0644
index.ts File 4.02 KB 0644
isEmpty.ts File 2.67 KB 0644
last.ts File 2.36 KB 0644
map.ts File 3.04 KB 0644
mapTo.ts File 1.9 KB 0644
materialize.ts File 3.25 KB 0644
max.ts File 1.54 KB 0644
merge.ts File 3.59 KB 0644
mergeAll.ts File 2.43 KB 0644
mergeMap.ts File 6.28 KB 0644
mergeMapTo.ts File 2.56 KB 0644
mergeScan.ts File 4.65 KB 0644
min.ts File 1.54 KB 0644
multicast.ts File 3.46 KB 0644
observeOn.ts File 5.17 KB 0644
onErrorResumeNext.ts File 8.18 KB 0644
pairwise.ts File 2.43 KB 0644
partition.ts File 2.68 KB 0644
pluck.ts File 3.07 KB 0644
publish.ts File 2.51 KB 0644
publishBehavior.ts File 589 B 0644
publishLast.ts File 2.06 KB 0644
publishReplay.ts File 1.47 KB 0644
race.ts File 1.85 KB 0644
reduce.ts File 3.71 KB 0644
refCount.ts File 5 KB 0644
repeat.ts File 3.03 KB 0644
repeatWhen.ts File 4.15 KB 0644
retry.ts File 2.74 KB 0644
retryWhen.ts File 3.45 KB 0644
sample.ts File 2.78 KB 0644
sampleTime.ts File 3.18 KB 0644
scan.ts File 4.13 KB 0644
sequenceEqual.ts File 5.16 KB 0644
share.ts File 1.02 KB 0644
shareReplay.ts File 4.19 KB 0644
single.ts File 3.79 KB 0644
skip.ts File 1.27 KB 0644
skipLast.ts File 2.81 KB 0644
skipUntil.ts File 3.81 KB 0644
skipWhile.ts File 1.95 KB 0644
startWith.ts File 4.35 KB 0644
subscribeOn.ts File 2.56 KB 0644
switchAll.ts File 1.99 KB 0644
switchMap.ts File 6.04 KB 0644
switchMapTo.ts File 2.56 KB 0644
take.ts File 2.74 KB 0644
takeLast.ts File 3.44 KB 0644
takeUntil.ts File 2.79 KB 0644
takeWhile.ts File 3.87 KB 0644
tap.ts File 5.33 KB 0644
throttle.ts File 4.83 KB 0644
throttleTime.ts File 5.83 KB 0644
throwIfEmpty.ts File 2.19 KB 0644
timeInterval.ts File 2.49 KB 0644
timeout.ts File 4.07 KB 0644
timeoutWith.ts File 6.13 KB 0644
timestamp.ts File 1.67 KB 0644
toArray.ts File 1.12 KB 0644
window.ts File 3.72 KB 0644
windowCount.ts File 4.82 KB 0644
windowTime.ts File 9.9 KB 0644
windowToggle.ts File 6.2 KB 0644
windowWhen.ts File 4.57 KB 0644
withLatestFrom.ts File 7.72 KB 0644
zip.ts File 3.35 KB 0644
zipAll.ts File 653 B 0644