UNPKG

create-expo-cljs-app

Version:

Create a react native application with Expo and Shadow-CLJS!

72 lines (58 loc) 1.59 kB
/** * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @flow * @format */ 'use strict'; import AnimatedInterpolation from './AnimatedInterpolation'; import AnimatedNode from './AnimatedNode'; import AnimatedWithChildren from './AnimatedWithChildren'; import type {InterpolationConfigType} from './AnimatedInterpolation'; class AnimatedDiffClamp extends AnimatedWithChildren { _a: AnimatedNode; _min: number; _max: number; _value: number; _lastValue: number; constructor(a: AnimatedNode, min: number, max: number) { super(); this._a = a; this._min = min; this._max = max; this._value = this._lastValue = this._a.__getValue(); } __makeNative() { this._a.__makeNative(); super.__makeNative(); } interpolate(config: InterpolationConfigType): AnimatedInterpolation { return new AnimatedInterpolation(this, config); } __getValue(): number { const value = this._a.__getValue(); const diff = value - this._lastValue; this._lastValue = value; this._value = Math.min(Math.max(this._value + diff, this._min), this._max); return this._value; } __attach(): void { this._a.__addChild(this); } __detach(): void { this._a.__removeChild(this); super.__detach(); } __getNativeConfig(): any { return { type: 'diffclamp', input: this._a.__getNativeTag(), min: this._min, max: this._max, }; } } export default AnimatedDiffClamp;