diff --git a/.eslintignore b/.eslintignore new file mode 100644 index 00000000..9803d45e --- /dev/null +++ b/.eslintignore @@ -0,0 +1,6 @@ +node_modules +build +dist +storybook-static +scripts +src/types \ No newline at end of file diff --git a/.eslintrc.js b/.eslintrc.js new file mode 100644 index 00000000..05991cec --- /dev/null +++ b/.eslintrc.js @@ -0,0 +1,22 @@ +module.exports = { + root: true, + extends: ['@react-native-community', 'prettier'], + parser: '@typescript-eslint/parser', + parserOptions: { + ecmaVersion: 13, + sourceType: 'module', + }, + plugins: ['@typescript-eslint', 'react', 'react-native'], + env: { + jest: true, + 'react-native/react-native': true, + browser: true, + es2021: true, + }, + rules: { + 'no-shadow': 'off', + '@typescript-eslint/no-shadow': ['error'], + '@typescript-eslint/no-unused-vars': ['warn'], + }, + globals: { fetch: false, NodeJS: true }, +}; diff --git a/.gitignore b/.gitignore index c5464d9d..d3263697 100644 --- a/.gitignore +++ b/.gitignore @@ -8,6 +8,9 @@ node_modules/ npm-debug.log yarn-error.log +# Typescript +dist/ + # Xcode # build/ diff --git a/.nvmrc b/.nvmrc index ad50938d..53d838af 100644 --- a/.nvmrc +++ b/.nvmrc @@ -1 +1 @@ -lts/erbium \ No newline at end of file +lts/gallium diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 00000000..b512c09d --- /dev/null +++ b/.prettierignore @@ -0,0 +1 @@ +node_modules \ No newline at end of file diff --git a/.prettierrc.js b/.prettierrc.js new file mode 100644 index 00000000..e2c88acd --- /dev/null +++ b/.prettierrc.js @@ -0,0 +1,7 @@ +module.exports = { + bracketSpacing: true, + bracketSameLine: true, + singleQuote: true, + trailingComma: 'all', + arrowParens: 'avoid', +}; diff --git a/.vscode/settings.json b/.vscode/settings.json index 1c1db490..a53444b6 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -1,7 +1,12 @@ { - "javascript.validate.enable": false, - "typescript.validate.enable": false, - "flow.enabled": true, + "javascript.validate.enable": true, + "typescript.validate.enable": true, + "editor.formatOnSave": true, + "eslint.format.enable": true, + "editor.codeActionsOnSave": { + "source.fixAll.eslint": true + }, "eslint.enable": true, - "flow.pathToFlow": "${workspaceFolder}/node_modules/.bin/flow" + "eslint.validate": ["javascript", "typescript"], + "cSpell.words": ["ADSB", "ATTI", "DCINELIKE", "DLOG", "PANO"] } diff --git a/android/build.gradle b/android/build.gradle index d3adfba3..31f25829 100644 --- a/android/build.gradle +++ b/android/build.gradle @@ -64,14 +64,14 @@ dependencies { //noinspection GradleDynamicVersion implementation 'com.facebook.react:react-native:+' // From node_modules - implementation ('com.dji:dji-sdk:4.16', { + implementation ('com.dji:dji-sdk:4.16.1', { // Uncomment the following line if your app does not need Anti Distortion for // Mavic 2 Pro and Mavic 2 Zoom. It will greatly reducing the size of the APK: exclude module: 'library-anti-distortion' // Uncomment the following line if your APP does not need network RTK exclude module: 'library-networkrtk-helper' }) - compileOnly 'com.dji:dji-sdk-provided:4.16' + compileOnly 'com.dji:dji-sdk-provided:4.16.1' implementation 'androidx.constraintlayout:constraintlayout:2.0.0-alpha2' } diff --git a/android/src/main/java/com/aerobotics/DjiMobile/CameraControlNative.java b/android/src/main/java/com/aerobotics/DjiMobile/CameraControlNative.java index fa47e35c..29c12027 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/CameraControlNative.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/CameraControlNative.java @@ -71,17 +71,17 @@ public void onFailure(@NonNull DJIError djiError) { } @ReactMethod - public void getWhiteBalance(final Promise promise) { + public void getWhiteBalancePreset(final Promise promise) { DJIKey whiteBalanceKey = CameraKey.create(CameraKey.WHITE_BALANCE); DJISDKManager.getInstance().getKeyManager().getValue(whiteBalanceKey, new GetCallback() { @Override public void onSuccess(@NonNull Object value) { - if (value instanceof SettingsDefinitions.WhiteBalancePreset) { - promise.resolve(value.toString()); - } - if (value instanceof Integer) { - promise.resolve(value); + if (!(value instanceof WhiteBalance)) { + promise.reject(new Throwable("getWhiteBalance error: Unexpected whitebalance returned")); } + + WhiteBalance whiteBalance = (WhiteBalance) value; + promise.resolve(whiteBalance.getWhiteBalancePreset().toString()); } @Override @@ -633,4 +633,22 @@ public void onFailure(DJIError djiError) { }); } + @ReactMethod + public void setPhotoFileFormat(String format, final Promise promise) { + DJIKey key = CameraKey.create(CameraKey.PHOTO_FILE_FORMAT); + DJISDKManager.getInstance().getKeyManager().setValue(key, + SettingsDefinitions.PhotoFileFormat.valueOf((format)), + new SetCallback() { + @Override + public void onSuccess() { + promise.resolve("setPhotoFileFormat: photo file format set successfully"); + } + + @Override + public void onFailure(DJIError djiError) { + promise.reject(new Throwable("setPhotoFileFormat error: " + djiError.getDescription())); + } + }); + } + } diff --git a/android/src/main/java/com/aerobotics/DjiMobile/DJIMissionControlWrapper.java b/android/src/main/java/com/aerobotics/DjiMobile/DJIMissionControlWrapper.java index f0247123..b224008a 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/DJIMissionControlWrapper.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/DJIMissionControlWrapper.java @@ -340,6 +340,22 @@ public void onFailure(@NonNull DJIError djiError) { }); } + @ReactMethod + public void cancelGoHome(final Promise promise) { + DJIKey key = FlightControllerKey.create(FlightControllerKey.CANCEL_GO_HOME); + DJISDKManager.getInstance().getKeyManager().performAction(key, new ActionCallback() { + @Override + public void onSuccess() { + promise.resolve("DJI Mission Control: Cancel go home"); + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + promise.reject(new Throwable("cancelGoHome error: " + djiError.getDescription())); + } + }); + } + @ReactMethod public void unscheduleEverything(Promise promise) { DJISDKManager.getInstance().getMissionControl().unscheduleEverything(); diff --git a/android/src/main/java/com/aerobotics/DjiMobile/DJIMobile.java b/android/src/main/java/com/aerobotics/DjiMobile/DJIMobile.java index 1e630d98..75eabea8 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/DJIMobile.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/DJIMobile.java @@ -1,10 +1,12 @@ package com.aerobotics.DjiMobile; +import com.aerobotics.DjiMobile.WaypointMissionV2.WaypointMissionV2Wrapper; import com.facebook.react.bridge.Arguments; import com.facebook.react.bridge.ReactApplicationContext; import com.facebook.react.bridge.ReactContextBaseJavaModule; import com.facebook.react.bridge.ReactMethod; import com.facebook.react.bridge.Promise; +import com.facebook.react.bridge.ReadableArray; import com.facebook.react.bridge.WritableArray; import com.facebook.react.bridge.WritableMap; import com.facebook.react.modules.core.DeviceEventManagerModule; @@ -18,24 +20,35 @@ import androidx.annotation.NonNull; import androidx.annotation.Nullable; +import java.security.Key; +import java.util.ArrayList; +import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; import dji.common.camera.ExposureSettings; import dji.common.camera.SettingsDefinitions; +import dji.common.camera.SystemState; +import dji.common.camera.WhiteBalance; import dji.common.error.DJIError; import dji.common.error.DJISDKError; +import dji.common.flightcontroller.FlightMode; import dji.common.flightcontroller.GPSSignalLevel; import dji.common.flightcontroller.LocationCoordinate3D; +import dji.common.flightcontroller.RemoteControllerFlightMode; import dji.common.flightcontroller.VisionControlState; import dji.common.flightcontroller.VisionDetectionState; import dji.common.flightcontroller.VisionSensorPosition; import dji.common.flightcontroller.VisionSystemWarning; +import dji.common.flightcontroller.imu.IMUState; +import dji.common.flightcontroller.imu.SensorState; import dji.common.model.LocationCoordinate2D; import dji.common.product.Model; import dji.internal.diagnostics.DiagnosticsBaseHandler; import dji.keysdk.AirLinkKey; +import dji.keysdk.BatteryKey; +import dji.keysdk.CameraKey; import dji.keysdk.DJIKey; import dji.keysdk.FlightControllerKey; import dji.keysdk.KeyManager; @@ -69,6 +82,8 @@ public class DJIMobile extends ReactContextBaseJavaModule { private FileObserver flightLogObserver; private EventSender eventSender; + private List prevDiagnostics; + private VisionControlState.Callback visionControlStateCallback = new VisionControlState.Callback() { @Override public void onUpdate(VisionControlState visionControlState) { @@ -271,6 +286,10 @@ public void startEventListener(String eventName, Promise promise) { startProductConnectionListener(); break; + case CameraConnection: + startCameraConnectionListener(); + break; + case BatteryChargeRemaining: startBatteryPercentChargeRemainingListener(); break; @@ -295,6 +314,10 @@ public void startEventListener(String eventName, Promise promise) { startGPSSignalLevelListener(); break; + case SatelliteCount: + startSatelliteCountListener(); + break; + case AirLinkUplinkSignalQuality: startAirlinkUplinkSignalQualityListener(); break; @@ -311,6 +334,18 @@ public void startEventListener(String eventName, Promise promise) { startUltrasonicHeightListener(); break; + case RemoteControllerFlightMode: + startRemoteControllerFlightModeListener(); + break; + + case AircraftFlightMode: + startAircraftFlightModeListener(); + break; + + case AircraftIsFlying: + startAircraftIsFlyingListener(); + break; + case CompassHasError: startCompassHasErrorListener(); break; @@ -327,6 +362,10 @@ public void startEventListener(String eventName, Promise promise) { startSDCardIsReadOnlyListener(); break; + case SDCardAvailableCaptureCount: + startSDCardAvailableCaptureCountListener(); + break; + case GimbalIsAtYawStop: startGimbalIsAtYawStopListener(); break; @@ -342,7 +381,30 @@ public void startEventListener(String eventName, Promise promise) { case VisionControlState: startVisionControlStateListener(); break; - + case IsHomeLocationSet: + startIsHomeLocationSetListener(); + break; + case CameraIsShootingPhoto: + startCameraIsShootingPhotoListener(); + break; + case CameraIsShootingSinglePhoto: + startCameraIsShootingSinglePhotoListener(); + break; + case CameraIsStoringPhoto: + startCameraIsStoringPhotoListener(); + break; + case CameraWhiteBalance: + startCameraWhiteBalanceListener(); + break; + case CameraPhotoFileFormat: + startCameraPhotoFileFormatListener(); + break; + case CameraPhotoAspectRatio: + startCameraPhotoAspectRatioListener(); + break; + case CameraExposureMode: + startCameraExposureModeListener(); + break; default: promise.reject("Invalid Key", "Invalid Key"); break; @@ -357,6 +419,21 @@ public void startEventListener(String eventName, Promise promise) { } private void startProductConnectionListener() { + KeyManager keyManager = DJISDKManager.getInstance().getKeyManager(); + if (keyManager != null) { + DJIKey productConnectedKey = ProductKey.create(ProductKey.CONNECTION); + keyManager.getValue(productConnectedKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object o) { + if (o instanceof Boolean) { + sendEvent(SDKEvent.ProductConnection, (boolean) o ? "connected" : "disconnected"); + } + } + + @Override + public void onFailure(@NonNull DJIError djiError) {} + }); + } startEventListener(SDKEvent.ProductConnection, new EventListener() { @Override public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { @@ -367,7 +444,45 @@ public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) }); } + private void startCameraConnectionListener() { + getInitialSDKEventValue(SDKEvent.CameraConnection, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleCameraConnectionUpdate(o, true); + } + }); + startEventListener(SDKEvent.CameraConnection, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleCameraConnectionUpdate(newValue, false); + } + }); + } + + private void handleCameraConnectionUpdate(@Nullable Object newValue, final Boolean realtime) { + if (newValue != null && newValue instanceof Boolean) { + this.eventSender.processEvent(SDKEvent.CameraConnection, (boolean) newValue, realtime); + } + } + private void startBatteryPercentChargeRemainingListener() { + KeyManager keyManager = DJISDKManager.getInstance().getKeyManager(); + if (keyManager != null) { + DJIKey batteryKey = BatteryKey.create(BatteryKey.CHARGE_REMAINING_IN_PERCENT); + keyManager.getValue(batteryKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object o) { + if (o instanceof Integer) { + sendEvent(SDKEvent.BatteryChargeRemaining, o); + } + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + + } + }); + } startEventListener(SDKEvent.BatteryChargeRemaining, new EventListener() { @Override public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { @@ -379,22 +494,68 @@ public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) } private void startGPSSignalLevelListener() { + getInitialSDKEventValue(SDKEvent.AircraftGpsSignalLevel, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleGpsSignalLevelUpdate(o, true); + } + }); startEventListener(SDKEvent.AircraftGpsSignalLevel, new EventListener() { @Override public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { - if (newValue != null && newValue instanceof GPSSignalLevel) { - GPSSignalLevel gpsSignalLevel = (GPSSignalLevel) newValue; - Integer signalValue = gpsSignalLevel.value(); - if (gpsSignalLevel == GPSSignalLevel.NONE) { - signalValue = null; - } - sendEvent(SDKEvent.AircraftGpsSignalLevel, signalValue); + handleGpsSignalLevelUpdate(newValue, false); + } + }); + } + + private void handleGpsSignalLevelUpdate(@Nullable Object newValue, final Boolean realtime) { + if (newValue != null && newValue instanceof GPSSignalLevel) { + GPSSignalLevel gpsSignalLevel = (GPSSignalLevel) newValue; + Integer signalValue = gpsSignalLevel.value(); + if (gpsSignalLevel == GPSSignalLevel.NONE) { + signalValue = null; + } + this.eventSender.processEvent(SDKEvent.AircraftGpsSignalLevel, signalValue, realtime); + } + } + + private void startSatelliteCountListener() { + startEventListener(SDKEvent.SatelliteCount, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue != null && newValue instanceof Integer) { + sendEvent(SDKEvent.SatelliteCount, newValue); } } }); } + private void startAircraftLocationListener() { + KeyManager keyManager = DJISDKManager.getInstance().getKeyManager(); + if (keyManager != null) { + DJIKey key = FlightControllerKey.create(FlightControllerKey.AIRCRAFT_LOCATION); + keyManager.getValue(key, new GetCallback() { + @Override + public void onSuccess(@NonNull Object value) { + LocationCoordinate3D location = (LocationCoordinate3D) value; + double longitude = location.getLongitude(); + double latitude = location.getLatitude(); + double altitude = location.getAltitude(); + if (!Double.isNaN(longitude) && !Double.isNaN(latitude)) { + WritableMap params = Arguments.createMap(); + params.putDouble("longitude", longitude); + params.putDouble("latitude", latitude); + params.putDouble("altitude", altitude); + sendEvent(SDKEvent.AircraftLocation, params); //TODO: send as realtime event + } + } + + @Override + public void onFailure(@NonNull DJIError djiError) { } + }); + } + startEventListener(SDKEvent.AircraftLocation, new EventListener() { @Override public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { @@ -531,6 +692,19 @@ public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) } private void startAircraftCompassHeadingListener() { + DJIKey aircraftCompassHeadingKey = (DJIKey) SDKEvent.AircraftCompassHeading.getKey(); + DJISDKManager.getInstance().getKeyManager().getValue(aircraftCompassHeadingKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object value) { + if (value instanceof Float) { + sendEvent(SDKEvent.AircraftCompassHeading, value); + } + } + + @Override + public void onFailure(@NonNull DJIError djiError) {} + }); + startEventListener(SDKEvent.AircraftCompassHeading, new EventListener() { @Override public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { @@ -542,13 +716,14 @@ public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) } private void startDiagnosticsListener() { + prevDiagnostics = new ArrayList(); // Add product connection listener DJIDiagnostics.DiagnosticsInformationCallback diagnosticsInformationCallback = new DJIDiagnostics.DiagnosticsInformationCallback() { @Override - public void onUpdate(List list) { - if (!list.isEmpty()) { + public void onUpdate(List newDiagnostics) { + if (!areDiagnosticsEqual(newDiagnostics, prevDiagnostics)) { WritableArray diagnosticsToSend = Arguments.createArray(); - for (DJIDiagnostics djiDiagnostics : list) { + for (DJIDiagnostics djiDiagnostics : newDiagnostics) { DiagnosticsBaseHandler.DJIDiagnosticsError error = DiagnosticsBaseHandler.DJIDiagnosticsError.find(djiDiagnostics.getCode()); WritableMap params = Arguments.createMap(); params.putString("type", djiDiagnostics.getType().name()); @@ -559,6 +734,7 @@ public void onUpdate(List list) { } sendEvent(SDKEvent.DJIDiagnostics, diagnosticsToSend); } + prevDiagnostics = new ArrayList(newDiagnostics); } }; if (product != null) { @@ -568,6 +744,32 @@ public void onUpdate(List list) { } } + @ReactMethod + private void resetPreviousDiagnostics(Promise promise) { + // ensures that when a new subscriber subscribes to the diagnostics events, the diagnostics are + // forced to update + prevDiagnostics = new ArrayList(); + promise.resolve(null); + } + + private boolean areDiagnosticsEqual(List diagA, List diagB) { + if (diagA.size() != diagB.size()) { + return false; + } + + String[] diagACodes = new String[diagA.size()]; + String[] diagBCodes = new String[diagB.size()]; + for (int i = 0; i < diagA.size(); i++) { + String tempA = String.valueOf(diagA.get(i).getCode()) + "_" + String.valueOf(diagA.get(i).getSubCode()); + String tempB = String.valueOf(diagB.get(i).getCode()) + "_" + String.valueOf(diagB.get(i).getSubCode()); + diagACodes[i] = String.valueOf(diagA.get(i).getCode()) + "_" + String.valueOf(diagA.get(i).getSubCode()); + diagBCodes[i] = String.valueOf(diagB.get(i).getCode()) + "_" + String.valueOf(diagB.get(i).getSubCode()); + } + Arrays.sort(diagACodes); + Arrays.sort(diagBCodes); + return Arrays.equals(diagACodes, diagBCodes); + } + @ReactMethod public void startCameraExposureSettingsListener(Promise promise) { startEventListener(SDKEvent.CameraExposureSettings, new EventListener() { @@ -640,6 +842,21 @@ public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) } } }); + startEventListener(SDKEvent.CameraDidUpdateSystemState, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue != null && newValue instanceof HashMap) { + HashMap payload = (HashMap) newValue; + SystemState systemState = (SystemState) payload.get("value"); + boolean isShootingSinglePhoto = systemState.isShootingSinglePhoto(); + boolean isStoringPhoto = systemState.isStoringPhoto(); + WritableMap params = Arguments.createMap(); + params.putBoolean("isShootingPhoto", isShootingSinglePhoto); + params.putBoolean("isStoringPhoto", isStoringPhoto); + sendRealTimeEvent(SDKEvent.CameraDidUpdateSystemState, params); + } + } + }); promise.resolve(null); } @@ -647,6 +864,47 @@ private void startAircraftHomeLocationListener() { final Double[] homeLocation = {null, null, null}; + DJIKey aircraftHomeLocationKey = (DJIKey) SDKEvent.AircraftHomeLocation.getKey(); + DJIKey takeoffLocationAltitudeKey = (DJIKey) SDKEvent.TakeoffLocationAltitude.getKey(); + DJISDKManager.getInstance().getKeyManager().getValue(aircraftHomeLocationKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object value) { + if (value != null && value instanceof LocationCoordinate2D) { + LocationCoordinate2D location = (LocationCoordinate2D) value; + Double longitude = location.getLongitude(); + Double latitude = location.getLatitude(); + if (!latitude.isNaN() && !latitude.isInfinite() && !longitude.isNaN() && !longitude.isInfinite()) { + homeLocation[0] = latitude; + homeLocation[1] = longitude; + sendAircraftHomeLocationEvent(homeLocation[0], homeLocation[1], homeLocation[2]); + } + } + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + Log.e("REACT", "Could not get home location: " + djiError.getDescription()); + } + }); + + DJISDKManager.getInstance().getKeyManager().getValue(takeoffLocationAltitudeKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object value) { + if (!isObjectValidFloatValue(value)) { + return; + } + Float takeoffLocationAltitude = (Float) value; + homeLocation[2] = Double.valueOf(takeoffLocationAltitude); + sendAircraftHomeLocationEvent(homeLocation[0], homeLocation[1], homeLocation[2]); + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + Log.e("REACT", "Could not get home location altitude: " + djiError.getDescription()); + } + }); + + startEventListener(SDKEvent.AircraftHomeLocation, new EventListener() { @Override public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { @@ -709,28 +967,142 @@ private void sendAircraftHomeLocationEvent(Double latitude, Double longitude, Do sendEvent(SDKEvent.AircraftHomeLocation, homeLocation); } + private void startIsHomeLocationSetListener() { + KeyManager keyManager = DJISDKManager.getInstance().getKeyManager(); + if (keyManager != null) { + DJIKey isHomeLocationSetKey = FlightControllerKey.create(FlightControllerKey.IS_HOME_LOCATION_SET); + keyManager.getValue(isHomeLocationSetKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object o) { + if (o instanceof Boolean) { + sendRealTimeEvent(SDKEvent.IsHomeLocationSet, o); + } + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + Log.e("REACT", "Could not set is home location set callback: " + djiError.getDescription()); + } + }); + } + startEventListener(SDKEvent.IsHomeLocationSet, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue instanceof Boolean) { + sendEvent(SDKEvent.IsHomeLocationSet, newValue); + } + } + }); + } + private void startUltrasonicHeightListener() { startEventListener(SDKEvent.AircraftUltrasonicHeight, new EventListener() { - @Override - public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { - if (newValue != null && newValue instanceof Float) { - sendEvent(SDKEvent.AircraftUltrasonicHeight, newValue); + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue != null && newValue instanceof Float) { + sendEvent(SDKEvent.AircraftUltrasonicHeight, newValue); + } + } + }); + } + + private void startRemoteControllerFlightModeListener() { + getInitialSDKEventValue(SDKEvent.RemoteControllerFlightMode, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleRemoteControllerFlightModeUpdate(o, true); + } + }); + startEventListener(SDKEvent.RemoteControllerFlightMode, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleRemoteControllerFlightModeUpdate(newValue, false); + } + }); + } + + private void handleRemoteControllerFlightModeUpdate(@Nullable Object newValue, Boolean realtime) { + if (newValue != null && newValue instanceof RemoteControllerFlightMode) { + this.eventSender.processEvent( + SDKEvent.RemoteControllerFlightMode, + ((RemoteControllerFlightMode)newValue).name(), + realtime + ); + } + } + + private void startAircraftFlightModeListener() { + getInitialSDKEventValue(SDKEvent.AircraftFlightMode, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleAircraftFlightModeUpdate(o, true); + } + }); + startEventListener(SDKEvent.AircraftFlightMode, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleAircraftFlightModeUpdate(newValue, false); + } + }); + } + + private void handleAircraftFlightModeUpdate(@Nullable Object newValue, Boolean realtime) { + if (newValue != null && newValue instanceof FlightMode) { + this.eventSender.processEvent( + SDKEvent.AircraftFlightMode, + ((FlightMode)newValue).name(), + realtime + ); + } + } + + private void startAircraftIsFlyingListener() { + getInitialSDKEventValue(SDKEvent.AircraftIsFlying, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleIsFlyingUpdate(o, true); + } + }); + startEventListener(SDKEvent.AircraftIsFlying, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleIsFlyingUpdate(newValue, false); } - } }); } + private void handleIsFlyingUpdate(@Nullable Object newValue, Boolean realtime) { + if (newValue != null && newValue instanceof Boolean) { + this.eventSender.processEvent( + SDKEvent.AircraftIsFlying, + newValue, + realtime + ); + } + } + private void startCompassHasErrorListener() { + getInitialSDKEventValue(SDKEvent.CompassHasError, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleCompassHasErrorUpdate(o, true); + } + }); + startEventListener(SDKEvent.CompassHasError, new EventListener() { @Override public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { - if (newValue instanceof Boolean) { - sendEvent(SDKEvent.CompassHasError, newValue); - } + handleCompassHasErrorUpdate(newValue, false); } }); } + private void handleCompassHasErrorUpdate(@Nullable Object newValue, Boolean realtime) { + if (newValue != null && newValue instanceof Boolean) { + this.eventSender.processEvent(SDKEvent.CompassHasError, newValue, realtime); + } + } + private void startIsRecordingListener() { startEventListener(SDKEvent.CameraIsRecording, new EventListener() { @Override @@ -742,6 +1114,128 @@ public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) }); } + private void startCameraIsShootingPhotoListener() { + startEventListener(SDKEvent.CameraIsShootingPhoto, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue instanceof Boolean) { + sendEvent(SDKEvent.CameraIsShootingPhoto, newValue); + } + } + }); + } + + private void startCameraIsShootingSinglePhotoListener() { + startEventListener(SDKEvent.CameraIsShootingSinglePhoto, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue instanceof Boolean) { + sendEvent(SDKEvent.CameraIsShootingSinglePhoto, newValue); + } + } + }); + } + + private void startCameraIsStoringPhotoListener() { + startEventListener(SDKEvent.CameraIsStoringPhoto, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue instanceof Boolean) { + sendEvent(SDKEvent.CameraIsStoringPhoto, newValue); + } + } + }); + } + + private void startCameraWhiteBalanceListener() { + getInitialSDKEventValue(SDKEvent.CameraWhiteBalance, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleCameraWhiteBalanceUpdate(o, true); + } + }); + startEventListener(SDKEvent.CameraWhiteBalance, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleCameraWhiteBalanceUpdate(newValue, false); + } + }); + } + + private void handleCameraWhiteBalanceUpdate(@Nullable Object newValue, Boolean realtime) { + if (newValue != null && newValue instanceof WhiteBalance) { + WhiteBalance whiteBalance = (WhiteBalance)newValue; + SettingsDefinitions.WhiteBalancePreset preset = whiteBalance.getWhiteBalancePreset(); + this.eventSender.processEvent(SDKEvent.CameraWhiteBalance, preset.name(), realtime); + } + } + + private void startCameraPhotoFileFormatListener() { + getInitialSDKEventValue(SDKEvent.CameraPhotoFileFormat, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleCameraPhotoFileFormatUpdate(o, true); + } + }); + startEventListener(SDKEvent.CameraPhotoFileFormat, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleCameraPhotoFileFormatUpdate(newValue, false); + } + }); + } + + private void handleCameraPhotoFileFormatUpdate(@Nullable Object newValue, Boolean realtime) { + if (newValue != null && newValue instanceof SettingsDefinitions.PhotoFileFormat) { + SettingsDefinitions.PhotoFileFormat format = (SettingsDefinitions.PhotoFileFormat)newValue; + this.eventSender.processEvent(SDKEvent.CameraPhotoFileFormat, format.name(), realtime); + } + } + + private void startCameraPhotoAspectRatioListener() { + getInitialSDKEventValue(SDKEvent.CameraPhotoAspectRatio, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleCameraPhotoAspectRatioUpdate(o, true); + } + }); + startEventListener(SDKEvent.CameraPhotoAspectRatio, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleCameraPhotoAspectRatioUpdate(newValue, false); + } + }); + } + + private void handleCameraPhotoAspectRatioUpdate(@Nullable Object newValue, Boolean realtime) { + if (newValue != null && newValue instanceof SettingsDefinitions.PhotoAspectRatio) { + SettingsDefinitions.PhotoAspectRatio format = (SettingsDefinitions.PhotoAspectRatio)newValue; + this.eventSender.processEvent(SDKEvent.CameraPhotoAspectRatio, format.name(), realtime); + } + } + + private void startCameraExposureModeListener() { + getInitialSDKEventValue(SDKEvent.CameraExposureMode, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleCameraExposureModeUpdate(o, true); + } + }); + startEventListener(SDKEvent.CameraExposureMode, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleCameraExposureModeUpdate(newValue, false); + } + }); + } + + private void handleCameraExposureModeUpdate(@Nullable Object newValue, Boolean realtime) { + if (newValue != null && newValue instanceof SettingsDefinitions.ExposureMode) { + SettingsDefinitions.ExposureMode format = (SettingsDefinitions.ExposureMode)newValue; + this.eventSender.processEvent(SDKEvent.CameraExposureMode, format.name(), realtime); + } + } + private void startVirtualStickEnabledListener() { startEventListener(SDKEvent.AircraftVirtualStickEnabled, new EventListener() { @Override @@ -775,6 +1269,27 @@ public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) }); } + private void startSDCardAvailableCaptureCountListener() { + getInitialSDKEventValue(SDKEvent.SDCardAvailableCaptureCount, new GetCallbackWrapper() { + @Override + public void onSuccess(@NonNull Object o) { + handleSDCardAvailableCaptureCountUpdate(o, true); + } + }); + startEventListener(SDKEvent.SDCardAvailableCaptureCount, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleSDCardAvailableCaptureCountUpdate(newValue, false); + } + }); + } + + private void handleSDCardAvailableCaptureCountUpdate(@Nullable Object newValue, Boolean realtime) { + if (newValue != null && newValue instanceof Long) { + this.eventSender.processEvent(SDKEvent.SDCardAvailableCaptureCount, newValue, realtime); + } + } + private void startGimbalIsAtYawStopListener() { startEventListener(SDKEvent.GimbalIsAtYawStop, new EventListener() { @Override @@ -874,7 +1389,7 @@ public void stopEventListener(String eventName, Promise promise) { promise.resolve(null); } - private void startEventListener(SDKEvent SDKEvent, EventListener eventListener) { + public void startEventListener(SDKEvent SDKEvent, EventListener eventListener) { Object existingEventListener = eventListeners.get(SDKEvent); if (sdkEventHandler == null) { @@ -976,28 +1491,30 @@ public void stopFlightLogListener(Promise promise) { private void startAirlinkUplinkSignalQualityListener() { DJIKey isLightbridgeSupportedKey = AirLinkKey.create(AirLinkKey.IS_LIGHTBRIDGE_LINK_SUPPORTED); - KeyManager.getInstance().getValue(isLightbridgeSupportedKey, new GetCallback() { - @Override - public void onSuccess(@NonNull Object value) { + KeyManager keyManager = DJISDKManager.getInstance().getKeyManager(); + if (keyManager != null) { + keyManager.getValue(isLightbridgeSupportedKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object value) { if (value instanceof Boolean) { - if ((Boolean) value) { - startEventListener(SDKEvent.AirLinkLightbridgeUplinkSignalQuality, new EventListener() { - @Override - public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { - if (newValue != null && newValue instanceof Integer) { - sendEvent(SDKEvent.AirLinkUplinkSignalQuality, newValue); - } - } - }); - } + if ((Boolean) value) { + startEventListener(SDKEvent.AirLinkLightbridgeUplinkSignalQuality, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue != null && newValue instanceof Integer) { + sendEvent(SDKEvent.AirLinkUplinkSignalQuality, newValue); + } + } + }); + } } - } + } - @Override - public void onFailure(@NonNull DJIError djiError) { + @Override + public void onFailure(@NonNull DJIError djiError) {} + }); + } - } - }); if (product != null && product.getAirLink() != null) { boolean isOcuSyncLinkSupported = product.getAirLink().isOcuSyncLinkSupported(); if (isOcuSyncLinkSupported) { @@ -1015,28 +1532,30 @@ public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) private void startAirlinkDownlinkSignalQualityListener() { DJIKey isLightbridgeSupportedKey = AirLinkKey.create(AirLinkKey.IS_LIGHTBRIDGE_LINK_SUPPORTED); - KeyManager.getInstance().getValue(isLightbridgeSupportedKey, new GetCallback() { - @Override - public void onSuccess(@NonNull Object value) { - if (value instanceof Boolean) { - if ((Boolean) value) { - startEventListener(SDKEvent.AirLinkLightbridgeDownlinkSignalQuality, new EventListener() { - @Override - public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { - if (newValue != null && newValue instanceof Integer) { - sendEvent(SDKEvent.AirLinkDownlinkSignalQuality, newValue); + KeyManager keyManager = DJISDKManager.getInstance().getKeyManager(); + if (keyManager != null) { + keyManager.getValue(isLightbridgeSupportedKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object value) { + if (value instanceof Boolean) { + if ((Boolean) value) { + startEventListener(SDKEvent.AirLinkLightbridgeDownlinkSignalQuality, new EventListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue != null && newValue instanceof Integer) { + sendEvent(SDKEvent.AirLinkDownlinkSignalQuality, newValue); + } } - } - }); + }); + } } } - } - @Override - public void onFailure(@NonNull DJIError djiError) { + @Override + public void onFailure(@NonNull DJIError djiError) {} + }); + } - } - }); if (product != null && product.getAirLink() != null) { boolean isOcuSyncLinkSupported = product.getAirLink().isOcuSyncLinkSupported(); if (isOcuSyncLinkSupported) { @@ -1052,7 +1571,26 @@ public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) } } - @ReactMethod + interface GetCallbackWrapper { + void onSuccess(@NonNull Object o); + } + + private void getInitialSDKEventValue(final SDKEvent sdkEvent,final GetCallbackWrapper callback) { + DJIKey key = (DJIKey) sdkEvent.getKey(); + DJISDKManager.getInstance().getKeyManager().getValue(key, new GetCallback() { + @Override + public void onSuccess(@NonNull Object o) { + callback.onSuccess(o); + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + Log.e("REACT", "Could not get inital value of " + sdkEvent.name() + ": " + djiError.getDescription()); + } + }); + } + + @ReactMethod public void limitEventFrequency(double newEventSendFrequencyInHz, Promise promise) { int milliSecs = (int) Math.round((1/newEventSendFrequencyInHz) * 1000); this.eventSender.setNewEventSendFrequency(milliSecs); @@ -1095,6 +1633,37 @@ public void onFailure(@NonNull DJIError djiError) { }); } + @ReactMethod + public void startIMUSensorStateListener(final Promise promise) { + Aircraft product = (Aircraft) DJISDKManager.getInstance().getProduct(); + if (product == null) { + promise.reject(new Throwable("startIMUSensorStateListener error: product is null")); + return; + } + FlightController flightController = product.getFlightController(); + if (flightController == null) { + promise.reject(new Throwable("startIMUSensorStateListener error: flightController is null")); + return; + } + flightController.setIMUStateCallback(new IMUState.Callback() { + @Override + public void onUpdate(@NonNull IMUState imuState) { + // This update method fires every ~2s, even when the values don't seem to be updating + // Handling this at the JS level with rxjs + SensorState accelerometerState = imuState.getAccelerometerState(); + SensorState gyroscopeState = imuState.getGyroscopeState(); + // Handle null `SensorState` values which occur every few updates + if (accelerometerState == null || gyroscopeState == null) { + return; + } + WritableMap params = Arguments.createMap(); + params.putString("accelerometerState", accelerometerState.name()); + params.putString("gyroscopeState", gyroscopeState.name()); + sendEvent(SDKEvent.IMUSensorState, params); + } + }); + } + @Override public String getName() { return "DJIMobile"; diff --git a/android/src/main/java/com/aerobotics/DjiMobile/DJIMobilePackage.java b/android/src/main/java/com/aerobotics/DjiMobile/DJIMobilePackage.java index c871f705..dd8eb49f 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/DJIMobilePackage.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/DJIMobilePackage.java @@ -2,12 +2,11 @@ import java.util.ArrayList; import java.util.Arrays; -import java.util.Collections; import java.util.List; import com.aerobotics.DjiMobile.DroneVideo.DroneVideoManager; +import com.aerobotics.DjiMobile.WaypointMissionV2.WaypointMissionV2Wrapper; import com.facebook.react.ReactPackage; -import com.facebook.react.bridge.JavaScriptModule; import com.facebook.react.bridge.NativeModule; import com.facebook.react.bridge.ReactApplicationContext; import com.facebook.react.uimanager.ViewManager; @@ -21,14 +20,9 @@ public List createNativeModules(ReactApplicationContext reactConte modules.add(new CameraControlNative(reactContext)); modules.add(new DJIMedia(reactContext)); modules.add(new FlightControllerWrapper(reactContext)); + modules.add(new WaypointMissionV2Wrapper(reactContext)); modules.add(new GimbalWrapper(reactContext)); return modules; -// return Arrays.asList( -// new DJIMobile(reactContext), -// new DJIMissionControlWrapper(reactContext), -// new CameraControlNative(reactContext), -// new DJIMedia(reactContext) -// ); } @Override diff --git a/android/src/main/java/com/aerobotics/DjiMobile/DJITimelineElements/WaypointMissionTimelineElement.java b/android/src/main/java/com/aerobotics/DjiMobile/DJITimelineElements/WaypointMissionTimelineElement.java index c1ad25ae..7a837120 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/DJITimelineElements/WaypointMissionTimelineElement.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/DJITimelineElements/WaypointMissionTimelineElement.java @@ -12,10 +12,13 @@ import dji.common.mission.waypoint.WaypointAction; import dji.common.mission.waypoint.WaypointActionType; import dji.common.mission.waypoint.WaypointMission; +import dji.common.mission.waypoint.WaypointMissionFinishedAction; import dji.common.mission.waypoint.WaypointMissionFlightPathMode; import dji.common.mission.waypoint.WaypointMissionGotoWaypointMode; import dji.common.mission.waypoint.WaypointMissionHeadingMode; +import static dji.common.mission.waypoint.WaypointMissionFlightPathMode.CURVED; + public class WaypointMissionTimelineElement extends WaypointMission.Builder { public WaypointMissionTimelineElement(ReadableMap parameters) { @@ -42,37 +45,58 @@ public WaypointMissionTimelineElement(ReadableMap parameters) { this.headingMode(WaypointMissionHeadingMode.valueOf(parameters.getString("headingMode"))); } + if (parameters.hasKey("goToWaypointMode")) { + this.gotoFirstWaypointMode(WaypointMissionGotoWaypointMode.valueOf(parameters.getString("goToWaypointMode"))); + } + + if(parameters.hasKey("flightPathMode")) { + this.flightPathMode(WaypointMissionFlightPathMode.valueOf(parameters.getString("flightPathMode"))); + } + + if(parameters.hasKey("finishedAction")) { + this.finishedAction(WaypointMissionFinishedAction.valueOf(parameters.getString("finishedAction"))); + } + ReadableArray waypointsParameter = parameters.getArray("waypoints"); for (int i = 0, n = waypointsParameter.size(); i < n; i++) { ReadableMap waypointParams = waypointsParameter.getMap(i); double longitude = waypointParams.getDouble("longitude"); double latitude = waypointParams.getDouble("latitude"); double altitude = waypointParams.getDouble("altitude"); - Integer heading = null; - Double speed = null; - try { - heading = waypointParams.getInt("heading"); - } catch (Exception e) {} - try { - speed = waypointParams.getDouble("speed"); - } catch (Exception e) {} Waypoint waypointObject = new Waypoint( latitude, longitude, (float) altitude ); - - if (heading != null) { + try { + int heading = waypointParams.getInt("heading"); waypointObject.heading = heading; + } catch (Exception e) {} + try { + double speed = waypointParams.getDouble("speed"); + waypointObject.speed = (float) speed; + } catch (Exception e) {} + + if (waypointParams.hasKey("cornerRadiusInMeters") && this.flightPathMode == CURVED) { + // First and last waypoints should have a corner radius of 0.2 according to the DJI docs + if (i == 0 || i == n - 1) { + waypointObject.cornerRadiusInMeters = Waypoint.MIN_CORNER_RADIUS; + } else { + double cornerRadiusInMeters = waypointParams.getDouble("cornerRadiusInMeters"); + // Ensure corner radius >= min corner radius (0.2m) + waypointObject.cornerRadiusInMeters = Math.max((float) cornerRadiusInMeters, Waypoint.MIN_CORNER_RADIUS); + } } - if (speed != null) { - waypointObject.speed = speed.floatValue(); + + if (waypointParams.hasKey("shootPhotoDistanceInterval")) { + double shootPhotoDistanceInterval = waypointParams.getDouble("shootPhotoDistanceInterval"); + waypointObject.shootPhotoDistanceInterval = (float) shootPhotoDistanceInterval; } - if (waypointParams.hasKey("cornerRadiusInMeters")) { - double cornerRadiusInMeters = waypointParams.getDouble("cornerRadiusInMeters"); - waypointObject.cornerRadiusInMeters = (float)cornerRadiusInMeters; + if (waypointParams.hasKey("shootPhotoTimeInterval")) { + double shootPhotoTimeInterval = waypointParams.getDouble("shootPhotoTimeInterval"); + waypointObject.shootPhotoTimeInterval = (float) shootPhotoTimeInterval; } if (waypointParams.hasKey("actions")) { @@ -92,14 +116,6 @@ public WaypointMissionTimelineElement(ReadableMap parameters) { this.addWaypoint(waypointObject); } - - if (parameters.hasKey("goToWaypointMode")) { - this.gotoFirstWaypointMode(WaypointMissionGotoWaypointMode.valueOf(parameters.getString("goToWaypointMode"))); - } - - if(parameters.hasKey("flightPathMode")) { - this.flightPathMode(WaypointMissionFlightPathMode.valueOf(parameters.getString("flightPathMode"))); - } } public @Nullable DJIError checkValidity() { diff --git a/android/src/main/java/com/aerobotics/DjiMobile/DroneVideo/DroneVideo.java b/android/src/main/java/com/aerobotics/DjiMobile/DroneVideo/DroneVideo.java index e17d1b9c..43a7c0f7 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/DroneVideo/DroneVideo.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/DroneVideo/DroneVideo.java @@ -7,71 +7,218 @@ import android.view.View; import android.widget.RelativeLayout; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; + import com.aerobotics.DjiMobile.R; +import com.aerobotics.DjiMobile.SDKEvent; +import dji.common.airlink.PhysicalSource; +import dji.common.error.DJIError; +import dji.common.product.Model; +import dji.common.util.CommonCallbacks; +import dji.keysdk.DJIKey; +import dji.keysdk.KeyManager; +import dji.keysdk.ProductKey; +import dji.keysdk.callback.GetCallback; +import dji.keysdk.callback.KeyListener; +import dji.midware.usb.P3.UsbAccessoryService; +import dji.sdk.base.BaseProduct; import dji.sdk.camera.VideoFeeder; import dji.sdk.codec.DJICodecManager; import dji.sdk.sdkmanager.DJISDKManager; +import dji.sdk.airlink.AirLink; +import dji.sdk.airlink.OcuSyncLink; public class DroneVideo extends RelativeLayout implements TextureView.SurfaceTextureListener { - private DJICodecManager codecManager; - - public DroneVideo(Context context) { - super(context); - initializeSurfaceTexture(); - } - - private void initializeSurfaceTexture() { - View.inflate(getContext(), R.layout.drone_video_layout, this); - TextureView droneVideoTexture = findViewById(R.id.droneVideoTexture); - droneVideoTexture.setSurfaceTextureListener(this); - if (DJISDKManager.getInstance().hasSDKRegistered()) { - VideoFeeder.getInstance().getPrimaryVideoFeed().addVideoDataListener(new VideoFeeder.VideoDataListener() { - @Override - public void onReceive(byte[] buffer, int size) { - if (codecManager != null) { - codecManager.sendDataToDecoder(buffer, size); - } + private DJICodecManager codecManager; + private AirLink airLink; + private PhysicalSource videoPrimarySource; + private VideoFeeder.PhysicalSourceListener sourceListener; + + public DroneVideo(Context context) { + super(context); + initializeSurfaceTexture(); + startProductConnectionListener(); + setUpListeners(); + } + + private void initOnProductConnection() { + initAirLink(); + setPrimaryVideoFeedForModel(); + } + + /** + * FIXME: this doesn't seem to fire, yet it does in the DJI sample + */ + private void setUpListeners() { + sourceListener = new VideoFeeder.PhysicalSourceListener() { + @Override + public void onChange(VideoFeeder.VideoFeed videoFeed, PhysicalSource newPhysicalSource) { + Log.d("REACT", "I HAVE FIRED!"); + if (videoFeed == VideoFeeder.getInstance().getPrimaryVideoFeed()) { + String newText = "Primary Source: " + newPhysicalSource.toString(); + Log.d("REACT", newText); + videoPrimarySource = newPhysicalSource; + } + if (videoFeed == VideoFeeder.getInstance().getSecondaryVideoFeed()) { + Log.d("REACT", "Secondary Source: " + newPhysicalSource.toString()); + } + } + }; + } + + private void initAirLink() { + BaseProduct baseProduct = DJISDKManager.getInstance().getProduct(); + if (baseProduct != null && baseProduct.getAirLink() != null) { + airLink = baseProduct.getAirLink(); + } else { + Log.w("REACT", "Product is not yet connected!"); + } + } + + public void setPrimaryVideoFeedForModel() { + BaseProduct product = DJISDKManager.getInstance().getProduct(); + if (product != null) { + Model model = DJISDKManager.getInstance().getProduct().getModel(); + if (model == Model.MATRICE_300_RTK) { + setPrimaryVideoFeed(PhysicalSource.LEFT_CAM); + } else { + setPrimaryVideoFeed(PhysicalSource.MAIN_CAM); + } } - }); + } - } - private void cleanUpVideoFeed() { - VideoFeeder.getInstance().getPrimaryVideoFeed().destroy(); - if (codecManager != null) { - codecManager.destroyCodec(); + public void setPrimaryVideoFeed(PhysicalSource primarySource) { + setPrimaryVideoFeed(primarySource, PhysicalSource.UNKNOWN); } - } - @Override - public void onSurfaceTextureAvailable(SurfaceTexture surface, int width, int height) { - if (codecManager == null) { - codecManager = new DJICodecManager(getContext(), surface, width, height); + public void setPrimaryVideoFeed(final PhysicalSource primarySource, PhysicalSource secondarySource) { + try { + if (airLink == null) { + throw new Exception("Airlink is null"); + } + OcuSyncLink ocuSyncLink = airLink.getOcuSyncLink(); + if (ocuSyncLink == null) { + throw new Exception("OcuSyncLink is null"); + } + ocuSyncLink.assignSourceToPrimaryChannel(primarySource, secondarySource, new CommonCallbacks.CompletionCallback() { + @Override + public void onResult(DJIError error) { + if (error != null) { + Log.w("REACT", "Failed to set video feed primary channel: " + error.getDescription()); + } else { + // TODO: move this to the sourceListener once that if fixed + videoPrimarySource = primarySource; + } + } + }); + } catch (Exception exception) { + Log.w("REACT", "Cannot set primary video feed: " + exception.getMessage()); + } } - } - @Override - public void onSurfaceTextureSizeChanged(SurfaceTexture surface, int width, int height) { - codecManager.cleanSurface(); - codecManager = new DJICodecManager(getContext(), surface, width, height); - } + private void initializeSurfaceTexture() { + View.inflate(getContext(), R.layout.drone_video_layout, this); + TextureView droneVideoTexture = findViewById(R.id.droneVideoTexture); + droneVideoTexture.setSurfaceTextureListener(this); + VideoFeeder.getInstance().getPrimaryVideoFeed().addVideoDataListener(new VideoFeeder.VideoDataListener() { + @Override + public void onReceive(byte[] buffer, int size) { + if (codecManager != null) { + codecManager.sendDataToDecoder(buffer, size, getVideoStreamSource().getIndex()); + } + } + }); + } - @Override - public boolean onSurfaceTextureDestroyed(SurfaceTexture surface) { - codecManager.destroyCodec(); - return false; - } + private UsbAccessoryService.VideoStreamSource getVideoStreamSource() { + if (videoPrimarySource == PhysicalSource.FPV_CAM) { + return UsbAccessoryService.VideoStreamSource.Fpv; + } else { + return UsbAccessoryService.VideoStreamSource.Camera; + } + } - @Override - public void onSurfaceTextureUpdated(SurfaceTexture surface) { + @Override + public void onSurfaceTextureAvailable(SurfaceTexture surface, int width, int height) { + if (codecManager == null) { + codecManager = new DJICodecManager(getContext(), surface, width, height, getVideoStreamSource()); + } + } - } + @Override + public void onSurfaceTextureSizeChanged(SurfaceTexture surface, int width, int height) { + codecManager.cleanSurface(); + codecManager = new DJICodecManager(getContext(), surface, width, height, getVideoStreamSource()); + } - @Override - protected void onDetachedFromWindow() { - super.onDetachedFromWindow(); - cleanUpVideoFeed(); - } -} + @Override + public boolean onSurfaceTextureDestroyed(SurfaceTexture surface) { + if (codecManager != null) { + codecManager.cleanSurface(); + codecManager.destroyCodec(); + codecManager = null; + } + return false; + } + + @Override + public void onSurfaceTextureUpdated(SurfaceTexture surface) { + } + + @Override + protected void onDetachedFromWindow() { + super.onDetachedFromWindow(); + cleanUpVideoFeed(); + tearDownListeners(); + } + + + private void cleanUpVideoFeed() { + VideoFeeder.getInstance().getPrimaryVideoFeed().destroy(); + if (codecManager != null) { + codecManager.destroyCodec(); + } + } + + private void tearDownListeners() { + VideoFeeder.getInstance().removePhysicalSourceListener(sourceListener); + } + + private void startProductConnectionListener() { + KeyManager keyManager = DJISDKManager.getInstance().getKeyManager(); + if (keyManager != null) { + DJIKey productConnectedKey = ProductKey.create(ProductKey.CONNECTION); + keyManager.getValue(productConnectedKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object newValue) { + handleProductConnection(newValue); + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + } + }); + } + DJISDKManager.getInstance().getKeyManager().addListener((DJIKey) SDKEvent.ProductConnection.getKey(), new KeyListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + handleProductConnection(newValue); + } + }); + } + + private void handleProductConnection(@Nullable Object newValue) { + if (newValue != null && newValue instanceof Boolean) { + Boolean isProductConnected = (Boolean) newValue; + if (isProductConnected) { + initOnProductConnection(); + } else { + + } + } + } +} \ No newline at end of file diff --git a/android/src/main/java/com/aerobotics/DjiMobile/DroneVideo/DroneVideoManager.java b/android/src/main/java/com/aerobotics/DjiMobile/DroneVideo/DroneVideoManager.java index 50fda55b..9892a25d 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/DroneVideo/DroneVideoManager.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/DroneVideo/DroneVideoManager.java @@ -1,17 +1,63 @@ package com.aerobotics.DjiMobile.DroneVideo; +import android.util.Log; + +import androidx.annotation.Nullable; + import com.facebook.react.uimanager.SimpleViewManager; import com.facebook.react.uimanager.ThemedReactContext; +import com.facebook.react.uimanager.annotations.ReactProp; + +import org.jetbrains.annotations.NotNull; + +import dji.common.airlink.PhysicalSource; public class DroneVideoManager extends SimpleViewManager { + @NotNull @Override public String getName() { return "DroneVideo"; } + @NotNull @Override - protected DroneVideo createViewInstance(ThemedReactContext reactContext) { + protected DroneVideo createViewInstance(@NotNull ThemedReactContext reactContext) { return new DroneVideo(reactContext); } + + /* + * FIXME: Could not get this to work as desired. I could not update the video feed once it has + * already been rendered. So for now, the choosing of the video feed is handled by the component + */ + @ReactProp(name = "videoSrc") + public void setVideoSrc(DroneVideo view, @Nullable String videoSrc) { + if (videoSrc == null) { + return; + } + + switch (videoSrc) { + case "MODEL_MAIN_CAMERA": + view.setPrimaryVideoFeedForModel(); + break; + case "LEFT_CAMERA": + view.setPrimaryVideoFeed(PhysicalSource.LEFT_CAM); + break; + case "FPV_CAMERA": + view.setPrimaryVideoFeed(PhysicalSource.FPV_CAM); + break; + case "MAIN_CAMERA": + view.setPrimaryVideoFeed(PhysicalSource.MAIN_CAM); + break; + case "RIGHT_CAMERA": + view.setPrimaryVideoFeed(PhysicalSource.RIGHT_CAM); + break; + case "UNKNOWN": + view.setPrimaryVideoFeed(PhysicalSource.UNKNOWN); + break; + default: + Log.w("REACT", "Unknown video src" + videoSrc); + break; + } + } } \ No newline at end of file diff --git a/android/src/main/java/com/aerobotics/DjiMobile/EventSender.java b/android/src/main/java/com/aerobotics/DjiMobile/EventSender.java index b22d3ad5..e18bc00e 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/EventSender.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/EventSender.java @@ -25,7 +25,7 @@ public void run() { } }; - EventSender(ReactContext reactContext) { + public EventSender(ReactContext reactContext) { this.reactContext = reactContext; if (eventSendLimiterTimer == null) { eventSendLimiterTimer = new Timer(); @@ -74,6 +74,8 @@ private WritableMap buildEventParams(Object value) { params.putInt("value", (Integer)value); } else if (value instanceof Double) { params.putDouble("value", (Double) value); + } else if (value instanceof Long) { + params.putDouble("value", ((Long) value).doubleValue()); } else if (value instanceof String) { params.putString("value", (String)value); } else if (value instanceof Boolean) { diff --git a/android/src/main/java/com/aerobotics/DjiMobile/FlightControllerWrapper.java b/android/src/main/java/com/aerobotics/DjiMobile/FlightControllerWrapper.java index 526047fd..b9520776 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/FlightControllerWrapper.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/FlightControllerWrapper.java @@ -17,20 +17,20 @@ import com.facebook.react.bridge.ReadableMap; import com.facebook.react.bridge.WritableMap; -import java.nio.charset.StandardCharsets; -import java.util.Arrays; -import java.util.Vector; - import javax.annotation.Nonnull; import dji.common.error.DJIError; +import dji.common.flightcontroller.LEDsSettings; import dji.common.flightcontroller.RemoteControllerFlightMode; +import dji.common.mission.MissionState; import dji.common.mission.waypoint.WaypointExecutionProgress; import dji.common.mission.waypoint.WaypointMission; import dji.common.mission.waypoint.WaypointMissionDownloadEvent; import dji.common.mission.waypoint.WaypointMissionExecutionEvent; import dji.common.mission.waypoint.WaypointMissionState; import dji.common.mission.waypoint.WaypointMissionUploadEvent; +import dji.common.mission.waypoint.WaypointUploadProgress; +import dji.common.mission.waypointv2.WaypointV2MissionExecuteState; import dji.common.util.CommonCallbacks; import dji.keysdk.DJIKey; import dji.keysdk.FlightControllerKey; @@ -47,122 +47,151 @@ public class FlightControllerWrapper extends ReactContextBaseJavaModule { private final ReactApplicationContext reactContext; - private EventSender eventSender; + private final EventSender eventSender; private WaypointMissionOperator waypointMissionOperator; private VirtualStickTimelineElement virtualStickTimelineElement; private DJIRealTimeDataLogger djiRealTimeDataLogger; - private Promise startMissionPromise; private boolean enableWaypointExecutionFinishListener = false; private boolean enableWaypointExecutionUpdateListener = false; + private boolean enableWaypointMissionStateListener = false; + private boolean enableWaypointMissionUploadListener = false; private FlightController.OnboardSDKDeviceDataCallback onboardSDKDeviceDataCallback; + private static WaypointMissionOperatorListener waypointMissionOperatorListener; - private WaypointMissionOperatorListener waypointMissionOperatorListener = new WaypointMissionOperatorListener() { - @Override - public void onDownloadUpdate(@NonNull WaypointMissionDownloadEvent waypointMissionDownloadEvent) { + public FlightControllerWrapper(@Nonnull ReactApplicationContext reactContext) { + super(reactContext); + this.eventSender = new EventSender(reactContext); + this.reactContext = reactContext; + } + @ReactMethod + public void uploadWaypointMission(ReadableMap parameters, Promise promise) { + try { + WaypointMissionTimelineElement waypointMissionTimelineElement = new WaypointMissionTimelineElement(parameters); + checkMissionParameters(waypointMissionTimelineElement); + WaypointMission waypointMission = waypointMissionTimelineElement.build(); + loadMission(waypointMission); + uploadMission(promise); + } catch (Exception error) { + promise.reject(new Throwable(error.getMessage())); } + } - @Override - public void onUploadUpdate(@NonNull WaypointMissionUploadEvent waypointMissionUploadEvent) { - if (waypointMissionUploadEvent.getCurrentState().equals(WaypointMissionState.READY_TO_EXECUTE)) { - getWaypointMissionOperator().startMission(new CommonCallbacks.CompletionCallback() { - @Override - public void onResult(DJIError djiError) { - if (djiError == null) { - startMissionPromise.resolve(null); - eventSender.processEvent(SDKEvent.WaypointMissionStarted, true, true); - } else { - eventSender.processEvent(SDKEvent.WaypointMissionStarted, false, true); - } + @ReactMethod + public void startWaypointMission(final Promise promise) { + if (getWaypointMissionOperator().getCurrentState().equals(WaypointMissionState.READY_TO_EXECUTE)) { + getWaypointMissionOperator().startMission(new CommonCallbacks.CompletionCallback() { + @Override + public void onResult(DJIError djiError) { + if (djiError == null) { + promise.resolve(null); + eventSender.processEvent(SDKEvent.WaypointMissionStarted, true, true); + } else { + promise.reject(new Throwable("startWaypointMission: " + djiError.getDescription())); + eventSender.processEvent(SDKEvent.WaypointMissionStarted, false, true); } - }); - } + } + }); + } else { + promise.reject(new Throwable("startWaypointMission: incorrect mission state " + getWaypointMissionOperator().getCurrentState().getName())); } + } - @Override - public void onExecutionUpdate(@NonNull WaypointMissionExecutionEvent waypointMissionExecutionEvent) { - if (!enableWaypointExecutionUpdateListener) { // Do not send events unnecessarily - return; - } - WritableMap progressMap = Arguments.createMap(); - WaypointExecutionProgress waypointExecutionProgress = waypointMissionExecutionEvent.getProgress(); - progressMap.putDouble("targetWaypointIndex", waypointExecutionProgress.targetWaypointIndex); - progressMap.putBoolean("isWaypointReached", waypointExecutionProgress.isWaypointReached); - progressMap.putString("executeState", waypointExecutionProgress.executeState.name()); - eventSender.processEvent(SDKEvent.WaypointMissionExecutionProgress, progressMap, true); + private void setWaypointMissionOperatorListener() { + if (waypointMissionOperatorListener != null) { + return; } + waypointMissionOperatorListener = new WaypointMissionOperatorListener() { + @Override + public void onDownloadUpdate(@NonNull WaypointMissionDownloadEvent event) { } - @Override - public void onExecutionStart() { - } + @Override + public void onUploadUpdate(@NonNull WaypointMissionUploadEvent event) { + handlePossibleErrorUpdate(event.getError()); - @Override - public void onExecutionFinish(@Nullable DJIError djiError) { - if (!enableWaypointExecutionFinishListener) { - return; + if (event.getProgress() != null) { + sendWaypointMissionUploadUpdate(event.getProgress()); + } + + /* + * The `waypointMissionUploadEvent` state differs from the mission operator state at times. + * Choosing to use the mission operator state as the source of truth. + */ + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); } - eventSender.processEvent(SDKEvent.WaypointMissionFinished, true, true); -// getWaypointMissionOperator().removeListener(waypointMissionOperatorListener); - } - }; - public FlightControllerWrapper(@Nonnull ReactApplicationContext reactContext) { - super(reactContext); - this.eventSender = new EventSender(reactContext); - this.reactContext = reactContext; - } + @Override + public void onExecutionUpdate(@NonNull WaypointMissionExecutionEvent event) { + handlePossibleErrorUpdate(event.getError()); + sendWaypointMissionExecutionUpdate(event.getProgress()); + /* + * The `waypointMissionExecutionEvent` state differs from the mission operator state at times. + * Choosing to use the mission operator state as the source of truth. + */ + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); + } - @ReactMethod - public void startWaypointMission(ReadableMap parameters, Promise promise) { - startMissionPromise = promise; - setWaypointMissionOperatorListener(); - WaypointMissionTimelineElement waypointMissionTimelineElement = new WaypointMissionTimelineElement(parameters); - DJIError missionParametersError = checkMissionParameters(waypointMissionTimelineElement); - if (missionParametersError == null) { - WaypointMission waypointMission = waypointMissionTimelineElement.build(); - if (loadMission(waypointMission)) { - uploadMission(); + @Override + public void onExecutionStart() { + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); } - } else { - startMissionPromise.reject(new Throwable("startWaypointMission error: " + missionParametersError.getDescription())); - } + @Override + public void onExecutionFinish(@Nullable DJIError djiError) { + handlePossibleErrorUpdate(djiError); + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); + if (enableWaypointExecutionFinishListener) { + eventSender.processEvent(SDKEvent.WaypointMissionFinished, true, true); + } + } + }; + getWaypointMissionOperator().addListener(waypointMissionOperatorListener); } - private void setWaypointMissionOperatorListener() { - getWaypointMissionOperator().removeListener(waypointMissionOperatorListener); - getWaypointMissionOperator().addListener(waypointMissionOperatorListener); + private void handlePossibleErrorUpdate(@Nullable DJIError error) { + if (error != null) { + sendWaypointMissionError(error); + } else { + sendNullWaypointMissionError(); + } } - private DJIError checkMissionParameters(WaypointMissionTimelineElement waypointMissionTimelineElement) { - return waypointMissionTimelineElement.checkParameters(); + private void checkMissionParameters(WaypointMissionTimelineElement waypointMissionTimelineElement) throws Exception { + DJIError error = waypointMissionTimelineElement.checkValidity(); + if (error != null) { + throw new Exception("checkMissionParameters error: " + error.getDescription()); + } } - private Boolean loadMission(WaypointMission mission){ + private void loadMission(WaypointMission mission) throws Exception { DJIError error = getWaypointMissionOperator().loadMission(mission); - return error == null; + if (error != null) { + throw new Exception("loadMission error: " + error.getDescription()); + } } - private void uploadMission() { - getWaypointMissionOperator().uploadMission(new CommonCallbacks.CompletionCallback() { + private void uploadMission(final Promise promise) { + getWaypointMissionOperator().uploadMission(new CommonCallbacks.CompletionCallback() { @Override public void onResult(DJIError error) { if (error == null) { - // Log.d("REACT", "Upload Success"); + promise.resolve(null); } else { if (getWaypointMissionOperator().getCurrentState().equals(WaypointMissionState.READY_TO_UPLOAD)) { - getWaypointMissionOperator().retryUploadMission((new CommonCallbacks.CompletionCallback() { + getWaypointMissionOperator().retryUploadMission((new CommonCallbacks.CompletionCallback() { @Override public void onResult(DJIError error) { if (error != null) { - startMissionPromise.reject(new Throwable("uploadMission error: Upload Failed" + error.getDescription())); + promise.reject(new Throwable("uploadMission error: Upload Failed" + error.getDescription())); + } else { + promise.resolve(null); } } })); } else { - startMissionPromise.reject(new Throwable("uploadMission error: Upload Failed" + error.getDescription())); + promise.reject(new Throwable("uploadMission error: Upload failed due to incorrect state " + getWaypointMissionOperator().getCurrentState().getName())); } } } @@ -173,11 +202,12 @@ private WaypointMissionOperator getWaypointMissionOperator() { if(waypointMissionOperator == null) { waypointMissionOperator = DJISDKManager.getInstance().getMissionControl().getWaypointMissionOperator(); } - return waypointMissionOperator; } + return waypointMissionOperator; + } @ReactMethod public void stopWaypointMission(final Promise promise) { - getWaypointMissionOperator().stopMission(new CommonCallbacks.CompletionCallback() { + getWaypointMissionOperator().stopMission(new CommonCallbacks.CompletionCallback() { @Override public void onResult(DJIError djiError) { if (djiError == null) { @@ -190,14 +220,14 @@ public void onResult(DJIError djiError) { } @ReactMethod - public void setWaypointmMissionAutoFlightSpeed(Float speed, final Promise promise) { - getWaypointMissionOperator().setAutoFlightSpeed(speed, new CommonCallbacks.CompletionCallback() { + public void setWaypointMissionAutoFlightSpeed(Float speed, final Promise promise) { + getWaypointMissionOperator().setAutoFlightSpeed(speed, new CommonCallbacks.CompletionCallback() { @Override public void onResult(DJIError djiError) { if (djiError == null) { promise.resolve(null); } else { - promise.reject(new Throwable("setWaypointmMissionAutoFlightSpeed error: " + djiError.getDescription())); + promise.reject(new Throwable("setWaypointMissionAutoFlightSpeed error: " + djiError.getDescription())); } } }); @@ -272,6 +302,76 @@ public void startWaypointExecutionUpdateListener(Promise promise) { promise.resolve("startWaypointExecutionUpdateListener"); } + private void sendWaypointMissionExecutionUpdate(WaypointExecutionProgress progress) { + if (enableWaypointExecutionUpdateListener) { + WritableMap progressMap = Arguments.createMap(); + progressMap.putInt("targetWaypointIndex", progress.targetWaypointIndex); + progressMap.putInt("totalWaypointCount", progress.totalWaypointCount); + progressMap.putBoolean("isWaypointReached", progress.isWaypointReached); + progressMap.putString("executeState", progress.executeState.name()); + + // If last waypoint has been completed, increment target waypoint index + WaypointMission waypointMission = getWaypointMissionOperator().getLoadedMission(); + if (waypointMission != null && progress.targetWaypointIndex == waypointMission.getWaypointCount() - 1 && progress.isWaypointReached) { + progressMap.putInt("targetWaypointIndex", progress.totalWaypointCount); + } else { + progressMap.putInt("targetWaypointIndex", progress.targetWaypointIndex); + } + eventSender.processEvent(SDKEvent.WaypointMissionExecutionProgress, progressMap, true); + } + } + + @ReactMethod + public void startWaypointMissionStateListener(Promise promise) { + enableWaypointMissionStateListener = true; + setWaypointMissionOperatorListener(); + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); + promise.resolve("startWaypointMissionStateListener"); + } + + @ReactMethod + public void stopWaypointMissionStateListener(Promise promise) { + enableWaypointMissionStateListener = false; + promise.resolve("stopWaypointMissionStateListener"); + } + + private void sendWaypointMissionStateUpdate(MissionState missionState) { + if (enableWaypointMissionStateListener) { + eventSender.processEvent(SDKEvent.WaypointMissionState, missionState.getName(), true); + } + } + + private void sendWaypointMissionError(DJIError error) { + eventSender.processEvent(SDKEvent.WaypointMissionError, error.getDescription(), true); + } + + private void sendNullWaypointMissionError() { + eventSender.processEvent(SDKEvent.WaypointMissionError, null, true); + } + + @ReactMethod + public void startWaypointMissionUploadListener(Promise promise) { + enableWaypointMissionUploadListener = true; + setWaypointMissionOperatorListener(); + promise.resolve("startWaypointMissionUploadListener"); + } + + @ReactMethod + public void stopWaypointMissionUploadListener(Promise promise) { + enableWaypointExecutionUpdateListener = false; + promise.resolve("stopWaypointMissionUploadListener"); + } + + private void sendWaypointMissionUploadUpdate(WaypointUploadProgress waypointUploadProgress) { + if (enableWaypointMissionUploadListener && waypointUploadProgress != null) { + WritableMap progressMap = Arguments.createMap(); + progressMap.putInt("uploadedWaypointIndex", waypointUploadProgress.uploadedWaypointIndex); + progressMap.putInt("totalWaypointCount", waypointUploadProgress.totalWaypointCount); + progressMap.putBoolean("isSummaryUploaded", waypointUploadProgress.isSummaryUploaded); + eventSender.processEvent(SDKEvent.WaypointMissionUploadProgress, progressMap, true); + } + } + @ReactMethod public void startRecordFlightData(String fileName, Promise promise){ if (djiRealTimeDataLogger == null) { @@ -291,7 +391,7 @@ public void stopRecordFlightData(Promise promise) { @ReactMethod public void setAutoFlightSpeed(float speed, final Promise promise) { - getWaypointMissionOperator().setAutoFlightSpeed(speed, new CommonCallbacks.CompletionCallback() { + getWaypointMissionOperator().setAutoFlightSpeed(speed, new CommonCallbacks.CompletionCallback() { @Override public void onResult(DJIError djiError) { if (djiError == null) { @@ -546,6 +646,65 @@ public void onFailure(DJIError djiError) { }); } + @ReactMethod + public void setAircraftLEDsState(final ReadableMap ledSettingsMap, final Promise promise) { + LEDsSettings.Builder builder = new LEDsSettings.Builder(); + try { + Boolean frontLEDsOn = ledSettingsMap.getBoolean("frontLEDsOn"); + builder.frontLEDsOn(frontLEDsOn); + } catch (Exception e) {} + try { + Boolean rearLEDsOn = ledSettingsMap.getBoolean("rearLEDsOn"); + builder.rearLEDsOn(rearLEDsOn); + } catch (Exception e) {} + try { + Boolean statusIndicatorOn = ledSettingsMap.getBoolean("statusIndicatorOn"); + builder.statusIndicatorOn(statusIndicatorOn); + } catch (Exception e) {} + try { + Boolean beaconsOn = ledSettingsMap.getBoolean("beaconsOn"); + builder.beaconsOn(beaconsOn); + } catch (Exception e) {} + + LEDsSettings ledSettings = builder.build(); + DJIKey key = FlightControllerKey.create(FlightControllerKey.LEDS_ENABLED_SETTINGS); + DJISDKManager.getInstance().getKeyManager().setValue(key, ledSettings, new SetCallback() { + @Override + public void onSuccess() { + promise.resolve(null); + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + promise.reject(new Throwable("setAircraftLEDsState error: " + djiError.getDescription())); + } + }); + } + + @ReactMethod + public void getAircraftLEDsState(final Promise promise) { + DJIKey key = FlightControllerKey.create(FlightControllerKey.LEDS_ENABLED_SETTINGS); + DJISDKManager.getInstance().getKeyManager().getValue(key, new GetCallback() { + @Override + public void onSuccess(@NonNull Object o) { + if (o instanceof LEDsSettings) { + LEDsSettings ledSettings = (LEDsSettings)o; + WritableMap settings = Arguments.createMap(); + settings.putBoolean("areFrontLEDsOn", ledSettings.areFrontLEDsOn()); + settings.putBoolean("areRearLEDsOn", ledSettings.areRearLEDsOn()); + settings.putBoolean("areBeaconsOn", ledSettings.areBeaconsOn()); + settings.putBoolean("isStatusIndicatorOn", ledSettings.isStatusIndicatorOn()); + promise.resolve(settings); + } + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + promise.reject(new Throwable("getAircraftLEDsState error: " + djiError.getDescription())); + } + }); + } + @Nonnull @Override public String getName() { diff --git a/android/src/main/java/com/aerobotics/DjiMobile/Helpers.java b/android/src/main/java/com/aerobotics/DjiMobile/Helpers.java new file mode 100644 index 00000000..18edbdc5 --- /dev/null +++ b/android/src/main/java/com/aerobotics/DjiMobile/Helpers.java @@ -0,0 +1,26 @@ +package com.aerobotics.DjiMobile; + +import dji.common.product.Model; +import dji.sdk.sdkmanager.DJISDKManager; + +public class Helpers { + + public static boolean isMultiStreamPlatform() { + if (DJISDKManager.getInstance() == null){ + return false; + } + Model model = DJISDKManager.getInstance().getProduct().getModel(); + return model != null && (model == Model.INSPIRE_2 + || model == Model.MATRICE_200 + || model == Model.MATRICE_210 + || model == Model.MATRICE_210_RTK + || model == Model.MATRICE_200_V2 + || model == Model.MATRICE_210_V2 + || model == Model.MATRICE_210_RTK_V2 + || model == Model.MATRICE_300_RTK + || model == Model.MATRICE_600 + || model == Model.MATRICE_600_PRO + || model == Model.A3 + || model == Model.N3); + } +} diff --git a/android/src/main/java/com/aerobotics/DjiMobile/SDKEvent.java b/android/src/main/java/com/aerobotics/DjiMobile/SDKEvent.java index 2ff6e416..e26d7032 100644 --- a/android/src/main/java/com/aerobotics/DjiMobile/SDKEvent.java +++ b/android/src/main/java/com/aerobotics/DjiMobile/SDKEvent.java @@ -9,6 +9,7 @@ public enum SDKEvent { ProductConnection(ProductKey.create(ProductKey.CONNECTION), EventType.DJI_KEY_MANAGER_EVENT), + CameraConnection(CameraKey.create(CameraKey.CONNECTION), EventType.DJI_KEY_MANAGER_EVENT), BatteryChargeRemaining(BatteryKey.create(BatteryKey.CHARGE_REMAINING_IN_PERCENT), EventType.DJI_KEY_MANAGER_EVENT), AircraftCompassHeading(FlightControllerKey.create(FlightControllerKey.COMPASS_HEADING), EventType.DJI_KEY_MANAGER_EVENT), AircraftLocation(FlightControllerKey.create(FlightControllerKey.AIRCRAFT_LOCATION), EventType.DJI_KEY_MANAGER_EVENT), @@ -26,6 +27,8 @@ public enum SDKEvent { AircraftAttitudeRoll(FlightControllerKey.create(FlightControllerKey.ATTITUDE_ROLL), EventType.DJI_KEY_MANAGER_EVENT), AircraftGpsSignalLevel(FlightControllerKey.create(FlightControllerKey.GPS_SIGNAL_LEVEL), EventType.DJI_KEY_MANAGER_EVENT), + SatelliteCount(FlightControllerKey.create(FlightControllerKey.SATELLITE_COUNT), EventType.DJI_KEY_MANAGER_EVENT), + AirLinkUplinkSignalQuality(null, EventType.DJI_KEY_MANAGER_EVENT), AirLinkLightbridgeUplinkSignalQuality(AirLinkKey.createLightbridgeLinkKey(AirLinkKey.UPLINK_SIGNAL_QUALITY), EventType.DJI_KEY_MANAGER_EVENT), AirLinkOcuSyncUplinkSignalQuality(AirLinkKey.createOcuSyncLinkKey(AirLinkKey.UPLINK_SIGNAL_QUALITY), EventType.DJI_KEY_MANAGER_EVENT), @@ -33,22 +36,44 @@ public enum SDKEvent { AirLinkLightbridgeDownlinkSignalQuality(AirLinkKey.createLightbridgeLinkKey(AirLinkKey.DOWNLINK_SIGNAL_QUALITY), EventType.DJI_KEY_MANAGER_EVENT), AirLinkOcuSyncDownlinkSignalQuality(AirLinkKey.createOcuSyncLinkKey(AirLinkKey.DOWNLINK_SIGNAL_QUALITY), EventType.DJI_KEY_MANAGER_EVENT), AircraftHomeLocation(FlightControllerKey.create(FlightControllerKey.HOME_LOCATION), EventType.DJI_KEY_MANAGER_EVENT), + IsHomeLocationSet(FlightControllerKey.create(FlightControllerKey.IS_HOME_LOCATION_SET), EventType.DJI_KEY_MANAGER_EVENT), TakeoffLocationAltitude(FlightControllerKey.create(FlightControllerKey.TAKEOFF_LOCATION_ALTITUDE), EventType.DJI_KEY_MANAGER_EVENT), AircraftUltrasonicHeight(FlightControllerKey.create(FlightControllerKey.ULTRASONIC_HEIGHT_IN_METERS), EventType.DJI_KEY_MANAGER_EVENT), CompassHasError(FlightControllerKey.create(FlightControllerKey.COMPASS_HAS_ERROR), EventType.DJI_KEY_MANAGER_EVENT), + IMUSensorState(FlightControllerKey.create(FlightControllerKey.IMU_STATE), EventType.DJI_KEY_MANAGER_EVENT), + AircraftIsFlying(FlightControllerKey.create(FlightControllerKey.IS_FLYING), EventType.DJI_KEY_MANAGER_EVENT), LandingProtectionEnabled(FlightControllerKey.create(FlightControllerKey.LANDING_PROTECTION_ENABLED), EventType.DJI_KEY_MANAGER_EVENT), VisionAssistedPositioningEnabled(FlightControllerKey.create(FlightControllerKey.VISION_ASSISTED_POSITIONING_ENABLED), EventType.DJI_KEY_MANAGER_EVENT), + RemoteControllerFlightMode(FlightControllerKey.create(FlightControllerKey.CURRENT_MODE), EventType.DJI_KEY_MANAGER_EVENT), + AircraftFlightMode(FlightControllerKey.create(FlightControllerKey.FLIGHT_MODE), EventType.DJI_KEY_MANAGER_EVENT), - CameraIsRecording(CameraKey.create(CameraKey.IS_RECORDING), EventType.DJI_KEY_MANAGER_EVENT), + // Camera & SD Card Events SDCardIsInserted(CameraKey.create(CameraKey.SDCARD_IS_INSERTED), EventType.DJI_KEY_MANAGER_EVENT), SDCardIsReadOnly(CameraKey.create(CameraKey.SDCARD_IS_READ_ONLY), EventType.DJI_KEY_MANAGER_EVENT), + SDCardAvailableCaptureCount(CameraKey.create(CameraKey.SDCARD_AVAILABLE_CAPTURE_COUNT), EventType.DJI_KEY_MANAGER_EVENT), + CameraIsRecording(CameraKey.create(CameraKey.IS_RECORDING), EventType.DJI_KEY_MANAGER_EVENT), + CameraIsShootingSinglePhoto(CameraKey.create(CameraKey.IS_SHOOTING_SINGLE_PHOTO), EventType.DJI_KEY_MANAGER_EVENT), + CameraIsStoringPhoto(CameraKey.create(CameraKey.IS_STORING_PHOTO), EventType.DJI_KEY_MANAGER_EVENT), + CameraIsShootingPhoto(CameraKey.create(CameraKey.IS_SHOOTING_PHOTO), EventType.DJI_KEY_MANAGER_EVENT), + CameraDidUpdateSystemState(null, EventType.DJI_CAMERA_DELEGATE_EVENT), + CameraDidGenerateNewMediaFile(null, EventType.DJI_CAMERA_DELEGATE_EVENT), + CameraExposureSettings(CameraKey.create(CameraKey.EXPOSURE_SETTINGS), EventType.DJI_KEY_MANAGER_EVENT), + CameraWhiteBalance(CameraKey.create(CameraKey.WHITE_BALANCE), EventType.DJI_KEY_MANAGER_EVENT), + CameraPhotoFileFormat(CameraKey.create(CameraKey.PHOTO_FILE_FORMAT), EventType.DJI_KEY_MANAGER_EVENT), + CameraPhotoAspectRatio(CameraKey.create(CameraKey.PHOTO_ASPECT_RATIO), EventType.DJI_KEY_MANAGER_EVENT), + CameraExposureMode(CameraKey.create(CameraKey.EXPOSURE_MODE), EventType.DJI_KEY_MANAGER_EVENT), GimbalIsAtYawStop(GimbalKey.create(GimbalKey.IS_YAW_AT_STOP), EventType.DJI_KEY_MANAGER_EVENT), WaypointMissionFinished(null, EventType.DJI_KEY_MANAGER_EVENT), WaypointMissionStarted(null, EventType.DJI_KEY_MANAGER_EVENT), WaypointMissionExecutionProgress(null, EventType.DJI_KEY_MANAGER_EVENT), + WaypointMissionUploadProgress(null, EventType.DJI_KEY_MANAGER_EVENT), + WaypointMissionError(null, EventType.DJI_KEY_MANAGER_EVENT), + WaypointMissionActionUploadProgress(null, EventType.DJI_KEY_MANAGER_EVENT), + WaypointMissionState(null, EventType.DJI_KEY_MANAGER_EVENT), + WaypointMissionActionState(null, EventType.DJI_KEY_MANAGER_EVENT), VirtualStickTimelineElementEvent(null, EventType.DJI_KEY_MANAGER_EVENT), @@ -56,10 +81,6 @@ public enum SDKEvent { OnboardSDKDeviceData(null, EventType.DJI_ONBOARD_SDK_DEVICE_DATA_EVENT), - CameraDidUpdateSystemState(null, EventType.DJI_CAMERA_DELEGATE_EVENT), - CameraDidGenerateNewMediaFile(null, EventType.DJI_CAMERA_DELEGATE_EVENT), - CameraExposureSettings(CameraKey.create(CameraKey.EXPOSURE_SETTINGS), EventType.DJI_KEY_MANAGER_EVENT), - VisionDetectionState(FlightControllerKey.createFlightAssistantKey(FlightControllerKey.VISION_DETECTION_STATE), EventType.DJI_KEY_MANAGER_EVENT), VisionControlState(null, EventType.DJI_CALLBACK_EVENT), diff --git a/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointMissionV2ActionsBuilder.java b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointMissionV2ActionsBuilder.java new file mode 100644 index 00000000..2154e91c --- /dev/null +++ b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointMissionV2ActionsBuilder.java @@ -0,0 +1,67 @@ +package com.aerobotics.DjiMobile.WaypointMissionV2; + +import com.facebook.react.bridge.ReadableArray; +import com.facebook.react.bridge.ReadableMap; + +import java.util.ArrayList; +import java.util.List; + +import dji.common.mission.waypointv2.Action.WaypointV2Action; +import dji.sdk.base.BaseProduct; +import dji.sdk.camera.Camera; +import dji.sdk.products.Aircraft; +import dji.sdk.sdkmanager.DJISDKManager; + +/** + * Note that this is non-generic, and very much built for a waypoint mapping mission application. + * This is largely due to the complexity of building these actions + * + * TODO: if necessary, make more generic/customizable + */ +public class WaypointMissionV2ActionsBuilder { + List waypointActionList; + + public WaypointMissionV2ActionsBuilder(ReadableMap parameters) throws Exception { + if (!parameters.hasKey("waypoints")) { + throw new Exception(("Cannot build mission actions with null waypoints")); + } + + // Each action collection is allocated 100 possible actions to avoid duplicated IDs + int actionId = 0; + waypointActionList = new ArrayList<>(); + ReadableArray waypointsParameter = parameters.getArray("waypoints"); + for (int i = 0; i < waypointsParameter.size(); i++) { + ReadableMap waypointParams = waypointsParameter.getMap(i); + + /* + * Focus camera at first waypoint for P1 camera + * TODO: Do we want this? (this was straight from the DJI sample) + */ + if (i == 0) { + final BaseProduct product = DJISDKManager.getInstance().getProduct(); + if (product instanceof Aircraft) { + Camera camera = ((Aircraft) product).getCamera(); + if (camera != null && camera.getDisplayName().equals("Zenmuse P1")) { + waypointActionList.addAll(WaypointV2ActionFactory.getActiveFocusAction(0, actionId, -90f)); + actionId += 1; + } + } + } + + /* + * Add take photo at distance interval action to all waypoints except the last. + */ + if (i < waypointsParameter.size() - 1) { + if (waypointParams.hasKey("shootPhotoDistanceInterval")) { + double shootPhotoDistanceInterval = waypointParams.getDouble("shootPhotoDistanceInterval"); + waypointActionList.addAll(WaypointV2ActionFactory.getCameraShootPhotoIntervalAction(i, actionId, (float) shootPhotoDistanceInterval)); + actionId += 1; + } + } + } + } + + public List build() { + return waypointActionList; + } +} diff --git a/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointMissionV2Builder.java b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointMissionV2Builder.java new file mode 100644 index 00000000..6555cec1 --- /dev/null +++ b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointMissionV2Builder.java @@ -0,0 +1,103 @@ +package com.aerobotics.DjiMobile.WaypointMissionV2; + +import com.facebook.react.bridge.ReadableArray; +import com.facebook.react.bridge.ReadableMap; + +import java.util.ArrayList; +import java.util.List; + +import dji.common.mission.waypointv2.WaypointV2; +import dji.common.mission.waypointv2.WaypointV2Mission; +import dji.common.mission.waypointv2.WaypointV2MissionTypes; +import dji.common.mission.waypointv2.WaypointV2MissionTypes.WaypointV2FlightPathMode; +import dji.common.mission.waypointv2.WaypointV2MissionTypes.WaypointV2HeadingMode; +import dji.common.model.LocationCoordinate2D; + +import static dji.common.mission.waypoint.Waypoint.MIN_CORNER_RADIUS; + +/** + * Compose and build WaypointV2 list. Note that only parameters that have been tested have been + * included in this wrapper, and thus, it is not yet exhaustive. + */ +public class WaypointMissionV2Builder extends WaypointV2Mission.Builder { + public WaypointMissionV2Builder(ReadableMap parameters) throws Exception { + if (!parameters.hasKey("autoFlightSpeed")) { + throw new Exception(("Cannot build mission with null autoFlightSpeed")); + } + + if (!parameters.hasKey("maxFlightSpeed")) { + throw new Exception(("Cannot build mission with null maxFlightSpeed")); + } + + if (!parameters.hasKey("waypoints")) { + throw new Exception(("Cannot build mission with null waypoints")); + } + + this.setAutoFlightSpeed((float) parameters.getDouble("autoFlightSpeed")); + this.setMaxFlightSpeed((float) parameters.getDouble("maxFlightSpeed")); + + if (parameters.hasKey("goToWaypointMode")) { + // Default is "SAFELY" + this.setGotoFirstWaypointMode(WaypointV2MissionTypes.MissionGotoWaypointMode.valueOf(parameters.getString("goToWaypointMode"))); + } + + if (parameters.hasKey("finishedAction")) { + this.setFinishedAction(WaypointV2MissionTypes.MissionFinishedAction.valueOf(parameters.getString("finishedAction"))); + } + + // In Waypoint Mission V2, this is defined on the waypoint level + // Default is "CURVATURE_CONTINUOUS_PASSED" - overwrite default to "GOTO_POINT_STRAIGHT_LINE_AND_STOP" + WaypointV2MissionTypes.WaypointV2FlightPathMode flightPathMode = WaypointV2FlightPathMode.GOTO_POINT_STRAIGHT_LINE_AND_STOP; + if (parameters.hasKey("flightPathMode")) { + flightPathMode = WaypointV2MissionTypes.WaypointV2FlightPathMode.valueOf(parameters.getString("flightPathMode")); + } + + List waypointV2List = new ArrayList<>(); + ReadableArray waypointsParameter = parameters.getArray("waypoints"); + for (int i = 0, n = waypointsParameter.size(); i < n; i++) { + ReadableMap waypointParams = waypointsParameter.getMap(i); + double longitude = waypointParams.getDouble("longitude"); + double latitude = waypointParams.getDouble("latitude"); + double altitude = waypointParams.getDouble("altitude"); + + WaypointV2.Builder waypointBuilder = new WaypointV2.Builder(); + + LocationCoordinate2D coordinateLatLng = new LocationCoordinate2D(latitude, longitude); + waypointBuilder + .setAltitude(altitude) + .setCoordinate(coordinateLatLng) + .setFlightPathMode(flightPathMode); + + if (waypointParams.hasKey("cornerRadiusInMeters") && flightPathMode.equals(WaypointV2FlightPathMode.COORDINATE_TURN)) { + /* + * Gotcha: using 'GOTO_POINT_STRAIGHT_LINE_AND_STOP' for the first and last waypoints + * causes a strange curved flight path, so we have to use 'GOTO_FIRST_POINT_ALONG_STRAIGHT_LINE' + * and 'STRAIGHT_OUT'. However, these both need a damping distance > 0.2m, although this + * damping distance seems to make no difference to the flight path, so using the min (0.2m) + */ + if (i == 0) { + waypointBuilder + .setFlightPathMode(WaypointV2FlightPathMode.GOTO_FIRST_POINT_ALONG_STRAIGHT_LINE) + .setDampingDistance(MIN_CORNER_RADIUS); + } else if (i == n - 1) { + waypointBuilder + .setFlightPathMode(WaypointV2FlightPathMode.STRAIGHT_OUT) + .setDampingDistance(MIN_CORNER_RADIUS); + } else { + double cornerRadiusInMeters = waypointParams.getDouble("cornerRadiusInMeters"); + // Ensure corner radius >= MIN_CORNER_RADIUS (0.2m) + waypointBuilder + .setFlightPathMode(WaypointV2FlightPathMode.COORDINATE_TURN) + .setDampingDistance(Math.max((float) cornerRadiusInMeters, MIN_CORNER_RADIUS)); + } + } + + if (waypointParams.hasKey("headingMode")) { + waypointBuilder.setHeadingMode(WaypointV2HeadingMode.valueOf(waypointParams.getString("headingMode"))); + } + + waypointV2List.add(waypointBuilder.build()); + } + this.addwaypoints(waypointV2List); + } +} diff --git a/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointMissionV2Wrapper.java b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointMissionV2Wrapper.java new file mode 100644 index 00000000..28460e13 --- /dev/null +++ b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointMissionV2Wrapper.java @@ -0,0 +1,546 @@ +package com.aerobotics.DjiMobile.WaypointMissionV2; + +import android.util.Log; + +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; + +import com.aerobotics.DjiMobile.EventSender; +import com.aerobotics.DjiMobile.SDKEvent; +import com.facebook.react.bridge.Arguments; +import com.facebook.react.bridge.Promise; +import com.facebook.react.bridge.ReactApplicationContext; +import com.facebook.react.bridge.ReactContextBaseJavaModule; +import com.facebook.react.bridge.ReactMethod; +import com.facebook.react.bridge.ReadableMap; +import com.facebook.react.bridge.WritableMap; + +import java.util.List; + +import javax.annotation.Nonnull; + +import dji.common.error.DJIError; +import dji.common.error.DJIWaypointV2Error; +import dji.common.mission.waypoint.WaypointMissionState; +import dji.common.mission.waypointv2.Action.ActionDownloadEvent; +import dji.common.mission.waypointv2.Action.ActionExecutionEvent; +import dji.common.mission.waypointv2.Action.ActionState; +import dji.common.mission.waypointv2.Action.ActionUploadEvent; +import dji.common.mission.waypointv2.Action.ActionUploadProgress; +import dji.common.mission.waypointv2.Action.WaypointV2Action; +import dji.common.mission.waypointv2.WaypointV2ExecutionProgress; +import dji.common.mission.waypointv2.WaypointV2Mission; +import dji.common.mission.waypointv2.WaypointV2MissionDownloadEvent; +import dji.common.mission.waypointv2.WaypointV2MissionExecutionEvent; +import dji.common.mission.waypointv2.WaypointV2MissionState; +import dji.common.mission.waypointv2.WaypointV2MissionUploadEvent; +import dji.common.mission.waypointv2.WaypointV2UploadProgress; +import dji.common.util.CommonCallbacks; +import dji.keysdk.DJIKey; +import dji.keysdk.KeyManager; +import dji.keysdk.ProductKey; +import dji.keysdk.callback.GetCallback; +import dji.keysdk.callback.KeyListener; +import dji.sdk.base.BaseProduct; +import dji.sdk.camera.Camera; +import dji.sdk.mission.waypoint.WaypointV2ActionListener; +import dji.sdk.mission.waypoint.WaypointV2MissionOperator; +import dji.sdk.mission.waypoint.WaypointV2MissionOperatorListener; +import dji.sdk.products.Aircraft; +import dji.sdk.sdkmanager.DJISDKManager; + + +public class WaypointMissionV2Wrapper extends ReactContextBaseJavaModule { + private final EventSender eventSender; + + private boolean enableWaypointExecutionFinishListener = false; + private boolean enableWaypointExecutionUpdateListener = false; + private boolean enableWaypointMissionStateListener = false; + private boolean enableWaypointMissionUploadListener = false; + + private boolean startListenersOnProductConnection = false; + + private static WaypointV2MissionOperatorListener waypointMissionOperatorListener; + private static WaypointV2ActionListener waypointActionListener; + + List waypointActionsList; + + public WaypointMissionV2Wrapper(@Nonnull ReactApplicationContext reactContext) { + super(reactContext); + this.eventSender = new EventSender(reactContext); + } + + @ReactMethod + public void uploadWaypointMission(ReadableMap parameters, Promise promise) { + try { + WaypointV2Mission waypointMission = new WaypointMissionV2Builder(parameters).build(); + waypointActionsList = new WaypointMissionV2ActionsBuilder(parameters).build(); + loadAndUploadMission(waypointMission, promise); + } catch (Exception error) { + promise.reject(new Throwable(error)); + } + } + + @ReactMethod + public void startWaypointMission(final Promise promise) { + try { + if (!getWaypointMissionOperator().getCurrentState().equals(WaypointV2MissionState.READY_TO_EXECUTE)) { + throw new Exception("Incorrect mission state " + getWaypointMissionOperator().getCurrentState().name()); + } + getWaypointMissionOperator().startMission(new CommonCallbacks.CompletionCallback() { + @Override + public void onResult(DJIWaypointV2Error error) { + if (error == null) { + promise.resolve(null); + eventSender.processEvent(SDKEvent.WaypointMissionStarted, true, true); + } else { + promise.reject(new Throwable("startWaypointMission: " + error.getDescription())); + eventSender.processEvent(SDKEvent.WaypointMissionStarted, false, true); + } + } + }); + } catch (Exception exception) { + promise.reject(new Throwable("Failed to start mission " + exception.getMessage())); + } + } + + public void startListenersOnProductConnection() { + if (startListenersOnProductConnection) { + setWaypointMissionOperatorListener(); + setWaypointActionListener(); + } + } + + private void setWaypointMissionOperatorListener() { + try { + if (waypointMissionOperatorListener != null) { + return; + } + waypointMissionOperatorListener = new WaypointV2MissionOperatorListener() { + @Override + public void onDownloadUpdate(@NonNull WaypointV2MissionDownloadEvent event) { + } + + @Override + public void onUploadUpdate(@NonNull WaypointV2MissionUploadEvent event) { + try { + handlePossibleErrorUpdate(event.getError()); + if (event.getProgress() != null) { + sendWaypointMissionUploadUpdate(event.getProgress()); + } + + + // Since action state updates and mission state updates are merged, use the "action" + // state update to send the READY_TO_EXECUTE message + if (event.getCurrentState().equals(WaypointV2MissionState.READY_TO_EXECUTE)) { + Log.i("REACT", "Current mission state is READY_TO_EXECUTE, waiting for action state to be ready"); + return; + } + /* + * The event state differs from the mission operator state at times. + * Choosing to use the mission operator state as the source of truth. + */ + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); + } catch (Exception exception) { + Log.w("REACT", exception); + } + } + + @Override + public void onExecutionUpdate(@NonNull WaypointV2MissionExecutionEvent event) { + try { + handlePossibleErrorUpdate(event.getError()); + sendWaypointMissionExecutionUpdate(event.getProgress()); + /* + * The event state differs from the mission operator state at times. + * Choosing to use the mission operator state as the source of truth. + */ + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); + } catch (Exception exception) { + Log.w("REACT", exception); + } + } + + @Override + public void onExecutionStart() { + try { + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); + } catch (Exception exception) { + Log.w("REACT", exception); + } + } + + @Override + public void onExecutionFinish(@Nullable DJIWaypointV2Error error) { + try { + handlePossibleErrorUpdate(error); + if (enableWaypointExecutionFinishListener) { + eventSender.processEvent(SDKEvent.WaypointMissionFinished, true, true); + } + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); + } catch (Exception exception) { + Log.w("REACT", exception); + } + } + + @Override + public void onExecutionStopped() { + } + }; + getWaypointMissionOperator().addWaypointEventListener(waypointMissionOperatorListener); + sendWaypointMissionStateUpdate(getWaypointMissionOperator().getCurrentState()); + } catch (Exception exception) { + Log.w("REACT", exception); + waypointMissionOperatorListener = null; + } + } + + private void setWaypointActionListener() { + try { + if (waypointActionListener != null) { + return; + } + waypointActionListener = new WaypointV2ActionListener() { + @Override + public void onDownloadUpdate(@NonNull ActionDownloadEvent event) { + } + + @Override + public void onUploadUpdate(@NonNull ActionUploadEvent event) { + try { + handlePossibleErrorUpdate(event.getError()); + if (event.getCurrentState().equals(ActionState.READY_TO_UPLOAD)) { + try { + uploadWaypointActions(); + } catch (Exception error) { + sendWaypointMissionError(error.getMessage()); + } + } + if (event.getProgress() != null) { + sendWaypointMissionActionUploadUpdate(event.getProgress()); + } + if (event.getPreviousState() == ActionState.UPLOADING && event.getCurrentState() == ActionState.READY_TO_EXECUTE) { + Log.i("REACT", "Action state is READY_TO_EXECUTE, sending mission READY_TO_EXECUTE!"); + sendWaypointMissionStateUpdate(WaypointV2MissionState.READY_TO_EXECUTE); + } + /* + * The event state differs from the mission operator state at times. + * Choosing to use the mission operator state as the source of truth. + */ + sendWaypointMissionActionStateUpdate(getWaypointMissionOperator().getCurrentActionState()); + } catch ( + Exception exception) { + Log.w("REACT", exception); + } + } + + @Override + public void onExecutionUpdate(@NonNull ActionExecutionEvent event) { + try { + handlePossibleErrorUpdate(event.getError()); + /* + * The event state differs from the mission operator state at times. + * Choosing to use the mission operator state as the source of truth. + */ + sendWaypointMissionActionStateUpdate(getWaypointMissionOperator().getCurrentActionState()); + } catch (Exception exception) { + Log.w("REACT", exception); + } + } + + @Override + public void onExecutionStart(int i) { + } + + @Override + public void onExecutionFinish(int i, @Nullable DJIWaypointV2Error error) { + handlePossibleErrorUpdate(error); + } + }; + getWaypointMissionOperator().addActionListener(waypointActionListener); + } catch ( + Exception exception) { + Log.w("REACT", exception); + waypointActionListener = null; + } + } + + /** + * Send an error event if an error has occurred, otherwise clear the error by sending a null + * error. + */ + private void handlePossibleErrorUpdate(@Nullable DJIWaypointV2Error error) { + if (error != null) { + sendWaypointMissionError(error); + } else { + // clear any existing error events + sendNullWaypointMissionError(); + } + } + + private void sendWaypointMissionError(@NonNull DJIError error) { + eventSender.processEvent(SDKEvent.WaypointMissionError, error.getDescription(), true); + } + + private void sendWaypointMissionError(String errorMsg) { + eventSender.processEvent(SDKEvent.WaypointMissionError, errorMsg, true); + } + + private void sendNullWaypointMissionError() { + eventSender.processEvent(SDKEvent.WaypointMissionError, null, true); + } + + private void loadAndUploadMission(WaypointV2Mission mission, final Promise promise) { + try { + getWaypointMissionOperator().loadMission(mission, new CommonCallbacks.CompletionCallback() { + @Override + public void onResult(DJIWaypointV2Error error) { + if (error == null) { + uploadMission(promise); + } else { + promise.reject(new Throwable("loadAndUploadMission error: Upload Failed" + error.getDescription())); + } + } + }); + } catch (Exception exception) { + promise.reject(new Throwable(exception)); + } + } + + private void uploadMission(final Promise promise) { + try { + getWaypointMissionOperator().uploadMission(new CommonCallbacks.CompletionCallback() { + @Override + public void onResult(DJIWaypointV2Error error) { + if (error == null) { + promise.resolve(null); + } else { + promise.reject(new Throwable("uploadMission error: Upload Failed" + error.getDescription())); + } + } + }); + } catch (Exception exception) { + promise.reject(new Throwable(exception)); + } + } + + private void uploadWaypointActions() throws Exception { + getWaypointMissionOperator().uploadWaypointActions(waypointActionsList, new CommonCallbacks.CompletionCallback() { + @Override + public void onResult(DJIWaypointV2Error error) { + handlePossibleErrorUpdate(error); + } + }); + } + + private WaypointV2MissionOperator getWaypointMissionOperator() throws MissionOperatorNullException { + WaypointV2MissionOperator waypointMissionOperator = DJISDKManager.getInstance().getMissionControl().getWaypointMissionV2Operator(); + if (waypointMissionOperator == null) { + throw new MissionOperatorNullException("Waypoint mission operator is null"); + } + return waypointMissionOperator; + } + + @ReactMethod + public void stopWaypointMission(final Promise promise) { + try { + getWaypointMissionOperator().stopMission(new CommonCallbacks.CompletionCallback() { + @Override + public void onResult(DJIWaypointV2Error djiError) { + if (djiError == null) { + promise.resolve(null); + } else { + promise.reject(new Throwable("stopWaypointMission error: " + djiError.getDescription())); + } + } + }); + } catch (Exception exception) { + promise.reject(new Throwable("stopWaypointMission error: " + exception.getMessage())); + } + } + + @ReactMethod + public void setWaypointMissionAutoFlightSpeed(Float speed, final Promise promise) { + try { + getWaypointMissionOperator().setAutoFlightSpeed(speed, new CommonCallbacks.CompletionCallback() { + @Override + public void onResult(DJIWaypointV2Error djiError) { + if (djiError == null) { + promise.resolve(null); + } else { + promise.reject(new Throwable("setWaypointMissionAutoFlightSpeed error: " + djiError.getDescription())); + } + } + }); + } catch (Exception exception) { + promise.reject(new Throwable("setWaypointMissionAutoFlightSpeed error: " + exception.getMessage())); + } + } + + @ReactMethod + public void stopAllWaypointMissionListeners(Promise promise) { + try { + enableWaypointExecutionUpdateListener = false; + enableWaypointExecutionFinishListener = false; + getWaypointMissionOperator().removeWaypointListener(waypointMissionOperatorListener); + getWaypointMissionOperator().removeActionListener(waypointActionListener); + promise.resolve(null); + } catch (Exception exception) { + promise.reject(new Throwable("stopAllWaypointMissionListeners error: " + exception.getMessage())); + } + } + + @ReactMethod + public void startWaypointExecutionUpdateListener(Promise promise) { + try { + enableWaypointExecutionUpdateListener = true; + startListenersOnProductConnection = true; + startProductConnectionListener(); + promise.resolve(null); + } catch (Exception exception) { + promise.reject(new Throwable("startWaypointExecutionUpdateListener: " + exception.getMessage())); + } + } + + private void sendWaypointMissionExecutionUpdate(@Nullable WaypointV2ExecutionProgress progress) { + if (enableWaypointExecutionUpdateListener && progress != null) { + WritableMap progressMap = Arguments.createMap(); + progressMap.putInt("targetWaypointIndex", progress.getTargetWaypointIndex()); + progressMap.putBoolean("isWaypointReached", progress.isWaypointReached()); + progressMap.putString("executeState", progress.getExecuteState().name()); + + try { + WaypointV2Mission waypointMission = getWaypointMissionOperator().getLoadedMission(); + if (waypointMission != null) { + progressMap.putInt("totalWaypointCount", waypointMission.getWaypointCount()); + } + } catch (Exception exception) { + Log.w("REACT", "sendWaypointMissionExecutionUpdate: " + exception.getMessage()); + } + + eventSender.processEvent(SDKEvent.WaypointMissionExecutionProgress, progressMap, true); + } + } + + @ReactMethod + public void startWaypointMissionStateListener(Promise promise) { + try { + enableWaypointMissionStateListener = true; + startListenersOnProductConnection = true; + startProductConnectionListener(); + promise.resolve(null); + } catch (Exception exception) { + promise.reject(new Throwable("startWaypointMissionStateListener: " + exception.getMessage())); + } + } + + @ReactMethod + public void stopWaypointMissionStateListener(Promise promise) { + enableWaypointMissionStateListener = false; + promise.resolve(null); + } + + private void sendWaypointMissionStateUpdate(WaypointV2MissionState missionState) { + if (enableWaypointMissionStateListener) { + // Merge V1 and V2 waypoint mission states + if (missionState.equals(WaypointV2MissionState.INTERRUPTED)) { + eventSender.processEvent(SDKEvent.WaypointMissionState, WaypointMissionState.EXECUTION_PAUSED.getName(), true); + } else { + eventSender.processEvent(SDKEvent.WaypointMissionState, missionState.name(), true); + } + } + } + + private void sendWaypointMissionActionStateUpdate(ActionState state) { + if (enableWaypointMissionStateListener) { + eventSender.processEvent(SDKEvent.WaypointMissionActionState, state.name(), true); + } + } + + @ReactMethod + public void startWaypointMissionUploadListener(Promise promise) { + try { + enableWaypointMissionUploadListener = true; + startListenersOnProductConnection = true; + startProductConnectionListener(); + promise.resolve(null); + } catch (Exception exception) { + promise.reject(new Throwable("startWaypointMissionUploadListener: " + exception.getMessage())); + } + } + + @ReactMethod + public void stopWaypointMissionUploadListener(Promise promise) { + enableWaypointExecutionUpdateListener = false; + promise.resolve("stopWaypointMissionUploadListener"); + } + + private void sendWaypointMissionUploadUpdate(WaypointV2UploadProgress waypointUploadProgress) { + if (enableWaypointMissionUploadListener && waypointUploadProgress != null) { + WritableMap progressMap = Arguments.createMap(); + progressMap.putInt("uploadedWaypointIndex", waypointUploadProgress.getLastUploadedWaypointIndex()); + progressMap.putInt("totalWaypointCount", waypointUploadProgress.getTotalWaypointCount()); + progressMap.putBoolean("isSummaryUploaded", waypointUploadProgress.isSummaryUploaded()); + eventSender.processEvent(SDKEvent.WaypointMissionUploadProgress, progressMap, true); + } + } + + private void sendWaypointMissionActionUploadUpdate(@NonNull ActionUploadProgress progress) { + if (enableWaypointMissionUploadListener) { + WritableMap progressMap = Arguments.createMap(); + progressMap.putInt("uploadedWaypointIndex", progress.getLastUploadedWaypointIndex()); + progressMap.putInt("totalActionCount", progress.getTotalActionCount()); + eventSender.processEvent(SDKEvent.WaypointMissionActionUploadProgress, progressMap, true); + } + } + + + // TODO (Nick A): this is duplicate code from the DJIMobile class, refactor + private void startProductConnectionListener() { + KeyManager keyManager = DJISDKManager.getInstance().getKeyManager(); + if (keyManager != null) { + DJIKey productConnectedKey = ProductKey.create(ProductKey.CONNECTION); + keyManager.getValue(productConnectedKey, new GetCallback() { + @Override + public void onSuccess(@NonNull Object o) { + if (o instanceof Boolean && (Boolean) o) { + Boolean isProductConnected = (Boolean) o; + if (isProductConnected) { + startListenersOnProductConnection(); + } + } + } + + @Override + public void onFailure(@NonNull DJIError djiError) { + } + }); + } + DJISDKManager.getInstance().getKeyManager().addListener((DJIKey) SDKEvent.ProductConnection.getKey(), new KeyListener() { + @Override + public void onValueChange(@Nullable Object oldValue, @Nullable Object newValue) { + if (newValue != null && newValue instanceof Boolean) { + Boolean isProductConnected = (Boolean) newValue; + if (isProductConnected) { + startListenersOnProductConnection(); + } + } + } + }); + } + + @Nonnull + @Override + public String getName() { + return "WaypointMissionV2Wrapper"; + } + + private static class MissionOperatorNullException extends Exception { + public MissionOperatorNullException(String message) { + super(message); + } + } +} + + + diff --git a/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointV2ActionFactory.java b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointV2ActionFactory.java new file mode 100644 index 00000000..03692c77 --- /dev/null +++ b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointV2ActionFactory.java @@ -0,0 +1,69 @@ +package com.aerobotics.DjiMobile.WaypointMissionV2; + +import java.util.ArrayList; +import java.util.List; + +import dji.common.mission.waypointv2.Action.CameraFocusMode; +import dji.common.mission.waypointv2.Action.WaypointActuator; +import dji.common.mission.waypointv2.Action.WaypointTrigger; +import dji.common.mission.waypointv2.Action.WaypointV2Action; + +public class WaypointV2ActionFactory { + public static WaypointV2Action getAction(WaypointTrigger trigger, int actionId, WaypointActuator actuator) { + //noinspection ConstantConditions + return new WaypointV2Action.Builder() + .setTrigger(trigger) + .setActionID(actionId) + .setActuator(actuator) + .build(); + } + + public static WaypointV2Action getStopFlyAction(int pointIndex, int actionId) { + return getAction(WaypointV2ActionUtils.getSimpleReachPointTrigger(pointIndex), actionId, WaypointV2ActionUtils.getStayActuator()); + } + + public static WaypointV2Action getSerialAction(int preActionId, int actionId, WaypointActuator actuator) { + return getAction(WaypointV2ActionUtils.getSerialTrigger(preActionId), actionId, actuator); + } + + public static WaypointV2Action getSerialDelayAction(int preActionId, int actionId, float delayTime, WaypointActuator actuator) { + return getAction(WaypointV2ActionUtils.getSerialWaitTrigger(preActionId, delayTime), actionId, actuator); + } + + /** + * Manually focus the camera when a waypoint index is reached. + * + * @param waypointIndex waypoint index to perform the action + * @param actionId an action ID + * @param gimbalPitch pitch adjustment of the gimbal after the focus is complete + * @return A list of actions which represent the manual focus action + */ + public static List getActiveFocusAction(int waypointIndex, int actionId, float gimbalPitch) { + final List actions = new ArrayList<>(); + int id = 100 * actionId; + actions.add(getStopFlyAction(waypointIndex, id)); + actions.add(getSerialAction(id, ++id, WaypointV2ActionUtils.getGimbalActuator(-90, 0))); + actions.add(getSerialDelayAction(id, ++id, 1f, WaypointV2ActionUtils.getCameraFocusModeActuator(CameraFocusMode.AUTO, 0))); + actions.add(getSerialDelayAction(id, ++id, 0.5f, WaypointV2ActionUtils.getCameraRectFocusActuator(0))); + actions.add(getSerialDelayAction(id, ++id, 1f, WaypointV2ActionUtils.getCameraFocusModeActuator(CameraFocusMode.MANUAL, 0))); + actions.add(getSerialAction(id, ++id, WaypointV2ActionUtils.getGimbalActuator(gimbalPitch, 0))); + actions.add(getSerialDelayAction(id, ++id, 2f, WaypointV2ActionUtils.getStayStartActuator())); + return actions; + } + + /** + * Capture single images at a distance interval + * + * @param waypointIndex the waypoint index at which to start the action + * @param actionId an action ID + * @param distanceM the interval distance to capture images + * @return A list of actions which represent the interval shoot photo action + */ + public static List getCameraShootPhotoIntervalAction(int waypointIndex, int actionId, float distanceM) { + int id = 100 * actionId; + final List actions = new ArrayList<>(); + actions.add(getAction(WaypointV2ActionUtils.getSimpleReachPointTrigger(waypointIndex), id++, WaypointV2ActionUtils.getGimbalActuator(-90, 0))); + actions.add(getAction(WaypointV2ActionUtils.getDistanceIntervalTrigger(waypointIndex, distanceM), id, WaypointV2ActionUtils.getCameraShootPhotoActuator(0))); + return actions; + } +} diff --git a/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointV2ActionUtils.java b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointV2ActionUtils.java new file mode 100644 index 00000000..2cb2e6d6 --- /dev/null +++ b/android/src/main/java/com/aerobotics/DjiMobile/WaypointMissionV2/WaypointV2ActionUtils.java @@ -0,0 +1,216 @@ +package com.aerobotics.DjiMobile.WaypointMissionV2; + +import android.graphics.PointF; + +import java.util.ArrayList; +import java.util.List; + +import dji.common.gimbal.Rotation; +import dji.common.gimbal.RotationMode; +import dji.common.mission.waypointv2.Action.ActionTypes; +import dji.common.mission.waypointv2.Action.CameraFocusMode; +import dji.common.mission.waypointv2.Action.CameraFocusRegionType; +import dji.common.mission.waypointv2.Action.WaypointActuator; +import dji.common.mission.waypointv2.Action.WaypointAircraftControlParam; +import dji.common.mission.waypointv2.Action.WaypointAircraftControlStartStopFlyParam; +import dji.common.mission.waypointv2.Action.WaypointCameraActuatorParam; +import dji.common.mission.waypointv2.Action.WaypointCameraFocusModeParam; +import dji.common.mission.waypointv2.Action.WaypointCameraFocusParam; +import dji.common.mission.waypointv2.Action.WaypointCameraFocusRectangleTargetParam; +import dji.common.mission.waypointv2.Action.WaypointGimbalActuatorParam; +import dji.common.mission.waypointv2.Action.WaypointGimbalPathPointInfo; +import dji.common.mission.waypointv2.Action.WaypointGimbalPathShooting; +import dji.common.mission.waypointv2.Action.WaypointGimbalStartPathShootingParam; +import dji.common.mission.waypointv2.Action.WaypointGimbalStopPathShootingParam; +import dji.common.mission.waypointv2.Action.WaypointIntervalTriggerParam; +import dji.common.mission.waypointv2.Action.WaypointReachPointTriggerParam; +import dji.common.mission.waypointv2.Action.WaypointTrajectoryTriggerParam; +import dji.common.mission.waypointv2.Action.WaypointTrigger; +import dji.common.mission.waypointv2.Action.WaypointV2AssociateTriggerParam; + +@SuppressWarnings({"ConstantConditions", "unused"}) +public class WaypointV2ActionUtils { + + public static WaypointTrigger getSimpleReachPointTrigger(int index) { + return new WaypointTrigger.Builder() + .setTriggerType(ActionTypes.ActionTriggerType.REACH_POINT) + .setReachPointParam(new WaypointReachPointTriggerParam.Builder() + .setStartIndex(index) + .build()) + .build(); + } + + public static WaypointTrigger getTrajectoryTrigger(int startIndex, int endIndex) { + return new WaypointTrigger.Builder() + .setTriggerType(ActionTypes.ActionTriggerType.TRAJECTORY) + .setTrajectoryParam(new WaypointTrajectoryTriggerParam.Builder() + .setStartIndex(startIndex) + .setEndIndex(endIndex) + .build()) + .build(); + + } + + public static WaypointTrigger getTimeIntervalTrigger(int pointIndex, float time) { + return new WaypointTrigger.Builder() + .setTriggerType(ActionTypes.ActionTriggerType.SIMPLE_INTERVAL) + .setIntervalTriggerParam(new WaypointIntervalTriggerParam.Builder() + .setStartIndex(pointIndex) + .setType(ActionTypes.ActionIntervalType.TIME) + .setInterval(time) + .build() + ) + .build(); + } + + public static WaypointTrigger getDistanceIntervalTrigger(int pointIndex, float distanceM) { + return new WaypointTrigger.Builder() + .setTriggerType(ActionTypes.ActionTriggerType.SIMPLE_INTERVAL) + .setIntervalTriggerParam(new WaypointIntervalTriggerParam.Builder() + .setStartIndex(pointIndex) + .setType(ActionTypes.ActionIntervalType.DISTANCE) + .setInterval(distanceM) + .build() + ) + .build(); + } + + public static WaypointTrigger getSerialTrigger(int actionIndex) { + return new WaypointTrigger.Builder() + .setTriggerType(ActionTypes.ActionTriggerType.ASSOCIATE) + .setAssociateParam(new WaypointV2AssociateTriggerParam.Builder() + .setAssociateActionID(actionIndex) + .setAssociateType(ActionTypes.AssociatedTimingType.AFTER_FINISHED) + .build()) + .build(); + } + + public static WaypointTrigger getSerialWaitTrigger(int actionIndex, float waitTime) { + return new WaypointTrigger.Builder() + .setTriggerType(ActionTypes.ActionTriggerType.ASSOCIATE) + .setAssociateParam(new WaypointV2AssociateTriggerParam.Builder() + .setAssociateActionID(actionIndex) + .setAssociateType(ActionTypes.AssociatedTimingType.AFTER_FINISHED) + .setWaitingTime(waitTime) + .build()) + .build(); + } + + public static WaypointActuator getStayActuator() { + return new WaypointActuator.Builder() + .setActuatorType(ActionTypes.ActionActuatorType.AIRCRAFT_CONTROL) + .setAircraftControlActuatorParam(new WaypointAircraftControlParam.Builder() + .setAircraftControlType(ActionTypes.AircraftControlType.START_STOP_FLY) + .setFlyControlParam(new WaypointAircraftControlStartStopFlyParam.Builder().setStartFly(false).build()) + .build()) + .build(); + } + + public static WaypointActuator getStayStartActuator() { + return new WaypointActuator.Builder() + .setActuatorType(ActionTypes.ActionActuatorType.AIRCRAFT_CONTROL) + .setAircraftControlActuatorParam(new WaypointAircraftControlParam.Builder() + .setAircraftControlType(ActionTypes.AircraftControlType.START_STOP_FLY) + .setFlyControlParam(new WaypointAircraftControlStartStopFlyParam.Builder().setStartFly(true).build()) + .build()) + .build(); + } + + public static WaypointActuator getGimbalActuator(float pitch, int gimbalIndex) { + Rotation rotation = new Rotation.Builder() + .pitch(pitch) + .roll(0f) + .yaw(0f) + .time(2) + .mode(RotationMode.RELATIVE_ANGLE) + .build(); + return new WaypointActuator.Builder() + .setActuatorType(ActionTypes.ActionActuatorType.GIMBAL) + .setActuatorIndex(gimbalIndex) + .setGimbalActuatorParam(new WaypointGimbalActuatorParam.Builder() + .rotation(rotation) + .operationType(ActionTypes.GimbalOperationType.ROTATE_GIMBAL) + .build() + ) + .build(); + } + + public static WaypointActuator getCameraFocusModeActuator(CameraFocusMode mode, int cameraIndex) { + return new WaypointActuator.Builder() + .setActuatorType(ActionTypes.ActionActuatorType.CAMERA) + .setActuatorIndex(cameraIndex) + .setCameraActuatorParam(new WaypointCameraActuatorParam.Builder() + .setCameraOperationType(ActionTypes.CameraOperationType.FOCUS_MODE) + .setFocusModeParam(WaypointCameraFocusModeParam.Builder.newBuilder().cameraFocusMode(mode).build()) + .build()) + .build(); + } + + public static WaypointActuator getCameraRectFocusActuator(int cameraIndex) { + return new WaypointActuator.Builder() + .setActuatorType(ActionTypes.ActionActuatorType.CAMERA) + .setActuatorIndex(cameraIndex) + .setCameraActuatorParam(new WaypointCameraActuatorParam.Builder() + .setCameraOperationType(ActionTypes.CameraOperationType.FOCUS) + .setFocusParam(new WaypointCameraFocusParam.Builder() + .setCameraFocusRegionType(CameraFocusRegionType.RECTANGLE) + .waypointCameraFocusRectangleTargetParam(new WaypointCameraFocusRectangleTargetParam.Builder() + .referencePoint(new PointF(0.25f, 0.25f)) + .width(0.5f) + .height(0.5f) + .build()) + .build()) + .build()) + .build(); + } + + public static WaypointActuator getCameraShootPhotoActuator(int cameraIndex) { + return new WaypointActuator.Builder() + .setActuatorType(ActionTypes.ActionActuatorType.CAMERA) + .setActuatorIndex(cameraIndex) + .setCameraActuatorParam(new WaypointCameraActuatorParam.Builder() + .setCameraOperationType(ActionTypes.CameraOperationType.SHOOT_SINGLE_PHOTO) + .build()) + .build(); + } + + public static WaypointActuator getStartPathShootingActuator(int cameraIndex, int gimbalPitch, ActionTypes.GimbalPathCycleMode cycleMode) { + List pointInfo = new ArrayList<>(); + pointInfo.add(new WaypointGimbalPathPointInfo.Builder().stayTime(0).eulerPitch(gimbalPitch).build()); + pointInfo.add(new WaypointGimbalPathPointInfo.Builder().stayTime(0).eulerPitch(-90).eulerRoll(90 + gimbalPitch).build()); + pointInfo.add(new WaypointGimbalPathPointInfo.Builder().stayTime(0).eulerPitch(-180 - gimbalPitch).build()); + pointInfo.add(new WaypointGimbalPathPointInfo.Builder().stayTime(0).eulerPitch(-90).eulerRoll(-(90 + gimbalPitch)).build()); + pointInfo.add(new WaypointGimbalPathPointInfo.Builder().stayTime(0).eulerPitch(-90).build()); + return new WaypointActuator.Builder() + .setActuatorType(ActionTypes.ActionActuatorType.GIMBAL) + .setActuatorIndex(cameraIndex) + .setGimbalActuatorParam(new WaypointGimbalActuatorParam.Builder() + .operationType(ActionTypes.GimbalOperationType.PATH_SHOOTING) + .pathShooting(new WaypointGimbalPathShooting.Builder().startPathShooting( + new WaypointGimbalStartPathShootingParam.Builder() + .pathCycleMode(cycleMode) + .pointNum(pointInfo.size()) + .pointInfo(pointInfo) + .build()) + .pathShootingType(ActionTypes.GimbalPathShootingType.START_PATH_SHOOTING) + .build()) + .build()) + .build(); + } + + public static WaypointActuator getStopPathShootingActuator(int cameraIndex, ActionTypes.GimbalPathCycleMode cycleMode) { + + return new WaypointActuator.Builder() + .setActuatorType(ActionTypes.ActionActuatorType.GIMBAL) + .setActuatorIndex(cameraIndex) + .setGimbalActuatorParam(new WaypointGimbalActuatorParam.Builder() + .operationType(ActionTypes.GimbalOperationType.PATH_SHOOTING) + .pathShooting(new WaypointGimbalPathShooting.Builder().stopPathShooting( + new WaypointGimbalStopPathShootingParam.Builder() + .pathCycleMode(cycleMode) + .build()) + .pathShootingType(ActionTypes.GimbalPathShootingType.STOP_PATH_SHOOTING) + .build() + ).build()).build(); + } +} diff --git a/index.js b/index.js deleted file mode 100644 index bfd066d6..00000000 --- a/index.js +++ /dev/null @@ -1,284 +0,0 @@ -// @flow strict - -import { - Platform, - NativeModules, - PermissionsAndroid, -} from 'react-native'; - -import { - filter as $filter, - map as $map, -} from 'rxjs/operators'; - -import DJIMissionControl from './lib/DJIMissionControl'; - -import CameraControl, { exposureCompensationValues } from './lib/CameraControl'; - -import DJIMediaControl from './lib/DJIMedia'; - -import DJIFlightController from './lib/DJIFlightController'; - -import DJIGimbal from './lib/DJIGimbal'; - -import { - DJIEventSubject, -} from './lib/utilities'; - -const startListener = (eventName: string) => async () => { - await DJIMobile.startEventListener(eventName); - return DJIEventSubject.pipe($filter(evt => evt.type === eventName)).asObservable(); -}; - -const stopListener = (eventName: string) => async () => { - await DJIMobile.stopEventListener(eventName); -}; - -const { - DJIMobile, -} = NativeModules; - -let SDKRegistered = false; - -const throwIfSDKNotRegistered = () => { - if (SDKRegistered === false) { - throw new Error('DJI SDK not registered!'); - } -}; - -export const FlightLogListenerEventNames = Object.freeze({ - create: 'create', - modify: 'modify', -}); - -export type FlightLogListenerEvent = { - value: { - eventName: $Values, - fileName: string, - }, - type: string, -} - -export type MediaFileData = { - fileName: string, - fileSizeInBytes: number, - dateCreated: string, -}; - -const DJIMobileWrapper = { - - registerApp: async (bridgeIp?: string) => { - - if (Platform.OS === 'android') { - const granted = await PermissionsAndroid.request( - PermissionsAndroid.PERMISSIONS.READ_PHONE_STATE, - // { - // title: 'Permission Required', - // message: 'The phone permission is required to allow the DJI drone functionality to work', - // buttonPositive: 'Ok', - // } - ); - if (granted !== PermissionsAndroid.RESULTS.GRANTED) { - throw new Error('Missing READ_PHONE_STATE permission'); - } - } - - let registerSDKPromise; - if (bridgeIp !== undefined) { - registerSDKPromise = DJIMobile.registerAppAndUseBridge(bridgeIp); - } else { - registerSDKPromise = DJIMobile.registerApp(); - } - registerSDKPromise.then(() => { - SDKRegistered = true; - }).catch(err => { - SDKRegistered = false; - }); - return registerSDKPromise; - }, - - limitEventFrequency: async (frequency: number) => { - if (frequency < 0 || frequency > 10) { - throw Error('Please ensure frequency is in the range (0, 10]'); - } else { - await DJIMobile.limitEventFrequency(frequency); - } - }, - - // TODO: (Adam) What should happen if these functions are called and the SDK is not registered? - - startProductConnectionListener: startListener(DJIMobile.ProductConnection), - stopProductConnectionListener: stopListener(DJIMobile.ProductConnection), - - startBatteryPercentChargeRemainingListener: startListener(DJIMobile.BatteryChargeRemaining), - stopBatteryPercentChargeRemainingListener: stopListener(DJIMobile.BatteryChargeRemaining), - - startAircraftLocationListener: startListener(DJIMobile.AircraftLocation), - stopAircraftLocationListener: stopListener(DJIMobile.AircraftLocation), - - startAircraftVelocityListener: startListener(DJIMobile.AircraftVelocity), - stopAircraftVelocityListener: stopListener(DJIMobile.AircraftVelocity), - - startAircraftAttitudeListener: startListener(DJIMobile.AircraftAttitude), - stopAircraftAttitudeListener: stopListener(DJIMobile.AircraftAttitude), - - startAircraftCompassHeadingListener: startListener(DJIMobile.AircraftCompassHeading), - stopAircraftCompassHeadingListener: stopListener(DJIMobile.AircraftCompassHeading), - - startAirLinkUplinkSignalQualityListener: startListener(DJIMobile.AirLinkUplinkSignalQuality), - stopAirLinkUplinkSignalQualityListener: stopListener(DJIMobile.AirLinkUplinkSignalQuality), - - startAirLinkDownlinkSignalQualityListener: startListener(DJIMobile.AirLinkDownlinkSignalQuality), - stopAirLinkDownlinkSignalQualityListener: stopListener(DJIMobile.AirLinkDownlinkSignalQuality), - - startHomeLocationListener: startListener(DJIMobile.AircraftHomeLocation), - stopHomeLocationListener: stopListener(DJIMobile.AircraftHomeLocation), - - startGpsSignalLevelListener: startListener(DJIMobile.AircraftGpsSignalLevel), - stopGpsSignalLevelListener: stopListener(DJIMobile.AircraftGpsSignalLevel), - - startUltrasonicHeightListener: startListener(DJIMobile.AircraftUltrasonicHeight), - stopUltrasonicHeightListener: stopListener(DJIMobile.AircraftUltrasonicHeight), - - startCompassHasErrorListener: startListener(DJIMobile.CompassHasError), - stopCompassHasErrorListener: stopListener(DJIMobile.CompassHasError), - - startCameraIsRecordingListener: startListener(DJIMobile.CameraIsRecording), - stopCameraIsRecordingListener: stopListener(DJIMobile.CameraIsRecording), - - startSDCardIsInsertedListener: startListener(DJIMobile.SDCardIsInserted), - stopSDCardIsInsertedListener: stopListener(DJIMobile.SDCardIsInserted), - - startSDCardIsReadOnlyListener: startListener(DJIMobile.SDCardIsReadOnly), - stopSDCardIsReadOnlyListener: stopListener(DJIMobile.SDCardIsReadOnly), - - startGimbalIsAtYawStopListener: startListener(DJIMobile.GimbalIsAtYawStop), - stopGimbalIsAtYawStopListener: stopListener(DJIMobile.GimbalIsAtYawStop), - - startAircraftVirtualStickEnabledListener: startListener(DJIMobile.AircraftVirtualStickEnabled), - stopAircraftVirtualStickEnabledListener: stopListener(DJIMobile.AircraftVirtualStickEnabled), - - startVisionDetectionStateListener: startListener(DJIMobile.VisionDetectionState), - stopVisionDetectionStateListener: stopListener(DJIMobile.VisionDetectionState), - - startVisionControlStateListener: startListener(DJIMobile.VisionControlState), - stopVisionControlStateListener: stopListener(DJIMobile.VisionControlState), - - startDiagnosticsListener: async () => { - return DJIEventSubject.pipe($filter(evt => evt.type === 'DJIDiagnostics')).asObservable(); - }, - - stopDiagnosticsListener: async () => { - await DJIMobile.stopEventListener('DJIDiagnostics'); - }, - - startCameraExposureSettingsListener: async () => { - await DJIMobile.startCameraExposureSettingsListener(); - return DJIEventSubject.pipe( - $filter(evt => evt.type === 'CameraExposureSettings'), - $map(evt => { - // Get exposure value from lookup. The possible values should only be - // string representations of floats. - evt.value = { - ...evt.value, - exposureValue: parseFloat(Object.keys(exposureCompensationValues).find(key => exposureCompensationValues[key] === evt.value.exposureValue)), - } - return evt; - }), - ).asObservable(); - }, - - stopCameraExposureSettingsListener: async () => { - await DJIMobile.stopEventListener('CameraExposureSettings'); - }, - - getAircraftLocation: async () => { - return await DJIMobile.getAircraftLocation(); - }, - - startNewMediaFileListener: async () => { - await DJIMobile.startNewMediaFileListener(); - return DJIEventSubject.pipe($filter(evt => evt.type === 'CameraDidGenerateNewMediaFile')).asObservable(); - }, - stopNewMediaFileListener: async () => { - // TODO: (Adam) generalize & merge these! - if (Platform.OS === 'ios') { - await DJIMobile.stopNotificationCenterListener('DJICameraEvent.didGenerateNewMediaFile'); - } else { - await DJIMobile.stopEventListener('CameraDidGenerateNewMediaFile'); - } - }, - /** - * ANDROID ONLY - */ - getMediaFileList: async (numberOfResults: ?number) => { - if (numberOfResults != null ) { - return await DJIMobile.getLimitedMediaFileList(numberOfResults) - } else { - return await DJIMobile.getMediaFileList(); - } - }, - - getFlightLogPath: async () => { - return await DJIMobile.getFlightLogPath(); - }, - - startFlightLogListener: async () => { - await DJIMobile.startFlightLogListener(); - return DJIEventSubject.pipe($filter((evt: FlightLogListenerEvent) => evt.type === 'DJIFlightLogEvent')).asObservable(); - }, - - stopFlightLogListener: async () => { - await DJIMobile.stopFlightLogListener(); - }, - - /** - * ANDROID ONLY - */ - getAircraftIsFlying: async () => { - return await DJIMobile.getAircraftIsFlying(); - }, - - setCollisionAvoidanceEnabled: async (enabled: boolean) => { - return await DJIMobile.setCollisionAvoidanceEnabled(enabled); - }, - - getCollisionAvoidanceEnabled: async () => { - return await DJIMobile.getCollisionAvoidanceEnabled(); - }, - - setVirtualStickAdvancedModeEnabled: async (enabled: boolean) => { - return await DJIMobile.setVirtualStickAdvancedModeEnabled(enabled); - }, - - setVisionAssistedPositioningEnabled: async (enabled: boolean) => { - return await DJIMobile.setVisionAssistedPositioningEnabled(enabled); - }, - - setLandingProtectionEnabled: async (enabled: boolean) => { - return await DJIMobile.setLandingProtectionEnabled(enabled); - }, - - isProductConnected: async () => { - return await DJIMobile.isProductConnected(); - }, - - getAircraftCompassHeading: async () => { - return await DJIMobile.getAircraftCompassHeading(); - }, - - getModelName: async () => { - return await DJIMobile.getModelName(); - }, - -}; - -export default DJIMobileWrapper; - -export { - DJIMissionControl, - CameraControl, - DJIMediaControl, - DJIFlightController, - DJIGimbal, -}; diff --git a/index.ts b/index.ts new file mode 100644 index 00000000..c8681caa --- /dev/null +++ b/index.ts @@ -0,0 +1,490 @@ +import { Platform, NativeModules, PermissionsAndroid } from 'react-native'; + +import { + filter as $filter, + map as $map, + distinctUntilChanged, +} from 'rxjs/operators'; + +import DJIMissionControl from './lib/DJIMissionControl'; + +import CameraControl, { + photoAspectRatioLookup, + readableExposureModes, +} from './lib/CameraControl'; + +import DJIMediaControl from './lib/DJIMedia'; + +import DJIFlightController from './lib/DJIFlightController'; + +import DJIGimbal from './lib/DJIGimbal'; + +import { DJIEventSubject, observeEvent } from './lib/utilities'; +import { parseExposureSettings } from './lib/utilities/parseExposureSettings'; +import { + Attitude, + LocationCoordinate3D, + VelocityVector, + HomeLocationCoordinate3D, + FlightLogListenerEvent, + MediaFileData, + DJIDiagnostic, + IMUState, + WhiteBalancePresets, + CameraExposureSettings, + RemoteControllerFlightMode, + AircraftFlightMode, + ModelName, +} from './types'; +import { + PhotoFileFormat, + PhotoAspectRatio, + DjiExposureModes, + DjiPhotoAspectRatio, +} from './lib/CameraControl/types'; + +const startListener = + (eventName: string) => + async () => { + await DJIMobile.startEventListener(eventName); + return observeEvent(eventName); + }; + +const stopListener = (eventName: string) => async () => { + await DJIMobile.stopEventListener(eventName); +}; + +const { DJIMobile } = NativeModules; + +let SDKRegistered = false; + +const throwIfSDKNotRegistered = () => { + if (SDKRegistered === false) { + throw new Error('DJI SDK not registered!'); + } +}; + +const DJIMobileWrapper = { + registerApp: async (bridgeIp?: string) => { + if (Platform.OS === 'android') { + const granted = await PermissionsAndroid.request( + PermissionsAndroid.PERMISSIONS.READ_PHONE_STATE, + // { + // title: 'Permission Required', + // message: 'The phone permission is required to allow the DJI drone functionality to work', + // buttonPositive: 'Ok', + // } + ); + if (granted !== PermissionsAndroid.RESULTS.GRANTED) { + throw new Error('Missing READ_PHONE_STATE permission'); + } + } + + let registerSDKPromise; + if (bridgeIp !== undefined) { + registerSDKPromise = DJIMobile.registerAppAndUseBridge(bridgeIp); + } else { + registerSDKPromise = DJIMobile.registerApp(); + } + registerSDKPromise + .then(() => { + SDKRegistered = true; + }) + .catch(err => { + SDKRegistered = false; + }); + return registerSDKPromise; + }, + + limitEventFrequency: async (frequency: number) => { + if (frequency < 0 || frequency > 10) { + throw Error('Please ensure frequency is in the range (0, 10]'); + } else { + await DJIMobile.limitEventFrequency(frequency); + } + }, + + // TODO: (Adam) What should happen if these functions are called and the SDK is not registered? + + startProductConnectionListener: startListener( + DJIMobile.ProductConnection, + ), + stopProductConnectionListener: stopListener(DJIMobile.ProductConnection), + observeProductionConnection: observeEvent( + DJIMobile.ProductConnection, + ), + + startCameraConnectionListener: startListener( + DJIMobile.CameraConnection, + ), + stopCameraConnectionListener: stopListener(DJIMobile.CameraConnection), + observeCameraConnection: observeEvent(DJIMobile.CameraConnection), + + startBatteryPercentChargeRemainingListener: startListener( + DJIMobile.BatteryChargeRemaining, + ), + stopBatteryPercentChargeRemainingListener: stopListener( + DJIMobile.BatteryChargeRemaining, + ), + observeBatteryPercentChargeRemaining: observeEvent( + DJIMobile.BatteryChargeRemaining, + ), + + startAircraftLocationListener: startListener( + DJIMobile.AircraftLocation, + ), + stopAircraftLocationListener: stopListener(DJIMobile.AircraftLocation), + observeAircraftLocation: observeEvent( + DJIMobile.AircraftLocation, + ), + + startAircraftVelocityListener: startListener( + DJIMobile.AircraftVelocity, + ), + stopAircraftVelocityListener: stopListener(DJIMobile.AircraftVelocity), + observeAircraftVelocity: observeEvent( + DJIMobile.AircraftVelocity, + ), + + startAircraftAttitudeListener: startListener( + DJIMobile.AircraftAttitude, + ), + stopAircraftAttitudeListener: stopListener(DJIMobile.AircraftAttitude), + observeAircraftAttitude: observeEvent(DJIMobile.AircraftAttitude), + + startAircraftCompassHeadingListener: startListener( + DJIMobile.AircraftCompassHeading, + ), + stopAircraftCompassHeadingListener: stopListener( + DJIMobile.AircraftCompassHeading, + ), + observeAircraftCompassHeading: observeEvent( + DJIMobile.AircraftCompassHeading, + ), + + startAirLinkUplinkSignalQualityListener: startListener( + DJIMobile.AirLinkUplinkSignalQuality, + ), + stopAirLinkUplinkSignalQualityListener: stopListener( + DJIMobile.AirLinkUplinkSignalQuality, + ), + observeAirlinkUplinkSignalQuality: observeEvent( + DJIMobile.AirLinkUplinkSignalQuality, + ), + + startAirLinkDownlinkSignalQualityListener: startListener( + DJIMobile.AirLinkDownlinkSignalQuality, + ), + stopAirLinkDownlinkSignalQualityListener: stopListener( + DJIMobile.AirLinkDownlinkSignalQuality, + ), + observeAirlinkDownlinkSignalQuality: observeEvent( + DJIMobile.AirLinkDownlinkSignalQuality, + ), + + startHomeLocationListener: startListener( + DJIMobile.AircraftHomeLocation, + ), + stopHomeLocationListener: stopListener(DJIMobile.AircraftHomeLocation), + observeHomeLocation: observeEvent( + DJIMobile.AircraftHomeLocation, + ), + + startIsHomeLocationSetListener: startListener( + DJIMobile.IsHomeLocationSet, + ), + stopIsHomeLocationSetListener: stopListener(DJIMobile.IsHomeLocationSet), + observeIsHomeLocationSet: observeEvent(DJIMobile.IsHomeLocationSet), + + startGpsSignalLevelListener: startListener( + DJIMobile.AircraftGpsSignalLevel, + ), + stopGpsSignalLevelListener: stopListener(DJIMobile.AircraftGpsSignalLevel), + observeGpsSignalLevel: observeEvent( + DJIMobile.AircraftGpsSignalLevel, + ), + + startSatelliteCountListener: startListener( + DJIMobile.SatelliteCount, + ), + stopSatelliteCountListener: stopListener(DJIMobile.SatelliteCount), + observeSatelliteCount: observeEvent(DJIMobile.SatelliteCount), + + startUltrasonicHeightListener: startListener( + DJIMobile.AircraftUltrasonicHeight, + ), + stopUltrasonicHeightListener: stopListener( + DJIMobile.AircraftUltrasonicHeight, + ), + + startCompassHasErrorListener: startListener( + DJIMobile.CompassHasError, + ), + stopCompassHasErrorListener: stopListener(DJIMobile.CompassHasError), + observeCompassHasError: observeEvent(DJIMobile.CompassHasError), + + startCameraIsRecordingListener: startListener(DJIMobile.CameraIsRecording), + stopCameraIsRecordingListener: stopListener(DJIMobile.CameraIsRecording), + + startSDCardIsInsertedListener: startListener(DJIMobile.SDCardIsInserted), + stopSDCardIsInsertedListener: stopListener(DJIMobile.SDCardIsInserted), + + startSDCardIsReadOnlyListener: startListener(DJIMobile.SDCardIsReadOnly), + stopSDCardIsReadOnlyListener: stopListener(DJIMobile.SDCardIsReadOnly), + + startSDCardAvailableCaptureCountListener: startListener( + DJIMobile.SDCardAvailableCaptureCount, + ), + stopSDCardAvailableCaptureCountListener: stopListener( + DJIMobile.SDCardAvailableCaptureCount, + ), + observeSDCardAvailableCaptureCount: observeEvent( + DJIMobile.SDCardAvailableCaptureCount, + ), + + startCameraWhiteBalanceListener: startListener( + DJIMobile.CameraWhiteBalance, + ), + stopCameraWhiteBalanceListener: stopListener(DJIMobile.CameraWhiteBalance), + observeCameraWhiteBalance: observeEvent( + DJIMobile.CameraWhiteBalance, + ), + + startPhotoFileFormatListener: startListener( + DJIMobile.CameraPhotoFileFormat, + ), + stopPhotoFileFormatListener: stopListener(DJIMobile.CameraPhotoFileFormat), + observePhotoFileFormat: observeEvent( + DJIMobile.CameraPhotoFileFormat, + ), + + // FIXME: this start listener function will actually return a DjiPhotoAspectRatio + startPhotoAspectRatioListener: startListener( + DJIMobile.CameraPhotoAspectRatio, + ), + stopPhotoAspectRatioListener: stopListener(DJIMobile.CameraPhotoAspectRatio), + observePhotoAspectRatio: observeEvent( + DJIMobile.CameraPhotoAspectRatio, + ).pipe($map(ratio => photoAspectRatioLookup[ratio])), + + startCameraExposureModeListener: startListener( + DJIMobile.CameraExposureMode, + ), + stopCameraExposureModeListener: stopListener(DJIMobile.CameraExposureMode), + observeCameraExposureMode: observeEvent( + DJIMobile.CameraExposureMode, + ), + + startGimbalIsAtYawStopListener: startListener(DJIMobile.GimbalIsAtYawStop), + stopGimbalIsAtYawStopListener: stopListener(DJIMobile.GimbalIsAtYawStop), + + startAircraftVirtualStickEnabledListener: startListener( + DJIMobile.AircraftVirtualStickEnabled, + ), + stopAircraftVirtualStickEnabledListener: stopListener( + DJIMobile.AircraftVirtualStickEnabled, + ), + + startVisionDetectionStateListener: startListener( + DJIMobile.VisionDetectionState, + ), + stopVisionDetectionStateListener: stopListener( + DJIMobile.VisionDetectionState, + ), + + startVisionControlStateListener: startListener(DJIMobile.VisionControlState), + stopVisionControlStateListener: stopListener(DJIMobile.VisionControlState), + + startIsShootingSinglePhotoListener: startListener( + DJIMobile.CameraIsShootingSinglePhoto, + ), + stopIsShootingSinglePhotoListener: stopListener( + DJIMobile.CameraIsShootingSinglePhoto, + ), + observeIsShootingSinglePhotoListener: observeEvent( + DJIMobile.CameraIsShootingSinglePhoto, + ), + + startIsStoringPhotoListener: startListener( + DJIMobile.CameraIsStoringPhoto, + ), + stopIsStoringPhotoListener: stopListener(DJIMobile.CameraIsStoringPhoto), + observeIsStoringPhotoListener: observeEvent( + DJIMobile.CameraIsStoringPhoto, + ), + + startIsShootingPhotoListener: startListener( + DJIMobile.CameraIsShootingPhoto, + ), + stopIsShootingPhotoListener: stopListener(DJIMobile.CameraIsShootingPhoto), + observeIsShootingPhotoListener: observeEvent( + DJIMobile.CameraIsShootingPhoto, + ), + + startRemoteControllerFlightModeListener: + startListener( + DJIMobile.RemoteControllerFlightMode, + ), + stopRemoteControllerFlightModeListener: stopListener( + DJIMobile.RemoteControllerFlightMode, + ), + observeRemoteControllerFlightMode: observeEvent( + DJIMobile.RemoteControllerFlightMode, + ), + + startAircraftFlightModeListener: startListener( + DJIMobile.AircraftFlightMode, + ), + stopAircraftFlightModeListener: stopListener(DJIMobile.AircraftFlightMode), + observeAircraftFlightMode: observeEvent( + DJIMobile.AircraftFlightMode, + ), + + startAircraftIsFlyingListener: startListener( + DJIMobile.AircraftIsFlying, + ), + stopAircraftIsFlyingListener: stopListener(DJIMobile.AircraftIsFlying), + observeAircraftIsFlying: observeEvent(DJIMobile.AircraftIsFlying), + + startDiagnosticsListener: async () => { + await DJIMobile.resetPreviousDiagnostics(); + return observeEvent('DJIDiagnostics'); + }, + stopDiagnosticsListener: async () => { + await DJIMobile.stopEventListener('DJIDiagnostics'); + }, + observeDiagnostics: observeEvent('DJIDiagnostics'), + + startCameraExposureSettingsListener: async () => { + await DJIMobile.startCameraExposureSettingsListener(); + return observeEvent( + DJIMobile.CameraExposureSettings, + ).pipe($map(value => parseExposureSettings(value))); + }, + observeCameraExposureSettings: observeEvent( + DJIMobile.CameraExposureSettings, + ).pipe($map(value => parseExposureSettings(value))), + + stopCameraExposureSettingsListener: async () => { + await DJIMobile.stopEventListener('CameraExposureSettings'); + }, + + getAircraftLocation: async () => { + return await DJIMobile.getAircraftLocation(); + }, + + startNewMediaFileListener: async () => { + await DJIMobile.startNewMediaFileListener(); + return observeEvent('CameraDidGenerateNewMediaFile'); + }, + observeNewMediaFile: observeEvent( + 'CameraDidGenerateNewMediaFile', + ), + // TODO: this is working, but hasn't been tested thoroughly or properly typed + observeCameraState: observeEvent('CameraDidUpdateSystemState'), + + stopNewMediaFileListener: async () => { + // TODO: (Adam) generalize & merge these! + if (Platform.OS === 'ios') { + await DJIMobile.stopNotificationCenterListener( + 'DJICameraEvent.didGenerateNewMediaFile', + ); + } else { + await DJIMobile.stopEventListener('CameraDidGenerateNewMediaFile'); + } + }, + + startIMUSensorStateListener: async () => { + await DJIMobile.startIMUSensorStateListener(); + return observeEvent(DJIMobile.IMUSensorState); + }, + observeIMUSensorState: observeEvent(DJIMobile.IMUSensorState).pipe( + distinctUntilChanged( + (prev, curr) => + prev.accelerometerState === curr.accelerometerState && + prev.gyroscopeState === curr.gyroscopeState, + ), + ), + + /** + * ANDROID ONLY + */ + getMediaFileList: async (numberOfResults?: number) => { + if (numberOfResults != null) { + return await DJIMobile.getLimitedMediaFileList(numberOfResults); + } else { + return await DJIMobile.getMediaFileList(); + } + }, + + getFlightLogPath: async () => { + return await DJIMobile.getFlightLogPath(); + }, + + startFlightLogListener: async () => { + await DJIMobile.startFlightLogListener(); + return DJIEventSubject.pipe( + $filter( + (evt: FlightLogListenerEvent) => evt.type === 'DJIFlightLogEvent', + ), + ); + }, + + stopFlightLogListener: async () => { + await DJIMobile.stopFlightLogListener(); + }, + + /** + * ANDROID ONLY + */ + getAircraftIsFlying: async () => { + return await DJIMobile.getAircraftIsFlying(); + }, + + setCollisionAvoidanceEnabled: async (enabled: boolean) => { + return await DJIMobile.setCollisionAvoidanceEnabled(enabled); + }, + + getCollisionAvoidanceEnabled: async () => { + return await DJIMobile.getCollisionAvoidanceEnabled(); + }, + + setVirtualStickAdvancedModeEnabled: async (enabled: boolean) => { + return await DJIMobile.setVirtualStickAdvancedModeEnabled(enabled); + }, + + setVisionAssistedPositioningEnabled: async (enabled: boolean) => { + return await DJIMobile.setVisionAssistedPositioningEnabled(enabled); + }, + + setLandingProtectionEnabled: async (enabled: boolean) => { + return await DJIMobile.setLandingProtectionEnabled(enabled); + }, + + isProductConnected: async () => { + return await DJIMobile.isProductConnected(); + }, + + getAircraftCompassHeading: async () => { + return await DJIMobile.getAircraftCompassHeading(); + }, + + getModelName: async (): Promise => { + return await DJIMobile.getModelName(); + }, +}; + +export default DJIMobileWrapper; + +export { + DJIMissionControl, + CameraControl, + DJIMediaControl, + DJIFlightController, + DJIGimbal, +}; + +export { readableExposureModes }; + +export * from './types'; +export * from './lib/CameraControl/types'; diff --git a/lib/CameraControl/index.js b/lib/CameraControl/index.js deleted file mode 100644 index e667ed4e..00000000 --- a/lib/CameraControl/index.js +++ /dev/null @@ -1,294 +0,0 @@ -// @flow strict - -import { - NativeModules, - Platform, -} from 'react-native'; - -const { - CameraControlNative, -} = NativeModules; - - -type PhotoAspectRatio = '4_3' | '16_9' | '3_2'; - -const photoAspectRatios = Object.freeze({ - '4_3': 'RATIO_4_3', - '16_9': 'RATIO_16_9', - '3_2': 'RATIO_3_2', -}); - -export type WhiteBalanceParameters = { - preset?: 'auto' | 'sunny' | 'cloudy' | 'waterSurface' | 'indoorIncandescent' | 'indoorFluorescent', - colorTemperature?: number, // in range [20, 100] -} - -const whiteBalancePresets = Object.freeze({ - auto: 'AUTO', - sunny: 'SUNNY', - cloudy: 'CLOUDY', - waterSurface: 'WATER_SURFACE', - indoorIncandescent: 'INDOOR_INCANDESCENT', - indoorFluorescent: 'INDOOR_FLUORESCENT', -}); - -type ExposureMode = 'program' | 'shutterPriority' | 'aperturePriority' | 'manual'; - -const exposureModes = Object.freeze({ - 'program': 'PROGRAM', - 'shutterPriority': 'SHUTTER_PRIORITY', - 'aperturePriority': 'APERTURE_PRIORITY', - 'manual': 'MANUAL', -}); - -type VideoFileFormat = 'mov' | 'mp4' | 'tiffSequence' | 'seq'; - -const videoFileFormats = Object.freeze({ - 'mov': 'MOV', - 'mp4': 'MP4', - 'tiffSequence': 'TIFF_SEQ', - 'seq': 'SEQ', -}); - -type VideoFileCompressionStandard = 'H264' | 'H265'; - -const videoFileCompressionStandards = Object.freeze({ - 'H264': 'H264', - 'H265': 'H265', -}); - -type VideoResolutions = '4096x2160' | '4608x2160' | '4608x2592' | '3840x2160'; - -const videoResolutions = Object.freeze({ - '4096x2160': 'RESOLUTION_4096x2160', - '4608x2160': 'RESOLUTION_4608x2160', - '4608x2592': 'RESOLUTION_4608x2592', - '3840x2160': 'RESOLUTION_3840x2160', -}); - -type VideoFrameRates = '60' | '59.94' | '30' | '29.97'; - -const videoFrameRates = Object.freeze({ - '60': 'FRAME_RATE_60_FPS', - '59.94': 'FRAME_RATE_59_DOT_940_FPS', - '30' : 'FRAME_RATE_30_FPS', - '29.97' : 'FRAME_RATE_29_DOT_970_FPS', -}); - -type ISOValues = 'AUTO' | '100' | '200' | '400' | '800' | '1600' | '3200' | '6400' | '12800' | '25600' | 'FIXED'; - -const isoValues = Object.freeze({ - '100': 'ISO_100', - '200': 'ISO_200', - '300': 'ISO_300', - '400': 'ISO_400', - '800': 'ISO_800', - '1600': 'ISO_1600', - '3200': 'ISO_3200', - '6400': 'ISO_6400', - '12800': 'ISO_12800', - '25600': 'ISO_25600', - 'FIXED': 'FIXED', - 'AUTO': 'AUTO', -}); - -type ShutterSpeeds = '1/400' | '1/500' | '1/640' | '1/725' | '1/800' | '1/1000' | '1/1250' | '1/1500' | '1/1600' | '1/2000' | '1/2500' | '1/3000' | '1/3200' | '1/4000'; - -const shutterSpeeds = Object.freeze({ - '1/400': 'SHUTTER_SPEED_1_400', - '1/500': 'SHUTTER_SPEED_1_500', - '1/640' : 'SHUTTER_SPEED_1_640', - '1/725': 'SHUTTER_SPEED_1_725', - '1/800': 'SHUTTER_SPEED_1_800', - '1/1000': 'SHUTTER_SPEED_1_1000', - '1/1250': 'SHUTTER_SPEED_1_1250', - '1/1500': 'SHUTTER_SPEED_1_1500', - '1/1600': 'SHUTTER_SPEED_1_1600', - '1/2000': 'SHUTTER_SPEED_1_2000', - '1/2500': 'SHUTTER_SPEED_1_2500', - '1/3000': 'SHUTTER_SPEED_1_3000', - '1/3200': 'SHUTTER_SPEED_1_3200', - '1/4000': 'SHUTTER_SPEED_1_4000', -}); - -type CameraModes = 'shootPhoto' | 'recordVideo' | 'playback' | 'mediaDownload' | 'broadcast' | 'unknown'; - -const cameraModes = Object.freeze({ - 'shootPhoto': 'SHOOT_PHOTO', - 'recordVideo': 'RECORD_VIDEO', - 'playback': 'PLAYBACK', - 'mediaDownload': 'MEDIA_DOWNLOAD', - 'broadcast': 'BROADCAST', - 'unknown': 'UNKNOWN', -}); - -type CameraColors = 'DLOG' | 'DCINELIKE' - -const cameraColors = Object.freeze({ - 'DLog': 'D_LOG', - 'DCinelike': 'D_CINELIKE' -}); - -type FocusModes = 'manual' | 'auto' | 'afc' - -const focusModes = Object.freeze({ - 'manual': 'MANUAL', - 'auto': 'AUTO', - 'afc': 'AFC', -}); - -type VideoStandard = 'pal' | 'ntsc' | 'unknown' - -const videoStandards = Object.freeze({ - 'pal': 'PAL', - 'ntsc': 'NTSC', - 'unknown': 'UNKNOWN', -}); - -type ExposureCompensationValues = '-5.0' | '-4.7' | '-4.3' | '-4.0' | '-3.7' | '-3.3' | '-3.0' | '-2.7' | '-2.3' | '-2.0' | '-1.7' | '-1.3' | '-1.0' | '-0.7' | '-0.3' | '0.0' | '0.3' | '0.7' | '1.0' | '1.3' | '1.7' | '2.0' | '2.3' | '2.7' | '3.0' | '3.3' | '3.7' | '4.0' | '5.0' | 'FIXED' -export const exposureCompensationValues = Object.freeze({ - '-5.0': 'N_5_0', - '-4.7': 'N_4_7', - '-4.3': 'N_4_3', - '-4.0': 'N_4_0', - '-3.7': 'N_3_7', - '-3.3': 'N_3_3', - '-3.0': 'N_3_0', - '-2.7': 'N_2_7', - '-2.3': 'N_2_3', - '-2.0': 'N_2_0', - '-1.7': 'N_1_7', - '-1.3': 'N_1_3', - '-1.0': 'N_1_0', - '-0.7': 'N_0_7', - '-0.3': 'N_0_3', - '0.0': 'N_0_0', - '0.3': 'P_0_3', - '0.7': 'P_0_7', - '1.0': 'P_1_0', - '1.3': 'P_1_3', - '1.7': 'P_1_7', - '2.0': 'P_2_0', - '2.3': 'P_2_3', - '2.7': 'P_2_7', - '3.0': 'P_3_0', - '3.3': 'P_3_3', - '3.7': 'P_3_7', - '4.0': 'P_4_0', - '5.0': 'P_5_0', - 'FIXED': 'FIXED' -}) - -const CameraControl = { - - setPhotoAspectRatio: async (photoAspectRatio: PhotoAspectRatio) => { - return await CameraControlNative.setPhotoAspectRatio(photoAspectRatios[photoAspectRatio]); - }, - - setWhiteBalance: async (parameters: WhiteBalanceParameters) => { - if (parameters.preset != null) { - if (!(parameters.preset in whiteBalancePresets)) { - throw new Error(`White balance value ${parameters.preset} is not recognised`); - } - parameters.preset = whiteBalancePresets[parameters.preset]; - } else if (parameters.colorTemperature != null) { - if (parameters.colorTemperature < 20 || parameters.colorTemperature > 100) { - throw new Error(`White balance value ${parameters.colorTemperature} is outside of range 20 to 100`); - } - } else { - throw new Error("Cannot set white balance with null values"); - } - return await CameraControlNative.setWhiteBalance(parameters); - }, - - setExposureMode: async (exposureMode: ExposureMode) => { - return await CameraControlNative.setExposureMode(exposureModes[exposureMode]); - }, - - startRecording: async () => { - return await CameraControlNative.startRecording(); - }, - - stopRecording: async () => { - return await CameraControlNative.stopRecording(); - }, - - setVideoFileFormat: async (videoFileFormat: VideoFileFormat) => { - return await CameraControlNative.setVideoFileFormat(videoFileFormats[videoFileFormat]); - }, - - setVideoFileCompressionStandard: async (videoFileCompressionStandard: VideoFileCompressionStandard) => { - return await CameraControlNative.setVideoFileCompressionStandard(videoFileCompressionStandards[videoFileCompressionStandard]); - }, - setVideoResolutionAndFrameRate: async (videoResolution: VideoResolutions, videoFrameRate: VideoFrameRates) => { - return await CameraControlNative.setVideoResolutionAndFrameRate(videoResolutions[videoResolution], videoFrameRates[videoFrameRate]); - }, - getVideoResolutionAndFrameRateRange: async () => { - return await CameraControlNative.getVideoResolutionAndFrameRateRange(); - }, - isSDCardInserted: async () => { - return await CameraControlNative.isSDCardInserted(); - }, - setISO: async (isoValue: ISOValues) => { - return await CameraControlNative.setISO(isoValues[isoValue]); - }, - setShutterSpeed: async (shutterSpeed: ShutterSpeeds) => { - return await CameraControlNative.setShutterSpeed(shutterSpeeds[shutterSpeed]); - }, - setCameraMode: async (cameraMode: CameraModes) => { - return await CameraControlNative.setCameraMode(cameraModes[cameraMode]); - }, - setVideoCaptionsEnabled: async (enabled: boolean) => { - return await CameraControlNative.setVideoCaptionsEnabled(enabled); - }, - setCameraColor: async (cameraColor: CameraColors) => { - return await CameraControlNative.setCameraColor(cameraColors[cameraColor]); - }, - setSharpness: async (sharpness: number) => { - return await CameraControlNative.setSharpness(sharpness); - }, - setContrast: async (contrast: number) => { - return await CameraControlNative.setContrast(contrast); - }, - setSaturation: async (saturation: number) => { - return await CameraControlNative.setSaturation(saturation); - }, - setFocusMode: async (focusMode: FocusModes) => { - return await CameraControlNative.setFocusMode(focusModes[focusMode]); - }, - setFocusTarget: async (x: number, y: number) => { - return await CameraControlNative.setFocusTarget(x, y); - }, - setVideoStandard: async (videoStandard: VideoStandard) => { - return await CameraControlNative.setVideoStandard(videoStandards[videoStandard]); - }, - getVideoStandard: async () => { - return await CameraControlNative.getVideoStandard(); - }, - getFocusStatus: async () => { - return await CameraControlNative.getFocusStatus(); - }, - getFocusRingValue: async () => { - return await CameraControlNative.getFocusRingValue(); - }, - getDisplayName: async () => { - return await CameraControlNative.getDisplayName(); - }, - isRecording: async () => { - return await CameraControlNative.isRecording(); - }, - setExposureCompensation: async (exposureCompensationValue: ExposureCompensationValues) => { - return await CameraControlNative.setExposureCompensation(exposureCompensationValues[exposureCompensationValue]); - }, - getExposureCompensation: async (): ExposureCompensationValues => { - const djiExposureCompensationValue = await CameraControlNative.getExposureCompensation(); - // map the DJI exposure value string to a ExposureCompensationValues type - return Object.keys(exposureCompensationValues).find(key => exposureCompensationValues[key] === djiExposureCompensationValue) - }, - getCameraMode: async (): CameraModes => { - const cameraMode = await CameraControlNative.getCameraMode(); - return Object.keys(cameraModes).find(key => cameraModes[key] === cameraMode) - } -}; - -export default CameraControl; diff --git a/lib/CameraControl/index.ts b/lib/CameraControl/index.ts new file mode 100644 index 00000000..a981f09d --- /dev/null +++ b/lib/CameraControl/index.ts @@ -0,0 +1,445 @@ +import { NativeModules } from 'react-native'; + +import { + PhotoFileFormat, + DjiPhotoAspectRatio, + PhotoAspectRatio, +} from './types'; +import { swapKeysAndValues } from '../utilities/swapKeysAndValues'; + +const { CameraControlNative } = NativeModules; + +export const photoAspectRatios: Record = + Object.freeze({ + '4:3': 'RATIO_4_3', + '16:9': 'RATIO_16_9', + '3:2': 'RATIO_3_2', + '1:1': 'RATIO_1_1', + '18:9': 'RATIO_18_9', + '5:4': 'RATIO_5_4', + Unknown: 'UNKNOWN', + }); + +export const photoAspectRatioLookup = swapKeysAndValues( + photoAspectRatios, +) as Record; + +type WBPreset = + | 'auto' + | 'sunny' + | 'cloudy' + | 'waterSurface' + | 'indoorIncandescent' + | 'indoorFluorescent' + | 'custom' + | 'presetNeutral' + | 'unknown'; + +export interface WhiteBalanceParameters { + preset?: WBPreset; + colorTemperature?: number; // in range [20, 100] +} + +const whiteBalancePresets: Record = { + auto: 'AUTO', + sunny: 'SUNNY', + cloudy: 'CLOUDY', + waterSurface: 'WATER_SURFACE', + indoorIncandescent: 'INDOOR_INCANDESCENT', + indoorFluorescent: 'INDOOR_FLUORESCENT', + custom: 'CUSTOM', + presetNeutral: 'PRESET_NEUTRAL', + unknown: 'UNKNOWN', +} as const; + +type WhiteBalancePresetKeys = keyof typeof whiteBalancePresets; +export type WhiteBalancePreset = + typeof whiteBalancePresets[WhiteBalancePresetKeys]; + +type ExposureMode = + | 'program' + | 'shutterPriority' + | 'aperturePriority' + | 'manual'; + +const exposureModes = Object.freeze({ + program: 'PROGRAM', + shutterPriority: 'SHUTTER_PRIORITY', + aperturePriority: 'APERTURE_PRIORITY', + manual: 'MANUAL', +}); + +export const readableExposureModes = Object.freeze({ + PROGRAM: 'Auto', + SHUTTER_PRIORITY: 'Shutter priority', + APERTURE_PRIORITY: 'Aperture priority', + MANUAL: 'Manual', + CINE: 'Cine', + UNKNOWN: 'Unknown', +}); + +type VideoFileFormat = 'mov' | 'mp4' | 'tiffSequence' | 'seq'; + +const videoFileFormats = Object.freeze({ + mov: 'MOV', + mp4: 'MP4', + tiffSequence: 'TIFF_SEQ', + seq: 'SEQ', +}); + +type VideoFileCompressionStandard = 'H264' | 'H265'; + +const videoFileCompressionStandards = Object.freeze({ + H264: 'H264', + H265: 'H265', +}); + +type VideoResolutions = '4096x2160' | '4608x2160' | '4608x2592' | '3840x2160'; + +const videoResolutions = Object.freeze({ + '4096x2160': 'RESOLUTION_4096x2160', + '4608x2160': 'RESOLUTION_4608x2160', + '4608x2592': 'RESOLUTION_4608x2592', + '3840x2160': 'RESOLUTION_3840x2160', +}); + +type VideoFrameRates = '60' | '59.94' | '30' | '29.97'; + +const videoFrameRates = Object.freeze({ + '60': 'FRAME_RATE_60_FPS', + '59.94': 'FRAME_RATE_59_DOT_940_FPS', + '30': 'FRAME_RATE_30_FPS', + '29.97': 'FRAME_RATE_29_DOT_970_FPS', +}); + +type ISOValues = + | 'AUTO' + | '100' + | '200' + | '400' + | '800' + | '1600' + | '3200' + | '6400' + | '12800' + | '25600' + | 'FIXED'; + +const isoValues = Object.freeze({ + '100': 'ISO_100', + '200': 'ISO_200', + '300': 'ISO_300', + '400': 'ISO_400', + '800': 'ISO_800', + '1600': 'ISO_1600', + '3200': 'ISO_3200', + '6400': 'ISO_6400', + '12800': 'ISO_12800', + '25600': 'ISO_25600', + FIXED: 'FIXED', + AUTO: 'AUTO', +}); + +type ShutterSpeeds = + | '1/400' + | '1/500' + | '1/640' + | '1/725' + | '1/800' + | '1/1000' + | '1/1250' + | '1/1500' + | '1/1600' + | '1/2000' + | '1/2500' + | '1/3000' + | '1/3200' + | '1/4000'; + +const shutterSpeeds = Object.freeze({ + '1/400': 'SHUTTER_SPEED_1_400', + '1/500': 'SHUTTER_SPEED_1_500', + '1/640': 'SHUTTER_SPEED_1_640', + '1/725': 'SHUTTER_SPEED_1_725', + '1/800': 'SHUTTER_SPEED_1_800', + '1/1000': 'SHUTTER_SPEED_1_1000', + '1/1250': 'SHUTTER_SPEED_1_1250', + '1/1500': 'SHUTTER_SPEED_1_1500', + '1/1600': 'SHUTTER_SPEED_1_1600', + '1/2000': 'SHUTTER_SPEED_1_2000', + '1/2500': 'SHUTTER_SPEED_1_2500', + '1/3000': 'SHUTTER_SPEED_1_3000', + '1/3200': 'SHUTTER_SPEED_1_3200', + '1/4000': 'SHUTTER_SPEED_1_4000', +}); + +type CameraModes = + | 'shootPhoto' + | 'recordVideo' + | 'playback' + | 'mediaDownload' + | 'broadcast' + | 'unknown'; + +const cameraModes: Record = { + shootPhoto: 'SHOOT_PHOTO', + recordVideo: 'RECORD_VIDEO', + playback: 'PLAYBACK', + mediaDownload: 'MEDIA_DOWNLOAD', + broadcast: 'BROADCAST', + unknown: 'UNKNOWN', +} as const; + +type CameraColors = 'DLog' | 'DCinelike'; + +const cameraColors = { + DLog: 'D_LOG', + DCinelike: 'D_CINELIKE', +} as const; + +type FocusModes = 'manual' | 'auto' | 'afc'; + +const focusModes = Object.freeze({ + manual: 'MANUAL', + auto: 'AUTO', + afc: 'AFC', +}); + +type VideoStandard = 'pal' | 'ntsc' | 'unknown'; + +const videoStandards = Object.freeze({ + pal: 'PAL', + ntsc: 'NTSC', + unknown: 'UNKNOWN', +}); + +export type ExposureCompensationValues = + | '-5.0' + | '-4.7' + | '-4.3' + | '-4.0' + | '-3.7' + | '-3.3' + | '-3.0' + | '-2.7' + | '-2.3' + | '-2.0' + | '-1.7' + | '-1.3' + | '-1.0' + | '-0.7' + | '-0.3' + | '0.0' + | '0.3' + | '0.7' + | '1.0' + | '1.3' + | '1.7' + | '2.0' + | '2.3' + | '2.7' + | '3.0' + | '3.3' + | '3.7' + | '4.0' + | '5.0' + | 'FIXED'; + +export const exposureCompensationValues: Record< + ExposureCompensationValues, + string +> = { + '-5.0': 'N_5_0', + '-4.7': 'N_4_7', + '-4.3': 'N_4_3', + '-4.0': 'N_4_0', + '-3.7': 'N_3_7', + '-3.3': 'N_3_3', + '-3.0': 'N_3_0', + '-2.7': 'N_2_7', + '-2.3': 'N_2_3', + '-2.0': 'N_2_0', + '-1.7': 'N_1_7', + '-1.3': 'N_1_3', + '-1.0': 'N_1_0', + '-0.7': 'N_0_7', + '-0.3': 'N_0_3', + '0.0': 'N_0_0', + '0.3': 'P_0_3', + '0.7': 'P_0_7', + '1.0': 'P_1_0', + '1.3': 'P_1_3', + '1.7': 'P_1_7', + '2.0': 'P_2_0', + '2.3': 'P_2_3', + '2.7': 'P_2_7', + '3.0': 'P_3_0', + '3.3': 'P_3_3', + '3.7': 'P_3_7', + '4.0': 'P_4_0', + '5.0': 'P_5_0', + FIXED: 'FIXED', +} as const; + +const CameraControl = { + setPhotoAspectRatio: async (photoAspectRatio: PhotoAspectRatio) => { + return await CameraControlNative.setPhotoAspectRatio( + photoAspectRatios[photoAspectRatio], + ); + }, + + setWhiteBalance: async (parameters: WhiteBalanceParameters) => { + if (parameters.preset != null) { + if (!(parameters.preset in whiteBalancePresets)) { + throw new Error( + `White balance value ${parameters.preset} is not recognised`, + ); + } + } else if (parameters.colorTemperature != null) { + if ( + parameters.colorTemperature < 20 || + parameters.colorTemperature > 100 + ) { + throw new Error( + `White balance value ${parameters.colorTemperature} is outside of range 20 to 100`, + ); + } + } else { + throw new Error('Cannot set white balance with null values'); + } + const newParameters = { + preset: + parameters.preset != null + ? whiteBalancePresets[parameters.preset] + : undefined, + colorTemperature: parameters.colorTemperature, + }; + return await CameraControlNative.setWhiteBalance(newParameters); + }, + + setExposureMode: async (exposureMode: ExposureMode) => { + return await CameraControlNative.setExposureMode( + exposureModes[exposureMode], + ); + }, + + startRecording: async () => { + return await CameraControlNative.startRecording(); + }, + + stopRecording: async () => { + return await CameraControlNative.stopRecording(); + }, + + setVideoFileFormat: async (videoFileFormat: VideoFileFormat) => { + return await CameraControlNative.setVideoFileFormat( + videoFileFormats[videoFileFormat], + ); + }, + + setVideoFileCompressionStandard: async ( + videoFileCompressionStandard: VideoFileCompressionStandard, + ) => { + return await CameraControlNative.setVideoFileCompressionStandard( + videoFileCompressionStandards[videoFileCompressionStandard], + ); + }, + setVideoResolutionAndFrameRate: async ( + videoResolution: VideoResolutions, + videoFrameRate: VideoFrameRates, + ) => { + return await CameraControlNative.setVideoResolutionAndFrameRate( + videoResolutions[videoResolution], + videoFrameRates[videoFrameRate], + ); + }, + getVideoResolutionAndFrameRateRange: async () => { + return await CameraControlNative.getVideoResolutionAndFrameRateRange(); + }, + isSDCardInserted: async () => { + return await CameraControlNative.isSDCardInserted(); + }, + setISO: async (isoValue: ISOValues) => { + return await CameraControlNative.setISO(isoValues[isoValue]); + }, + setShutterSpeed: async (shutterSpeed: ShutterSpeeds) => { + return await CameraControlNative.setShutterSpeed( + shutterSpeeds[shutterSpeed], + ); + }, + setCameraMode: async (cameraMode: CameraModes) => { + return await CameraControlNative.setCameraMode(cameraModes[cameraMode]); + }, + setVideoCaptionsEnabled: async (enabled: boolean) => { + return await CameraControlNative.setVideoCaptionsEnabled(enabled); + }, + setCameraColor: async (cameraColor: CameraColors) => { + return await CameraControlNative.setCameraColor(cameraColors[cameraColor]); + }, + setSharpness: async (sharpness: number) => { + return await CameraControlNative.setSharpness(sharpness); + }, + setContrast: async (contrast: number) => { + return await CameraControlNative.setContrast(contrast); + }, + setSaturation: async (saturation: number) => { + return await CameraControlNative.setSaturation(saturation); + }, + setFocusMode: async (focusMode: FocusModes) => { + return await CameraControlNative.setFocusMode(focusModes[focusMode]); + }, + setFocusTarget: async (x: number, y: number) => { + return await CameraControlNative.setFocusTarget(x, y); + }, + setVideoStandard: async (videoStandard: VideoStandard) => { + return await CameraControlNative.setVideoStandard( + videoStandards[videoStandard], + ); + }, + getVideoStandard: async () => { + return await CameraControlNative.getVideoStandard(); + }, + getFocusStatus: async () => { + return await CameraControlNative.getFocusStatus(); + }, + getFocusRingValue: async () => { + return await CameraControlNative.getFocusRingValue(); + }, + getDisplayName: async () => { + return await CameraControlNative.getDisplayName(); + }, + isRecording: async () => { + return await CameraControlNative.isRecording(); + }, + setExposureCompensation: async ( + exposureCompensationValue: ExposureCompensationValues, + ) => { + return await CameraControlNative.setExposureCompensation( + exposureCompensationValues[exposureCompensationValue], + ); + }, + getExposureCompensation: async (): Promise => { + const djiExposureCompensationValue = + await CameraControlNative.getExposureCompensation(); + // map the DJI exposure value string to a ExposureCompensationValues type + return Object.keys(exposureCompensationValues).find( + key => + exposureCompensationValues[key as ExposureCompensationValues] === + djiExposureCompensationValue, + ) as ExposureCompensationValues; + }, + getCameraMode: async (): Promise => { + const djiCameraMode = await CameraControlNative.getCameraMode(); + return Object.keys(cameraModes).find( + key => cameraModes[key as CameraModes] === djiCameraMode, + ) as CameraModes; + }, + setPhotoFileFormat: async (format: PhotoFileFormat) => { + return CameraControlNative.setPhotoFileFormat(format); + }, + getWhiteBalancePreset: async (): Promise => { + return CameraControlNative.getWhiteBalancePreset(); + }, +}; + +export default CameraControl; diff --git a/lib/CameraControl/types.ts b/lib/CameraControl/types.ts new file mode 100644 index 00000000..c3506b4c --- /dev/null +++ b/lib/CameraControl/types.ts @@ -0,0 +1,38 @@ +export type PhotoFileFormat = + | 'RAW' + | 'JPEG' + | 'RAW_AND_JPEG' + | 'TIFF_8_BIT' + | 'TIFF_14_BIT' + | 'TIFF_14_BIT_LINEAR_LOW_TEMP_RESOLUTION' + | 'TIFF_14_BIT_LINEAR_HIGH_TEMP_RESOLUTION' + | 'RADIOMETRIC_JPEG' + | 'RADIOMETRIC_JPEG_LOW' + | 'RADIOMETRIC_JPEG_HIGH' + | 'UNKNOWN'; + +export type DjiPhotoAspectRatio = + | 'RATIO_4_3' + | 'RATIO_16_9' + | 'RATIO_3_2' + | 'RATIO_1_1' + | 'RATIO_18_9' + | 'RATIO_5_4' + | 'UNKNOWN' + +export type PhotoAspectRatio = + | '4:3' + | '16:9' + | '3:2' + | '1:1' + | '18:9' + | '5:4' + | 'Unknown'; + +export type DjiExposureModes = + | 'PROGRAM' + | 'SHUTTER_PRIORITY' + | 'APERTURE_PRIORITY' + | 'MANUAL' + | 'CINE' + | 'UNKNOWN' diff --git a/lib/DJIErrorHandler/index.js b/lib/DJIErrorHandler/index.ts similarity index 97% rename from lib/DJIErrorHandler/index.js rename to lib/DJIErrorHandler/index.ts index 3f9d6d5e..01961b84 100644 --- a/lib/DJIErrorHandler/index.js +++ b/lib/DJIErrorHandler/index.ts @@ -1,4 +1,3 @@ -// @flow strict const DJIGimbalAttitudeActionErrorDomain = { name: 'DJIGimbalAttitudeActionErrorDomain', @@ -35,7 +34,7 @@ export const handleSdkError = (err) => { errorDomainIndex = index; } }); - - // if + + // if }; diff --git a/lib/DJIFlightController/index.js b/lib/DJIFlightController/index.js deleted file mode 100644 index dfa6429e..00000000 --- a/lib/DJIFlightController/index.js +++ /dev/null @@ -1,125 +0,0 @@ -// @flow strict - -import { - NativeModules, -} from 'react-native'; - -import type { - CreateWaypointMissionParameters, - Waypoint, -} from './DJIMissionControlTypes'; - -import { - DJIEventSubject, -} from '../utilities'; - -import { - type Observer, -} from 'rxjs'; - -import { - filter as $filter, - map as $map, -} from 'rxjs/operators'; - -const { - FlightControllerWrapper, -} = NativeModules; - -import { - type VirtualStickParameters, -} from '../DJIMissionControl/DJITimelineElements/VirtualStickTimelineElement'; - -type RemoteControllerFlightModes = 'P' | 'A' | 'S' | 'G' | 'M' | 'F' | 'T' | 'UNKNOWN' - -const DJIFlightController = { - - startVirtualStick: async (parameters: VirtualStickParameters) => { - return await FlightControllerWrapper.startVirtualStick(parameters); - }, - stopVirtualStick: async () => { - return await FlightControllerWrapper.stopVirtualStick(); - }, - - startYawAction: (angle: number, isAbsolute: boolean, timeoutMs: number) => { - return FlightControllerWrapper.startYawAction(angle, isAbsolute, timeoutMs); - }, - - startWaypointMission: async (parameters) => { - return await FlightControllerWrapper.startWaypointMission(parameters); - }, - stopWaypointMission: async () => { - return await FlightControllerWrapper.stopWaypointMission(); - }, - - startVirtualStickTimelineElementEventListener: async () => { - return DJIEventSubject.pipe($filter(evt => evt.type === 'VirtualStickTimelineElementEvent')).asObservable(); - }, - stopVirtualStickTimelineElementEventListener: async () => { - return; // The events are sent automatically when a virtual stick timeline event is running, so no listener needs to be started or stopped - }, - - startWaypointMissionFinishedListener: async () => { - await FlightControllerWrapper.startWaypointMissionFinishedListener(); - return DJIEventSubject.pipe($filter(evt => evt.type === 'WaypointMissionFinished')).asObservable(); - }, - startWaypointMissionStartedListener: async () => { - return DJIEventSubject.pipe($filter(evt => evt.type === 'WaypointMissionStarted')).asObservable(); - }, - startWaypointExecutionUpdateListener: async () => { - await FlightControllerWrapper.startWaypointExecutionUpdateListener(); - return DJIEventSubject.pipe($filter(evt => evt.type === 'WaypointMissionExecutionProgress')).asObservable(); - }, - stopAllWaypointMissionListeners: async () => { - return await FlightControllerWrapper.stopAllWaypointMissionListeners(); - }, - - startRecordFlightData: async (fileName: string) => { - return await FlightControllerWrapper.startRecordFlightData(fileName); - }, - stopRecordFlightData: async () => { - return await FlightControllerWrapper.stopRecordFlightData(); - }, - setAutoFlightSpeed: async (speed: number) => { - return await FlightControllerWrapper.setAutoFlightSpeed(speed); - }, - setTerrainFollowModeEnabled: async (enabled: boolean) => { - return await FlightControllerWrapper.setTerrainFollowModeEnabled(enabled); - }, - getUltrasonicHeight: async () => { - return await FlightControllerWrapper.getUltrasonicHeight(); - }, - setVirtualStickAdvancedModeEnabled: async (enabled: boolean) => { - return await FlightControllerWrapper.setVirtualStickAdvancedModeEnabled(enabled); - }, - isVirtualStickAdvancedModeEnabled: async () => { - return await FlightControllerWrapper.isVirtualStickAdvancedModeEnabled(); - }, - isOnboardSDKDeviceAvailable: async () => { - return await FlightControllerWrapper.isOnboardSDKDeviceAvailable(); - }, - sendDataToOnboardSDKDevice: async (data: number[]) => { - return await FlightControllerWrapper.sendDataToOnboardSDKDevice(data); - }, - startOnboardSDKDeviceDataListener: async () => { - await FlightControllerWrapper.startOnboardSDKDeviceDataListener(); - return DJIEventSubject.pipe($filter(evt => evt.type === 'OnboardSDKDeviceData')).asObservable(); - }, - stopOnboardSDKDeviceDataListener: async () => { - await FlightControllerWrapper.stopOnboardSDKDeviceDataListener(); - }, - setPowerSupplyPortEnabled: async (enabled: boolean) => { - return await FlightControllerWrapper.setPowerSupplyPortEnabled(enabled); - }, - getPowerSupplyPortEnabled: async () => { - return await FlightControllerWrapper.getPowerSupplyPortEnabled(); - }, - doesCompassNeedCalibrating: async () => { - return await FlightControllerWrapper.doesCompassNeedCalibrating(); - }, - getRemoteControllerFlightMode: async (): RemoteControllerFlightModes => { - return await FlightControllerWrapper.getRemoteControllerFlightMode(); - } - }; - -export default DJIFlightController; diff --git a/lib/DJIFlightController/index.ts b/lib/DJIFlightController/index.ts new file mode 100644 index 00000000..dcf4fb78 --- /dev/null +++ b/lib/DJIFlightController/index.ts @@ -0,0 +1,294 @@ +import { NativeModules } from 'react-native'; + +import { DJIEventSubject, observeEvent } from '../utilities'; + +import { filter as $filter } from 'rxjs/operators'; + +import { VirtualStickParameters } from '../DJIMissionControl/DJITimelineElements/VirtualStickTimelineElement'; +import { + WaypointMissionExecutionProgressEvent, + WaypointMissionState, + WaypointMissionUploadEvent, +} from '../../types'; + +import { + AircraftLEDsState, + RemoteControllerFlightModes, + SetAircraftLEDsState, + WaypointMissionParameters, + WaypointMissionV2Parameters, +} from './types'; +import { modelSupportsWaypointV2 } from './utils/modelSupportsWaypointV2'; + +const { FlightControllerWrapper, WaypointMissionV2Wrapper, DJIMobile } = + NativeModules; + +const DJIFlightController = { + startVirtualStick: async (parameters: VirtualStickParameters) => { + return FlightControllerWrapper.startVirtualStick(parameters); + }, + stopVirtualStick: async () => { + return FlightControllerWrapper.stopVirtualStick(); + }, + + startYawAction: (angle: number, isAbsolute: boolean, timeoutMs: number) => { + return FlightControllerWrapper.startYawAction(angle, isAbsolute, timeoutMs); + }, + + uploadWaypointMission: async (parameters: WaypointMissionParameters) => { + const modelName = await DJIMobile.getModelName(); + if (modelSupportsWaypointV2(modelName)) { + throw new Error( + `Attempted to start waypoint V1 mission with incompatible drone model ${modelName}`, + ); + } + return FlightControllerWrapper.uploadWaypointMission(parameters); + }, + uploadWaypointV2Mission: async (parameters: WaypointMissionV2Parameters) => { + const modelName = await DJIMobile.getModelName(); + if (!modelSupportsWaypointV2(modelName)) { + throw new Error( + `Attempted to start waypoint V2 mission with incompatible drone model ${modelName}`, + ); + } + return WaypointMissionV2Wrapper.uploadWaypointMission(parameters); + }, + startWaypointMission: async () => { + const modelName = await DJIMobile.getModelName(); + if (modelSupportsWaypointV2(modelName)) { + return WaypointMissionV2Wrapper.startWaypointMission(); + } + return FlightControllerWrapper.startWaypointMission(); + }, + stopWaypointMission: async () => { + const modelName = await DJIMobile.getModelName(); + if (modelSupportsWaypointV2(modelName)) { + return WaypointMissionV2Wrapper.stopWaypointMission(); + } + return FlightControllerWrapper.stopWaypointMission(); + }, + + /** + * Waypoint Mission V2 + * + * You should not need to call these V2 methods explicitly since calling + * startWaypointMission, etc. should choose the appropriate waypoint mission method + */ + uploadWaypointMissionV2: async (parameters: WaypointMissionParameters) => { + return WaypointMissionV2Wrapper.uploadWaypointMission(parameters); + }, + startWaypointMissionV2: async () => { + return WaypointMissionV2Wrapper.startWaypointMission(); + }, + stopWaypointMissionV2: async () => { + return WaypointMissionV2Wrapper.stopWaypointMission(); + }, + + startVirtualStickTimelineElementEventListener: async () => { + return DJIEventSubject.pipe( + $filter(evt => evt.type === 'VirtualStickTimelineElementEvent'), + ); + }, + stopVirtualStickTimelineElementEventListener: async () => { + return; // The events are sent automatically when a virtual stick timeline event is running, so no listener needs to be started or stopped + }, + + // Waypoint mission started/stopped listeners + // TODO: add to V2 mission if useful + startWaypointMissionFinishedListener: async () => { + await FlightControllerWrapper.startWaypointMissionFinishedListener(); + return DJIEventSubject.pipe( + $filter(evt => evt.type === 'WaypointMissionFinished'), + ); + }, + startWaypointMissionStartedListener: async () => { + return DJIEventSubject.pipe( + $filter(evt => evt.type === 'WaypointMissionStarted'), + ); + }, + + // Waypoint mission execution state listeners + startWaypointExecutionUpdateListener: async () => { + const modelName = await DJIMobile.getModelName(); + if (modelSupportsWaypointV2(modelName)) { + await WaypointMissionV2Wrapper.startWaypointExecutionUpdateListener(); + } else { + await FlightControllerWrapper.startWaypointExecutionUpdateListener(); + } + return observeEvent( + 'WaypointMissionExecutionProgress', + ); + }, + startWaypointV1ExecutionUpdateListener: async () => { + await FlightControllerWrapper.startWaypointExecutionUpdateListener(); + return observeEvent( + 'WaypointMissionExecutionProgress', + ); + }, + startWaypointV2ExecutionUpdateListener: async () => { + await WaypointMissionV2Wrapper.startWaypointExecutionUpdateListener(); + return observeEvent( + 'WaypointMissionExecutionProgress', + ); + }, + observeWaypointExecutionUpdate: + observeEvent( + 'WaypointMissionExecutionProgress', + ), + + // Waypoint mission state listeners + startWaypointMissionStateListener: async () => { + const modelName = await DJIMobile.getModelName(); + if (modelSupportsWaypointV2(modelName)) { + await WaypointMissionV2Wrapper.startWaypointMissionStateListener(); + } else { + await FlightControllerWrapper.startWaypointMissionStateListener(); + } + return observeEvent( + 'WaypointMissionExecutionProgress', + ); + }, + startWaypointMissionV1StateListener: async () => { + await FlightControllerWrapper.startWaypointMissionStateListener(); + return observeEvent('WaypointMissionState'); + }, + startWaypointMissionV2StateListener: async () => { + await WaypointMissionV2Wrapper.startWaypointMissionStateListener(); + return observeEvent('WaypointMissionState'); + }, + observeWaypointMissionState: observeEvent( + 'WaypointMissionState', + ), + + // Waypoint mission upload listeners + startWaypointMissionUploadListener: async () => { + const modelName = await DJIMobile.getModelName(); + if (modelSupportsWaypointV2(modelName)) { + await WaypointMissionV2Wrapper.startWaypointMissionUploadListener(); + } else { + await FlightControllerWrapper.startWaypointMissionUploadListener(); + } + return observeEvent( + 'WaypointMissionUploadProgress', + ); + }, + startWaypointMissionV1UploadListener: async () => { + await FlightControllerWrapper.startWaypointMissionUploadListener(); + return observeEvent( + 'WaypointMissionUploadProgress', + ); + }, + startWaypointMissionV2UploadListener: async () => { + await WaypointMissionV2Wrapper.startWaypointMissionUploadListener(); + return observeEvent( + 'WaypointMissionUploadProgress', + ); + }, + observeWaypointMissionUpload: observeEvent( + 'WaypointMissionUploadProgress', + ), + + // Waypoint mission error listeners + startWaypointMissionErrorListener: async () => { + const modelName = await DJIMobile.getModelName(); + if (modelSupportsWaypointV2(modelName)) { + await WaypointMissionV2Wrapper.startWaypointMissionStateListener(); + } else { + await FlightControllerWrapper.startWaypointMissionStateListener(); + } + return observeEvent('WaypointMissionError'); + }, + startWaypointMissionV1ErrorListener: async () => { + await FlightControllerWrapper.startWaypointMissionStateListener(); + return observeEvent('WaypointMissionError'); + }, + startWaypointMissionV2ErrorListener: async () => { + await WaypointMissionV2Wrapper.startWaypointMissionStateListener(); + return observeEvent('WaypointMissionError'); + }, + observeWaypointMissionError: observeEvent('WaypointMissionError'), + + // Waypoint mission action listeners - V2 only + startWaypointMissionActionStateListener: async () => { + const modelName = await DJIMobile.getModelName(); + if (modelSupportsWaypointV2(modelName)) { + await WaypointMissionV2Wrapper.startWaypointMissionStateListener(); + } + return observeEvent('WaypointMissionActionState'); + }, + observeWaypointMissionActionState: observeEvent( + 'WaypointMissionActionState', + ), + observeWaypointMissionActionUploadProgress: observeEvent( + 'WaypointMissionActionUploadProgress', + ), + + // Stop waypoint mission listeners + stopAllWaypointMissionListeners: async () => { + return FlightControllerWrapper.stopAllWaypointMissionListeners(); + }, + stopAllWaypointMissionV1Listeners: async () => { + return FlightControllerWrapper.stopAllWaypointMissionListeners(); + }, + stopAllWaypointMissionV2Listeners: async () => { + return WaypointMissionV2Wrapper.stopAllWaypointMissionListeners(); + }, + + startRecordFlightData: async (fileName: string) => { + return FlightControllerWrapper.startRecordFlightData(fileName); + }, + stopRecordFlightData: async () => { + return FlightControllerWrapper.stopRecordFlightData(); + }, + setAutoFlightSpeed: async (speed: number) => { + return FlightControllerWrapper.setAutoFlightSpeed(speed); + }, + setTerrainFollowModeEnabled: async (enabled: boolean) => { + return FlightControllerWrapper.setTerrainFollowModeEnabled(enabled); + }, + getUltrasonicHeight: async () => { + return FlightControllerWrapper.getUltrasonicHeight(); + }, + setVirtualStickAdvancedModeEnabled: async (enabled: boolean) => { + return FlightControllerWrapper.setVirtualStickAdvancedModeEnabled(enabled); + }, + isVirtualStickAdvancedModeEnabled: async () => { + return FlightControllerWrapper.isVirtualStickAdvancedModeEnabled(); + }, + isOnboardSDKDeviceAvailable: async () => { + return FlightControllerWrapper.isOnboardSDKDeviceAvailable(); + }, + sendDataToOnboardSDKDevice: async (data: number[]) => { + return FlightControllerWrapper.sendDataToOnboardSDKDevice(data); + }, + startOnboardSDKDeviceDataListener: async () => { + await FlightControllerWrapper.startOnboardSDKDeviceDataListener(); + return DJIEventSubject.pipe( + $filter(evt => evt.type === 'OnboardSDKDeviceData'), + ); + }, + stopOnboardSDKDeviceDataListener: async () => { + await FlightControllerWrapper.stopOnboardSDKDeviceDataListener(); + }, + setPowerSupplyPortEnabled: async (enabled: boolean) => { + return FlightControllerWrapper.setPowerSupplyPortEnabled(enabled); + }, + getPowerSupplyPortEnabled: async () => { + return FlightControllerWrapper.getPowerSupplyPortEnabled(); + }, + doesCompassNeedCalibrating: async () => { + return FlightControllerWrapper.doesCompassNeedCalibrating(); + }, + getRemoteControllerFlightMode: + async (): Promise => { + return FlightControllerWrapper.getRemoteControllerFlightMode(); + }, + setAircraftLEDsState: async (settings: SetAircraftLEDsState) => { + return FlightControllerWrapper.setAircraftLEDsState(settings); + }, + getAircraftLEDsState: async (): Promise => { + return FlightControllerWrapper.getAircraftLEDsState(); + }, +}; + +export default DJIFlightController; diff --git a/lib/DJIFlightController/types.ts b/lib/DJIFlightController/types.ts new file mode 100644 index 00000000..50cefa89 --- /dev/null +++ b/lib/DJIFlightController/types.ts @@ -0,0 +1,103 @@ +import { LocationCoordinate3D } from '../../types'; + +export type RemoteControllerFlightModes = + | 'P' + | 'A' + | 'S' + | 'G' + | 'M' + | 'F' + | 'T' + | 'UNKNOWN'; + +export type WaypointMissionHeadingMode = + | 'AUTO' + | 'USING_INITIAL_DIRECTION' + | 'CONTROL_BY_REMOTE_CONTROLLER' + | 'USING_WAYPOINT_HEADING' + | 'TOWARD_POINT_OF_INTEREST'; + +export type WaypointMissionGotoWaypointMode = 'SAFELY' | 'POINT_TO_POINT'; + +export type WaypointMissionFlightPathMode = 'NORMAL' | 'CURVED'; + +export type WaypointMissionFinishedAction = + | 'NO_ACTION' + | 'GO_HOME' + | 'AUTO_LAND' + | 'GO_FIRST_WAYPOINT' + | 'CONTINUE_UNTIL_END'; + +export interface Waypoint extends LocationCoordinate3D { + heading?: number; + speed?: number; + cornerRadiusInMeters?: number; + actions?: [ + { + actionType: string; + actionParam: number; + }, + ]; + shootPhotoDistanceInterval?: number; + shootPhotoTimeInterval?: number; +} + +export interface WaypointMissionParameters { + autoFlightSpeed: number; + maxFlightSpeed: number; + waypoints: Waypoint[]; + headingMode?: WaypointMissionHeadingMode; + heading?: number; + goToWaypointMode?: WaypointMissionGotoWaypointMode; + flightPathMode?: WaypointMissionFlightPathMode; + finishedAction?: WaypointMissionFinishedAction; +} + +// TODO: make the actions interface more generic +export interface WaypointV2 extends LocationCoordinate3D { + cornerRadiusInMeters?: number; + shootPhotoDistanceInterval?: number; + headingMode?: WaypointMissionV2HeadingMode; +} + +export type WaypointMissionV2HeadingMode = + | 'AUTO' + | 'FIXED' + | 'MANUAL' + | 'WAYPOINT_CUSTOM' + | 'TOWARD_POINT_OF_INTEREST' + | 'GIMBAL_YAW_FOLLOW' + | 'UNKNOWN'; + +export type WaypointMissionV2FlightPathMode = + | 'CURVATURE_CONTINUOUS_PASSED' + | 'GOTO_POINT_CURVE_AND_STOP' + | 'GOTO_POINT_STRAIGHT_LINE_AND_STOP' + | 'COORDINATE_TURN' + | 'GOTO_FIRST_POINT_ALONG_STRAIGHT_LINE' + | 'STRAIGHT_OUT' + | 'UNKNOWN'; + +export interface WaypointMissionV2Parameters { + autoFlightSpeed: number; + maxFlightSpeed: number; + waypoints: WaypointV2[]; + heading?: number; // not implemented yet + goToWaypointMode?: WaypointMissionGotoWaypointMode; // Same as V1 mission + flightPathMode?: WaypointMissionV2FlightPathMode; + finishedAction?: WaypointMissionFinishedAction; // Same as V1 mission +} + +export interface SetAircraftLEDsState { + frontLEDsOn?: boolean; + rearLEDsOn?: boolean; + beaconsOn?: boolean; + statusIndicatorOn?: boolean; +} + +export interface AircraftLEDsState { + areFrontLEDsOn: boolean; + areRearLEDsOn: boolean; + areBeaconsOn: boolean; + isStatusIndicatorOn: boolean; +} diff --git a/lib/DJIFlightController/utils/modelSupportsWaypointV2.ts b/lib/DJIFlightController/utils/modelSupportsWaypointV2.ts new file mode 100644 index 00000000..519d6d6c --- /dev/null +++ b/lib/DJIFlightController/utils/modelSupportsWaypointV2.ts @@ -0,0 +1,7 @@ +import { ModelName } from '../../../types'; + +const WAYPOINT_V2_DRONE_MODELS = ['MATRICE_300_RTK']; + +export const modelSupportsWaypointV2 = (modelName: ModelName) => { + return WAYPOINT_V2_DRONE_MODELS.includes(modelName); +}; diff --git a/lib/DJIGimbal/index.js b/lib/DJIGimbal/index.ts similarity index 58% rename from lib/DJIGimbal/index.js rename to lib/DJIGimbal/index.ts index a4c58463..c252931a 100644 --- a/lib/DJIGimbal/index.js +++ b/lib/DJIGimbal/index.ts @@ -1,31 +1,22 @@ -// @flow strict - import { NativeModules, } from 'react-native'; -import { - DJIEventSubject, -} from '../utilities'; -import { - filter as $filter, -} from 'rxjs/operators'; const { GimbalWrapper, } = NativeModules; type RotateParameters = { - roll: ?number, - pitch: ?number, - yaw: ?number, - time: ?number, + roll?: number, + pitch?: number, + yaw?: number, + time?: number, } -const gimbalModes = Object.freeze({ - 'FREE': 'FREE', - 'FPV': 'FPV', - 'YAW_FOLLOW': 'YAW_FOLLOW', -}); +type GimbalModes = + 'FREE' | + 'FPV' | + 'YAW_FOLLOW' const DJIGimbal = { getGimbalAttitude: async () => { @@ -37,8 +28,8 @@ const DJIGimbal = { getMode: async () => { return await GimbalWrapper.getMode(); }, - setMode: async(gimbalModeName: $Keys) => { - return await GimbalWrapper.setMode(gimbalModes[gimbalModeName]); + setMode: async(gimbalModeName: GimbalModes) => { + return await GimbalWrapper.setMode(gimbalModeName); }, resetPose: async() => { return await GimbalWrapper.resetPose(); diff --git a/lib/DJIMedia/index.js b/lib/DJIMedia/index.ts similarity index 88% rename from lib/DJIMedia/index.js rename to lib/DJIMedia/index.ts index 50a96fa8..7f9beac9 100644 --- a/lib/DJIMedia/index.js +++ b/lib/DJIMedia/index.ts @@ -1,5 +1,3 @@ -// @flow strict - import { NativeModules, } from 'react-native'; @@ -16,16 +14,16 @@ const { const DJIMediaControl = { - startFullResMediaFileDownload: async (fileName: string, newFileName: ?string) => { + startFullResMediaFileDownload: async (fileName: string, newFileName?: string) => { await DJIMedia.startFullResMediaFileDownload(fileName, newFileName); return DJIEventSubject.pipe( $filter(evt => evt.type === 'mediaFileDownloadEvent'), - ).asObservable(); + ); }, startFullResMediaFileDownloadListener: async () => { return DJIEventSubject.pipe( $filter(evt => evt.type === 'mediaFileDownloadEvent'), - ).asObservable(); + ); }, }; diff --git a/lib/DJIMissionControl/DJIMissionControlTypes.js b/lib/DJIMissionControl/DJIMissionControlTypes.ts similarity index 85% rename from lib/DJIMissionControl/DJIMissionControlTypes.js rename to lib/DJIMissionControl/DJIMissionControlTypes.ts index 3b3b68b3..dac80b5d 100644 --- a/lib/DJIMissionControl/DJIMissionControlTypes.js +++ b/lib/DJIMissionControl/DJIMissionControlTypes.ts @@ -1,6 +1,4 @@ -// @flow strict -// TODO: (Adam) export type CreateWaypointMissionParameters = { autoFlightSpeed: number, maxFlightSpeed: number, @@ -16,7 +14,7 @@ export type Waypoint = { latitude: number, altitude: number, actions?: Array<{ - actionType: $Values, + actionType: typeof WaypointActionType, actionParam: number, }>, cornerRadiusInMeters?: number, diff --git a/lib/DJIMissionControl/DJITimelineElements/AircraftYawAction.js b/lib/DJIMissionControl/DJITimelineElements/AircraftYawAction.ts similarity index 96% rename from lib/DJIMissionControl/DJITimelineElements/AircraftYawAction.js rename to lib/DJIMissionControl/DJITimelineElements/AircraftYawAction.ts index 888f17a6..9373a482 100644 --- a/lib/DJIMissionControl/DJITimelineElements/AircraftYawAction.js +++ b/lib/DJIMissionControl/DJITimelineElements/AircraftYawAction.ts @@ -1,5 +1,3 @@ -// @flow strict - import CustomTimelineElement from './CustomTimelineElement'; class AircraftYawAction extends CustomTimelineElement { @@ -8,11 +6,11 @@ class AircraftYawAction extends CustomTimelineElement { isAbsolute: boolean; constructor( - parameters?: {| + parameters?: { angle: number, velocity?: number, isAbsolute?: boolean, - |} + } ) { super('AircraftYawAction'); diff --git a/lib/DJIMissionControl/DJITimelineElements/CustomTimelineElement.js b/lib/DJIMissionControl/DJITimelineElements/CustomTimelineElement.ts similarity index 100% rename from lib/DJIMissionControl/DJITimelineElements/CustomTimelineElement.js rename to lib/DJIMissionControl/DJITimelineElements/CustomTimelineElement.ts diff --git a/lib/DJIMissionControl/DJITimelineElements/GimbalAttitudeAction.js b/lib/DJIMissionControl/DJITimelineElements/GimbalAttitudeAction.ts similarity index 96% rename from lib/DJIMissionControl/DJITimelineElements/GimbalAttitudeAction.js rename to lib/DJIMissionControl/DJITimelineElements/GimbalAttitudeAction.ts index 22b39693..32efbabf 100644 --- a/lib/DJIMissionControl/DJITimelineElements/GimbalAttitudeAction.js +++ b/lib/DJIMissionControl/DJITimelineElements/GimbalAttitudeAction.ts @@ -1,5 +1,3 @@ -// @flow strict - import CustomTimelineElement from './CustomTimelineElement'; type Parameters = { @@ -17,12 +15,12 @@ class GimbalAttitudeAction extends CustomTimelineElement { // gimbalMode; // TODO: constructor( - parameters?: {| + parameters?: { pitch?: number, roll?: number, yaw?: number, completionTime?: number, - |} + } ) { super('GimbalAttitudeAction'); diff --git a/lib/DJIMissionControl/DJITimelineElements/GoHomeAction.js b/lib/DJIMissionControl/DJITimelineElements/GoHomeAction.ts similarity index 82% rename from lib/DJIMissionControl/DJITimelineElements/GoHomeAction.js rename to lib/DJIMissionControl/DJITimelineElements/GoHomeAction.ts index eb62dae0..05b7491b 100644 --- a/lib/DJIMissionControl/DJITimelineElements/GoHomeAction.js +++ b/lib/DJIMissionControl/DJITimelineElements/GoHomeAction.ts @@ -1,14 +1,12 @@ -// @flow strict - import CustomTimelineElement from './CustomTimelineElement'; -type Parameters = {| +type Parameters = { autoConfirmLandingEnabled?: boolean, -|} +} class GoHomeAction extends CustomTimelineElement { - autoConfirmLandingEnabled: ?boolean; - constructor(parameters: ?Parameters) { + autoConfirmLandingEnabled?: boolean; + constructor(parameters?: Parameters) { super('GoHomeAction'); if (parameters != null) { diff --git a/lib/DJIMissionControl/DJITimelineElements/GoToAction.js b/lib/DJIMissionControl/DJITimelineElements/GoToAction.ts similarity index 91% rename from lib/DJIMissionControl/DJITimelineElements/GoToAction.js rename to lib/DJIMissionControl/DJITimelineElements/GoToAction.ts index a4e68c8d..028b8c59 100644 --- a/lib/DJIMissionControl/DJITimelineElements/GoToAction.js +++ b/lib/DJIMissionControl/DJITimelineElements/GoToAction.ts @@ -1,23 +1,21 @@ -// @flow strict - import CustomTimelineElement from './CustomTimelineElement'; -type Parameters = {| - coordinate?: {| +type Parameters = { + coordinate?: { longitude: number, latitude: number, - |}, + }, altitude?: number, flightSpeed?: number, -|} +} class GoToAction extends CustomTimelineElement { - coordinate: ?{| + coordinate?: { longitude: number, latitude: number, - |}; - altitude: ?number; - flightSpeed: ?number; + }; + altitude?: number; + flightSpeed?: number; constructor( parameters: Parameters diff --git a/lib/DJIMissionControl/DJITimelineElements/HotpointAction.js b/lib/DJIMissionControl/DJITimelineElements/HotpointAction.ts similarity index 96% rename from lib/DJIMissionControl/DJITimelineElements/HotpointAction.js rename to lib/DJIMissionControl/DJITimelineElements/HotpointAction.ts index 17af9384..9b39d7b1 100644 --- a/lib/DJIMissionControl/DJITimelineElements/HotpointAction.js +++ b/lib/DJIMissionControl/DJITimelineElements/HotpointAction.ts @@ -1,9 +1,7 @@ -// @flow strict - import CustomTimelineElement from './CustomTimelineElement'; -import type { +import { Hotpoint, -} from '../DJIMissionControlTypes.js'; +} from '../DJIMissionControlTypes'; const validHeadings = ['ALONG_CIRCLE_LOOKING_FORWARDS', 'ALONG_CIRCLE_LOOKING_BACKWARDS', 'TOWARDS_HOT_POINT', 'AWAY_FROM_HOT_POINT', 'CONTROLLED_BY_REMOTE_CONTROLLER', 'USING_INITIAL_HEADING']; @@ -20,7 +18,7 @@ class HotpointAction extends CustomTimelineElement { clockwise: boolean; constructor( - parameters?: {| + parameters?: { hotpoint: Hotpoint, angle: number, radius: number, @@ -28,7 +26,7 @@ class HotpointAction extends CustomTimelineElement { startPoint: string, heading: string, clockwise: boolean, - |} + } ) { super('HotpointAction'); diff --git a/lib/DJIMissionControl/DJITimelineElements/RecordFlightDataElement.js b/lib/DJIMissionControl/DJITimelineElements/RecordFlightDataElement.ts similarity index 91% rename from lib/DJIMissionControl/DJITimelineElements/RecordFlightDataElement.js rename to lib/DJIMissionControl/DJITimelineElements/RecordFlightDataElement.ts index f072a86a..fc8bea4b 100644 --- a/lib/DJIMissionControl/DJITimelineElements/RecordFlightDataElement.js +++ b/lib/DJIMissionControl/DJITimelineElements/RecordFlightDataElement.ts @@ -1,18 +1,16 @@ -// @flow strict - import CustomTimelineElement from './CustomTimelineElement'; class RecordFlightDataElement extends CustomTimelineElement { - parameters: {| + parameters: { stopRecordFlightData?: boolean, fileName?: string, - |} = {}; + } = {}; constructor( - parameters?: {| + parameters?: { stopRecordFlightData?: boolean, fileName: string, - |} + } ) { super('RecordFlightData'); diff --git a/lib/DJIMissionControl/DJITimelineElements/RecordVideoAction.js b/lib/DJIMissionControl/DJITimelineElements/RecordVideoAction.ts similarity index 88% rename from lib/DJIMissionControl/DJITimelineElements/RecordVideoAction.js rename to lib/DJIMissionControl/DJITimelineElements/RecordVideoAction.ts index d8fd8b77..94910a8d 100644 --- a/lib/DJIMissionControl/DJITimelineElements/RecordVideoAction.js +++ b/lib/DJIMissionControl/DJITimelineElements/RecordVideoAction.ts @@ -1,16 +1,14 @@ -// @flow strict - import CustomTimelineElement from './CustomTimelineElement'; class RecordVideoAction extends CustomTimelineElement { - duration: ?number; - stopRecord: ?boolean; + duration?: number; + stopRecord?: boolean; constructor( - parameters?: {| + parameters?: { duration?: number, stopRecord?: boolean, - |} + } ) { super('RecordVideoAction'); diff --git a/lib/DJIMissionControl/DJITimelineElements/RunJSElement.js b/lib/DJIMissionControl/DJITimelineElements/RunJSElement.ts similarity index 91% rename from lib/DJIMissionControl/DJITimelineElements/RunJSElement.js rename to lib/DJIMissionControl/DJITimelineElements/RunJSElement.ts index ba1b78a7..78d2abf8 100644 --- a/lib/DJIMissionControl/DJITimelineElements/RunJSElement.js +++ b/lib/DJIMissionControl/DJITimelineElements/RunJSElement.ts @@ -1,5 +1,3 @@ -// @flow strict - import CustomTimelineElement from './CustomTimelineElement'; import DJIMissionControl, { @@ -10,12 +8,12 @@ import DJIMissionControl, { class RunJSElement extends CustomTimelineElement { callbackfunc: () => void; - callbackFuncId: ?number; + callbackFuncId?: number; constructor( - parameters: {| + parameters: { callbackfunc: () => void, - |} + } ) { super('RunJSElement'); diff --git a/lib/DJIMissionControl/DJITimelineElements/ShootPhotoAction.js b/lib/DJIMissionControl/DJITimelineElements/ShootPhotoAction.ts similarity index 98% rename from lib/DJIMissionControl/DJITimelineElements/ShootPhotoAction.js rename to lib/DJIMissionControl/DJITimelineElements/ShootPhotoAction.ts index a487624e..4a166b18 100644 --- a/lib/DJIMissionControl/DJITimelineElements/ShootPhotoAction.js +++ b/lib/DJIMissionControl/DJITimelineElements/ShootPhotoAction.ts @@ -9,12 +9,12 @@ class ShootPhotoAction extends CustomTimelineElement { stopShoot: boolean; constructor( - parameters?: {| + parameters?: { count?: number, interval?: number, wait?: boolean, stopShoot?: boolean, - |} + } ) { super('ShootPhotoAction'); diff --git a/lib/DJIMissionControl/DJITimelineElements/TakeOffAction.js b/lib/DJIMissionControl/DJITimelineElements/TakeOffAction.ts similarity index 100% rename from lib/DJIMissionControl/DJITimelineElements/TakeOffAction.js rename to lib/DJIMissionControl/DJITimelineElements/TakeOffAction.ts diff --git a/lib/DJIMissionControl/DJITimelineElements/VirtualStickTimelineElement.js b/lib/DJIMissionControl/DJITimelineElements/VirtualStickTimelineElement.ts similarity index 99% rename from lib/DJIMissionControl/DJITimelineElements/VirtualStickTimelineElement.js rename to lib/DJIMissionControl/DJITimelineElements/VirtualStickTimelineElement.ts index fec6e188..c1757702 100644 --- a/lib/DJIMissionControl/DJITimelineElements/VirtualStickTimelineElement.js +++ b/lib/DJIMissionControl/DJITimelineElements/VirtualStickTimelineElement.ts @@ -19,7 +19,7 @@ type yawControlStickAdjustmentSettings = { // Vertical throttle [-4, 4] // Others [-15, 15] -export type VirtualStickParameters = {| +export type VirtualStickParameters = { baseVirtualStickControlValues?: { pitch?: number, roll?: number, @@ -42,7 +42,7 @@ export type VirtualStickParameters = {| yaw?: yawControlStickAdjustmentSettings, verticalThrottle?: controlStickAdjustmentSettings, } -|} +} const throwErrorIfSetAndNotBoolean = (variable: any, variableName: string) => { if (variable != null && typeof variable != 'boolean') { diff --git a/lib/DJIMissionControl/DJITimelineElements/WaypointMissionTimelineElement.js b/lib/DJIMissionControl/DJITimelineElements/WaypointMissionTimelineElement.ts similarity index 89% rename from lib/DJIMissionControl/DJITimelineElements/WaypointMissionTimelineElement.js rename to lib/DJIMissionControl/DJITimelineElements/WaypointMissionTimelineElement.ts index 34dd0bcd..4aefea3c 100644 --- a/lib/DJIMissionControl/DJITimelineElements/WaypointMissionTimelineElement.js +++ b/lib/DJIMissionControl/DJITimelineElements/WaypointMissionTimelineElement.ts @@ -1,5 +1,3 @@ -// @flow strict - import { NativeModules, } from 'react-native'; @@ -7,8 +5,8 @@ import { import CustomTimelineElement from './CustomTimelineElement'; import { - type Waypoint, -} from '../DJIMissionControlTypes.js'; + Waypoint, +} from '../DJIMissionControlTypes'; const { DJIMissionControlWrapper, @@ -20,7 +18,7 @@ const GO_TO_WAYPOINT_MODES = ['POINT_TO_POINT', 'SAFELY']; const FLIGHT_PATH_MODES = ['NORMAL', 'CURVED']; -export type WaypointMissionParameters = {| +export type WaypointMissionParameters = { waypoints: Waypoint[], autoFlightSpeed: number, // m/s maxFlightSpeed: number, // m/s @@ -28,7 +26,7 @@ export type WaypointMissionParameters = {| pauseSecondsAtWaypoints?: number, goToWaypointMode?: string, flightPathMode?: string, -|} +} class WaypointMissionTimelineElement extends CustomTimelineElement { parameters: WaypointMissionParameters; @@ -99,50 +97,50 @@ class WaypointMissionTimelineElement extends CustomTimelineElement { // FIXME: (Adam) the app will crash if any waypoint is missing an altitude, rather throw an error! addWaypoint(waypoint: Waypoint) { // this._throwErrorIfMissionBuilt(); - this.waypoints.push(waypoint); + this.parameters.waypoints.push(waypoint); } addWaypoints(waypoints: Waypoint[]) { // this._throwErrorIfMissionBuilt(); - this.waypoints = [...this.waypoints, ...waypoints]; + this.parameters.waypoints = [...this.parameters.waypoints, ...waypoints]; } removeWaypoint() { // this._throwErrorIfMissionBuilt(); - this.waypoints.pop(); + this.parameters.waypoints.pop(); } removeWaypointAtIndex(index: number) { // this._throwErrorIfMissionBuilt(); - this.waypoints.splice(index, 1); + this.parameters.waypoints.splice(index, 1); } removeAllWaypoints() { // this._throwErrorIfMissionBuilt(); - this.waypoints = []; + this.parameters.waypoints = []; } setAutoFlightSpeed(autoFlightSpeed: number) { - const maxFlightSpeed = this.maxFlightSpeed; + const maxFlightSpeed = this.parameters.maxFlightSpeed; if (autoFlightSpeed > maxFlightSpeed) { throw Error( 'Invalid Auto Flight Speed: Received auto flight speed is invalid as it cannot be greater than ' + `the set max flight speed of ${maxFlightSpeed} m/s.` ); } else { - this.autoFlightSpeed = autoFlightSpeed; + this.parameters.autoFlightSpeed = autoFlightSpeed; } } setMaxFlightSpeed(maxFlightSpeed: number) { - const autoFlightSpeed = this.autoFlightSpeed; + const autoFlightSpeed = this.parameters.autoFlightSpeed; if (maxFlightSpeed < autoFlightSpeed) { throw Error( 'Invalid Max Flight Speed: Received max flight speed is invalid as it cannot be less than ' + `the set auto flight speed of ${autoFlightSpeed} m/s.` ); } else { - this.maxFlightSpeed = maxFlightSpeed; + this.parameters.maxFlightSpeed = maxFlightSpeed; } } @@ -152,7 +150,7 @@ class WaypointMissionTimelineElement extends CustomTimelineElement { `Invalid headingMode ${headingMode}, make sure it is one of ${VALID_HEADING_MODES}` ); } else { - this.headingMode = headingMode; + this.parameters.headingMode = headingMode; } } diff --git a/lib/DJIMissionControl/index.js b/lib/DJIMissionControl/index.ts similarity index 94% rename from lib/DJIMissionControl/index.js rename to lib/DJIMissionControl/index.ts index 324b2f64..81c7476a 100644 --- a/lib/DJIMissionControl/index.js +++ b/lib/DJIMissionControl/index.ts @@ -1,20 +1,13 @@ -// @flow strict - import { NativeModules, } from 'react-native'; -import type { - CreateWaypointMissionParameters, - Waypoint, -} from './DJIMissionControlTypes'; - import { DJIEventSubject, } from '../utilities'; import { - type Observer, + Subscription, } from 'rxjs'; import { @@ -116,7 +109,7 @@ export const getCallbackFuncId = () => { return callbackFuncIdIncrementor++; }; -DJIEventSubject.subscribe(evt => { +DJIEventSubject.subscribe((evt: any) => { if (evt.type === 'RunJSElementEvent') { const { callbackFuncId, @@ -151,7 +144,8 @@ const DJIMissionControl = { elementName, } = element; const elementParameters = element.getElementParameters(); - + //FIXME: typing of CustomTimelineElement which is being used as an abstract class + //@ts-ignore if (elementName && elementParameters) { // This will return a rejected promise if the element is invalid, causing this function to return a rejected promise @@ -168,6 +162,8 @@ const DJIMissionControl = { throw Error( 'Missing Element Name: Element missing "elementName" parameter. Elements must have unique ' + 'elementName string.'); + //FIXME: typing of CustomTimelineElement which is being used as an abstract class + //@ts-ignore } else if (!elementParameters) { throw Error( 'Missing Element Parameters: getElementParameters returns undefined. Elements must have valid parameters for correct ' @@ -193,10 +189,10 @@ const DJIMissionControl = { }, stopTimeline: async () => { - let timelineObserver: Observer; + let timelineObserver: Subscription; try { - await new Promise(async (resolve, reject) => { + await new Promise(async (resolve, reject) => { const timeoutId = setTimeout(() => { // Fail after a set timeout period reject(); @@ -234,6 +230,10 @@ const DJIMissionControl = { await DJIMissionControlWrapper.startGoHome(); }, + cancelGoHome: async () => { + await DJIMissionControlWrapper.cancelGoHome(); + }, + startTimelineListener: async () => { await DJIMissionControlWrapper.startTimelineListener(); // TODO: (Adam) need to change eventType (int value) to a readable string value @@ -255,7 +255,7 @@ const DJIMissionControl = { } return updatedEvent; }) - ).asObservable(); + ); }, // TODO: (Adam) should this be stopAllTimelineListeners ? diff --git a/lib/utilities/index.js b/lib/utilities/index.js deleted file mode 100644 index 1c08dfc4..00000000 --- a/lib/utilities/index.js +++ /dev/null @@ -1,17 +0,0 @@ -// @flow strict - -import { - Subject, -} from 'rxjs'; - -import PlatformEventEmitter from './platformEventEmitter'; - -const DJIEventSubject = new Subject(); - -PlatformEventEmitter.addListener('DJIEvent', evt => { - DJIEventSubject.next(evt); -}); - -export { - DJIEventSubject, -}; diff --git a/lib/utilities/index.ts b/lib/utilities/index.ts new file mode 100644 index 00000000..da9e8432 --- /dev/null +++ b/lib/utilities/index.ts @@ -0,0 +1,25 @@ +// @flow strict + +import { + Observable, + Subject, +} from 'rxjs'; + +import PlatformEventEmitter from './platformEventEmitter'; +import { DJIEvent } from '../../types'; +import { filter as $filter, map as $map } from 'rxjs/operators'; + +const DJIEventSubject: Subject = new Subject(); + +PlatformEventEmitter.addListener('DJIEvent', evt => { + DJIEventSubject.next(evt); +}); + +const observeEvent = (eventName: string): Observable => { + return DJIEventSubject.pipe($filter(evt => evt.type === eventName), $map(evt => evt.value)); +} + +export { + DJIEventSubject, + observeEvent, +}; diff --git a/lib/utilities/parseExposureSettings.ts b/lib/utilities/parseExposureSettings.ts new file mode 100644 index 00000000..758f6dd1 --- /dev/null +++ b/lib/utilities/parseExposureSettings.ts @@ -0,0 +1,22 @@ +import { CameraExposureSettings } from '../../types'; +import { + ExposureCompensationValues, + exposureCompensationValues, +} from '../CameraControl'; + +export const parseExposureSettings = (settings: CameraExposureSettings) => { + const newExposureValueString = Object.keys(exposureCompensationValues).find( + key => + exposureCompensationValues[key as ExposureCompensationValues] === + `${settings.exposureValue}`, + ); + const exposureValue = + newExposureValueString == null + ? undefined + : parseFloat(newExposureValueString); + + return { + ...settings, + exposureValue, + }; +}; diff --git a/lib/utilities/platformEventEmitter.ios.js b/lib/utilities/platformEventEmitter.ios.ts similarity index 92% rename from lib/utilities/platformEventEmitter.ios.js rename to lib/utilities/platformEventEmitter.ios.ts index d1a9f968..70ca1a3b 100644 --- a/lib/utilities/platformEventEmitter.ios.js +++ b/lib/utilities/platformEventEmitter.ios.ts @@ -1,5 +1,3 @@ -// @flow strict - import { NativeModules, NativeEventEmitter, diff --git a/lib/utilities/platformEventEmitter.android.js b/lib/utilities/platformEventEmitter.ts similarity index 100% rename from lib/utilities/platformEventEmitter.android.js rename to lib/utilities/platformEventEmitter.ts diff --git a/lib/utilities/swapKeysAndValues.ts b/lib/utilities/swapKeysAndValues.ts new file mode 100644 index 00000000..70acd72d --- /dev/null +++ b/lib/utilities/swapKeysAndValues.ts @@ -0,0 +1,10 @@ +interface Object { + [key: string]: string +} + +export const swapKeysAndValues = (obj: T): Object => { + const swapped = Object.entries(obj).map( + ([key, value]) => [value, key] + ); + return Object.fromEntries(swapped); +} diff --git a/package-lock.json b/package-lock.json index 86bb5cc1..4b4fcada 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,28 +1,7730 @@ { "name": "react-native-dji-mobile", "version": "0.3.17", - "lockfileVersion": 1, + "lockfileVersion": 2, "requires": true, + "packages": { + "": { + "name": "react-native-dji-mobile", + "version": "0.3.17", + "license": "MIT", + "devDependencies": { + "@types/react-native": "^0.69.1", + "chokidar": "^3.1.1", + "react": "^17.0.2", + "react-native": "^0.66.4", + "typescript": "^4.6.2" + }, + "peerDependencies": { + "react": "^17.0.2", + "react-native": "^0.66.4", + "rxjs": ">=7.0.0" + } + }, + "node_modules/@babel/code-frame": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", + "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", + "dev": true, + "dependencies": { + "@babel/highlight": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/compat-data": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.18.6.tgz", + "integrity": "sha512-tzulrgDT0QD6U7BJ4TKVk2SDDg7wlP39P9yAx1RfLy7vP/7rsDRlWVfbWxElslu56+r7QOhB2NSDsabYYruoZQ==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/core": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/code-frame": "^7.16.7", + "@babel/generator": "^7.16.7", + "@babel/helper-compilation-targets": "^7.16.7", + "@babel/helper-module-transforms": "^7.16.7", + "@babel/helpers": "^7.16.7", + "@babel/parser": "^7.16.7", + "@babel/template": "^7.16.7", + "@babel/traverse": "^7.16.7", + "@babel/types": "^7.16.7", + "convert-source-map": "^1.7.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.1.2", + "semver": "^6.3.0", + "source-map": "^0.5.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/babel" + } + }, + "node_modules/@babel/core/node_modules/debug": { + "version": "4.3.3", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@babel/core/node_modules/ms": { + "version": "2.1.2", + "dev": true, + "license": "MIT" + }, + "node_modules/@babel/core/node_modules/source-map": { + "version": "0.5.7", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/@babel/generator": { + "version": "7.18.7", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.18.7.tgz", + "integrity": "sha512-shck+7VLlY72a2w9c3zYWuE1pwOKEiQHV7GTUbSnhyl5eu3i04t30tBY82ZRWrDfo3gkakCFtevExnxbkf2a3A==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.7", + "@jridgewell/gen-mapping": "^0.3.2", + "jsesc": "^2.5.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-annotate-as-pure": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz", + "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-builder-binary-assignment-operator-visitor": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.6.tgz", + "integrity": "sha512-KT10c1oWEpmrIRYnthbzHgoOf6B+Xd6a5yhdbNtdhtG7aO1or5HViuf1TQR36xY/QprXA5nvxO6nAjhJ4y38jw==", + "dev": true, + "dependencies": { + "@babel/helper-explode-assignable-expression": "^7.18.6", + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-compilation-targets": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.18.6.tgz", + "integrity": "sha512-vFjbfhNCzqdeAtZflUFrG5YIFqGTqsctrtkZ1D/NB0mDW9TwW3GmmUepYY4G9wCET5rY5ugz4OGTcLd614IzQg==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.18.6", + "@babel/helper-validator-option": "^7.18.6", + "browserslist": "^4.20.2", + "semver": "^6.3.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-create-class-features-plugin": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.18.6.tgz", + "integrity": "sha512-YfDzdnoxHGV8CzqHGyCbFvXg5QESPFkXlHtvdCkesLjjVMT2Adxe4FGUR5ChIb3DxSaXO12iIOCWoXdsUVwnqw==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-function-name": "^7.18.6", + "@babel/helper-member-expression-to-functions": "^7.18.6", + "@babel/helper-optimise-call-expression": "^7.18.6", + "@babel/helper-replace-supers": "^7.18.6", + "@babel/helper-split-export-declaration": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-create-regexp-features-plugin": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.18.6.tgz", + "integrity": "sha512-7LcpH1wnQLGrI+4v+nPp+zUvIkF9x0ddv1Hkdue10tg3gmRnLy97DXh4STiOf1qeIInyD69Qv5kKSZzKD8B/7A==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "regexpu-core": "^5.1.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-define-polyfill-provider": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.1.tgz", + "integrity": "sha512-J9hGMpJQmtWmj46B3kBHmL38UhJGhYX7eqkcq+2gsstyYt341HmPeWspihX43yVRA0mS+8GGk2Gckc7bY/HCmA==", + "dev": true, + "dependencies": { + "@babel/helper-compilation-targets": "^7.13.0", + "@babel/helper-module-imports": "^7.12.13", + "@babel/helper-plugin-utils": "^7.13.0", + "@babel/traverse": "^7.13.0", + "debug": "^4.1.1", + "lodash.debounce": "^4.0.8", + "resolve": "^1.14.2", + "semver": "^6.1.2" + }, + "peerDependencies": { + "@babel/core": "^7.4.0-0" + } + }, + "node_modules/@babel/helper-define-polyfill-provider/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@babel/helper-define-polyfill-provider/node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/@babel/helper-environment-visitor": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.6.tgz", + "integrity": "sha512-8n6gSfn2baOY+qlp+VSzsosjCVGFqWKmDF0cCWOybh52Dw3SEyoWR1KrhMJASjLwIEkkAufZ0xvr+SxLHSpy2Q==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-explode-assignable-expression": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz", + "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-function-name": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.18.6.tgz", + "integrity": "sha512-0mWMxV1aC97dhjCah5U5Ua7668r5ZmSC2DLfH2EZnf9c3/dHZKiFa5pRLMH5tjSl471tY6496ZWk/kjNONBxhw==", + "dev": true, + "dependencies": { + "@babel/template": "^7.18.6", + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-hoist-variables": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", + "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-member-expression-to-functions": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.18.6.tgz", + "integrity": "sha512-CeHxqwwipekotzPDUuJOfIMtcIHBuc7WAzLmTYWctVigqS5RktNMQ5bEwQSuGewzYnCtTWa3BARXeiLxDTv+Ng==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-imports": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz", + "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-transforms": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.18.6.tgz", + "integrity": "sha512-L//phhB4al5uucwzlimruukHB3jRd5JGClwRMD/ROrVjXfLqovYnvQrK/JK36WYyVwGGO7OD3kMyVTjx+WVPhw==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-module-imports": "^7.18.6", + "@babel/helper-simple-access": "^7.18.6", + "@babel/helper-split-export-declaration": "^7.18.6", + "@babel/helper-validator-identifier": "^7.18.6", + "@babel/template": "^7.18.6", + "@babel/traverse": "^7.18.6", + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-optimise-call-expression": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz", + "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-plugin-utils": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.18.6.tgz", + "integrity": "sha512-gvZnm1YAAxh13eJdkb9EWHBnF3eAub3XTLCZEehHT2kWxiKVRL64+ae5Y6Ivne0mVHmMYKT+xWgZO+gQhuLUBg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-remap-async-to-generator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.6.tgz", + "integrity": "sha512-z5wbmV55TveUPZlCLZvxWHtrjuJd+8inFhk7DG0WW87/oJuGDcjDiu7HIvGcpf5464L6xKCg3vNkmlVVz9hwyQ==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-wrap-function": "^7.18.6", + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-replace-supers": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.18.6.tgz", + "integrity": "sha512-fTf7zoXnUGl9gF25fXCWE26t7Tvtyn6H4hkLSYhATwJvw2uYxd3aoXplMSe0g9XbwK7bmxNes7+FGO0rB/xC0g==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-member-expression-to-functions": "^7.18.6", + "@babel/helper-optimise-call-expression": "^7.18.6", + "@babel/traverse": "^7.18.6", + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-simple-access": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz", + "integrity": "sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-skip-transparent-expression-wrappers": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.18.6.tgz", + "integrity": "sha512-4KoLhwGS9vGethZpAhYnMejWkX64wsnHPDwvOsKWU6Fg4+AlK2Jz3TyjQLMEPvz+1zemi/WBdkYxCD0bAfIkiw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-split-export-declaration": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", + "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", + "dev": true, + "dependencies": { + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-identifier": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz", + "integrity": "sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-option": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz", + "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-wrap-function": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.18.6.tgz", + "integrity": "sha512-I5/LZfozwMNbwr/b1vhhuYD+J/mU+gfGAj5td7l5Rv9WYmH6i3Om69WGKNmlIpsVW/mF6O5bvTKbvDQZVgjqOw==", + "dev": true, + "dependencies": { + "@babel/helper-function-name": "^7.18.6", + "@babel/template": "^7.18.6", + "@babel/traverse": "^7.18.6", + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helpers": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/template": "^7.16.7", + "@babel/traverse": "^7.16.7", + "@babel/types": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", + "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", + "dev": true, + "dependencies": { + "@babel/helper-validator-identifier": "^7.18.6", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight/node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/highlight/node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/highlight/node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/@babel/highlight/node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "node_modules/@babel/highlight/node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/highlight/node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/parser": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.18.6.tgz", + "integrity": "sha512-uQVSa9jJUe/G/304lXspfWVpKpK4euFLgGiMQFOCpM/bgcAdeoHwi/OQz23O9GK2osz26ZiXRRV9aV+Yl1O8tw==", + "dev": true, + "bin": { + "parser": "bin/babel-parser.js" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz", + "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.18.6.tgz", + "integrity": "sha512-Udgu8ZRgrBrttVz6A0EVL0SJ1z+RLbIeqsu632SA1hf0awEppD6TvdznoH+orIF8wtFFAV/Enmw9Y+9oV8TQcw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-skip-transparent-expression-wrappers": "^7.18.6", + "@babel/plugin-proposal-optional-chaining": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.13.0" + } + }, + "node_modules/@babel/plugin-proposal-async-generator-functions": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.18.6.tgz", + "integrity": "sha512-WAz4R9bvozx4qwf74M+sfqPMKfSqwM0phxPTR6iJIi8robgzXwkEgmeJG1gEKhm6sDqT/U9aV3lfcqybIpev8w==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-remap-async-to-generator": "^7.18.6", + "@babel/plugin-syntax-async-generators": "^7.8.4" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-class-properties": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz", + "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==", + "dev": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-class-static-block": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.18.6.tgz", + "integrity": "sha512-+I3oIiNxrCpup3Gi8n5IGMwj0gOCAjcJUSQEcotNnCCPMEnixawOQ+KeJPlgfjzx+FKQ1QSyZOWe7wmoJp7vhw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-class-static-block": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.12.0" + } + }, + "node_modules/@babel/plugin-proposal-dynamic-import": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz", + "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-dynamic-import": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-export-default-from": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7", + "@babel/plugin-syntax-export-default-from": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-export-namespace-from": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.6.tgz", + "integrity": "sha512-zr/QcUlUo7GPo6+X1wC98NJADqmy5QTFWWhqeQWiki4XHafJtLl/YMGkmRB2szDD2IYJCCdBTd4ElwhId9T7Xw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-json-strings": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz", + "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-json-strings": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-logical-assignment-operators": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.18.6.tgz", + "integrity": "sha512-zMo66azZth/0tVd7gmkxOkOjs2rpHyhpcFo565PUP37hSp6hSd9uUKIfTDFMz58BwqgQKhJ9YxtM5XddjXVn+Q==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-nullish-coalescing-operator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz", + "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-numeric-separator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz", + "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-numeric-separator": "^7.10.4" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-object-rest-spread": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.18.6.tgz", + "integrity": "sha512-9yuM6wr4rIsKa1wlUAbZEazkCrgw2sMPEXCr4Rnwetu7cEW1NydkCWytLuYletbf8vFxdJxFhwEZqMpOx2eZyw==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.18.6", + "@babel/helper-compilation-targets": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-transform-parameters": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-optional-catch-binding": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz", + "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-optional-chaining": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.18.6.tgz", + "integrity": "sha512-PatI6elL5eMzoypFAiYDpYQyMtXTn+iMhuxxQt5mAXD4fEmKorpSI3PHd+i3JXBJN3xyA6MvJv7at23HffFHwA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-skip-transparent-expression-wrappers": "^7.18.6", + "@babel/plugin-syntax-optional-chaining": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-private-methods": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz", + "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-private-property-in-object": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.18.6.tgz", + "integrity": "sha512-9Rysx7FOctvT5ouj5JODjAFAkgGoudQuLPamZb0v1TGLpapdNaftzifU8NTWQm0IRjqoYypdrSmyWgkocDQ8Dw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-unicode-property-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz", + "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-class-properties": { + "version": "7.12.13", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.12.13" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", + "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-dynamic-import": { + "version": "7.8.3", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-export-default-from": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-export-namespace-from": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz", + "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.3" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-flow": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-assertions": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.18.6.tgz", + "integrity": "sha512-/DU3RXad9+bZwrgWJQKbr39gYbJpLJHezqEzRzi/BHRlJ9zsQb4CK2CA/5apllXNomwA1qHwzvHl+AdEmC5krQ==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-jsx": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", + "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-typescript": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-arrow-functions": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.18.6.tgz", + "integrity": "sha512-9S9X9RUefzrsHZmKMbDXxweEH+YlE8JJEuat9FdvW9Qh1cw7W64jELCtWNkPBPX5En45uy28KGvA/AySqUh8CQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-async-to-generator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.18.6.tgz", + "integrity": "sha512-ARE5wZLKnTgPW7/1ftQmSi1CmkqqHo2DNmtztFhvgtOWSDfq0Cq9/9L+KnZNYSNrydBekhW3rwShduf59RoXag==", + "dev": true, + "dependencies": { + "@babel/helper-module-imports": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-remap-async-to-generator": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-block-scoped-functions": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz", + "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-block-scoping": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.18.6.tgz", + "integrity": "sha512-pRqwb91C42vs1ahSAWJkxOxU1RHWDn16XAa6ggQ72wjLlWyYeAcLvTtE0aM8ph3KNydy9CQF2nLYcjq1WysgxQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-classes": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.18.6.tgz", + "integrity": "sha512-XTg8XW/mKpzAF3actL554Jl/dOYoJtv3l8fxaEczpgz84IeeVf+T1u2CSvPHuZbt0w3JkIx4rdn/MRQI7mo0HQ==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-function-name": "^7.18.6", + "@babel/helper-optimise-call-expression": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-replace-supers": "^7.18.6", + "@babel/helper-split-export-declaration": "^7.18.6", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-computed-properties": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.18.6.tgz", + "integrity": "sha512-9repI4BhNrR0KenoR9vm3/cIc1tSBIo+u1WVjKCAynahj25O8zfbiE6JtAtHPGQSs4yZ+bA8mRasRP+qc+2R5A==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-destructuring": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.18.6.tgz", + "integrity": "sha512-tgy3u6lRp17ilY8r1kP4i2+HDUwxlVqq3RTc943eAWSzGgpU1qhiKpqZ5CMyHReIYPHdo3Kg8v8edKtDqSVEyQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-dotall-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz", + "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-duplicate-keys": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.6.tgz", + "integrity": "sha512-NJU26U/208+sxYszf82nmGYqVF9QN8py2HFTblPT9hbawi8+1C5a9JubODLTGFuT0qlkqVinmkwOD13s0sZktg==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-exponentiation-operator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz", + "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==", + "dev": true, + "dependencies": { + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-flow-strip-types": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7", + "@babel/plugin-syntax-flow": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-for-of": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.6.tgz", + "integrity": "sha512-WAjoMf4wIiSsy88KmG7tgj2nFdEK7E46tArVtcgED7Bkj6Fg/tG5SbvNIOKxbFS2VFgNh6+iaPswBeQZm4ox8w==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-function-name": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.6.tgz", + "integrity": "sha512-kJha/Gbs5RjzIu0CxZwf5e3aTTSlhZnHMT8zPWnJMjNpLOUgqevg+PN5oMH68nMCXnfiMo4Bhgxqj59KHTlAnA==", + "dev": true, + "dependencies": { + "@babel/helper-compilation-targets": "^7.18.6", + "@babel/helper-function-name": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-literals": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.6.tgz", + "integrity": "sha512-x3HEw0cJZVDoENXOp20HlypIHfl0zMIhMVZEBVTfmqbObIpsMxMbmU5nOEO8R7LYT+z5RORKPlTI5Hj4OsO9/Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-member-expression-literals": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz", + "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-amd": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.18.6.tgz", + "integrity": "sha512-Pra5aXsmTsOnjM3IajS8rTaLCy++nGM4v3YR4esk5PCsyg9z8NA5oQLwxzMUtDBd8F+UmVza3VxoAaWCbzH1rg==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-module-transforms": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "babel-plugin-dynamic-import-node": "^2.3.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-commonjs": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.18.6.tgz", + "integrity": "sha512-Qfv2ZOWikpvmedXQJDSbxNqy7Xr/j2Y8/KfijM0iJyKkBTmWuvCA1yeH1yDM7NJhBW/2aXxeucLj6i80/LAJ/Q==", + "dev": true, + "dependencies": { + "@babel/helper-module-transforms": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-simple-access": "^7.18.6", + "babel-plugin-dynamic-import-node": "^2.3.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-systemjs": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.18.6.tgz", + "integrity": "sha512-UbPYpXxLjTw6w6yXX2BYNxF3p6QY225wcTkfQCy3OMnSlS/C3xGtwUjEzGkldb/sy6PWLiCQ3NbYfjWUTI3t4g==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-hoist-variables": "^7.18.6", + "@babel/helper-module-transforms": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-validator-identifier": "^7.18.6", + "babel-plugin-dynamic-import-node": "^2.3.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-umd": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz", + "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-module-transforms": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.18.6.tgz", + "integrity": "sha512-UmEOGF8XgaIqD74bC8g7iV3RYj8lMf0Bw7NJzvnS9qQhM4mg+1WHKotUIdjxgD2RGrgFLZZPCFPFj3P/kVDYhg==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-transform-new-target": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz", + "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-object-assign": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-object-super": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz", + "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-replace-supers": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-parameters": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.18.6.tgz", + "integrity": "sha512-FjdqgMv37yVl/gwvzkcB+wfjRI8HQmc5EgOG9iGNvUY1ok+TjsoaMP7IqCDZBhkFcM5f3OPVMs6Dmp03C5k4/A==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-property-literals": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz", + "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-react-display-name": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-react-jsx": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.16.7", + "@babel/helper-module-imports": "^7.16.7", + "@babel/helper-plugin-utils": "^7.16.7", + "@babel/plugin-syntax-jsx": "^7.16.7", + "@babel/types": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-react-jsx-self": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-react-jsx-source": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-regenerator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.18.6.tgz", + "integrity": "sha512-poqRI2+qiSdeldcz4wTSTXBRryoq3Gc70ye7m7UD5Ww0nE29IXqMl6r7Nd15WBgRd74vloEMlShtH6CKxVzfmQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "regenerator-transform": "^0.15.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-reserved-words": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz", + "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-runtime": { + "version": "7.16.8", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-module-imports": "^7.16.7", + "@babel/helper-plugin-utils": "^7.16.7", + "babel-plugin-polyfill-corejs2": "^0.3.0", + "babel-plugin-polyfill-corejs3": "^0.5.0", + "babel-plugin-polyfill-regenerator": "^0.3.0", + "semver": "^6.3.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-shorthand-properties": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz", + "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-spread": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.18.6.tgz", + "integrity": "sha512-ayT53rT/ENF8WWexIRg9AiV9h0aIteyWn5ptfZTZQrjk/+f3WdrJGCY4c9wcgl2+MKkKPhzbYp97FTsquZpDCw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-skip-transparent-expression-wrappers": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-sticky-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz", + "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-template-literals": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.6.tgz", + "integrity": "sha512-UuqlRrQmT2SWRvahW46cGSany0uTlcj8NYOS5sRGYi8FxPYPoLd5DDmMd32ZXEj2Jq+06uGVQKHxa/hJx2EzKw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-typeof-symbol": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.6.tgz", + "integrity": "sha512-7m71iS/QhsPk85xSjFPovHPcH3H9qeyzsujhTc+vcdnsXavoWYJ74zx0lP5RhpC5+iDnVLO+PPMHzC11qels1g==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-typescript": { + "version": "7.16.8", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.16.7", + "@babel/helper-plugin-utils": "^7.16.7", + "@babel/plugin-syntax-typescript": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-escapes": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.6.tgz", + "integrity": "sha512-XNRwQUXYMP7VLuy54cr/KS/WeL3AZeORhrmeZ7iewgu+X2eBqmpaLI/hzqr9ZxCeUoq0ASK4GUzSM0BDhZkLFw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz", + "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/preset-env": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.18.6.tgz", + "integrity": "sha512-WrthhuIIYKrEFAwttYzgRNQ5hULGmwTj+D6l7Zdfsv5M7IWV/OZbUfbeL++Qrzx1nVJwWROIFhCHRYQV4xbPNw==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/compat-data": "^7.18.6", + "@babel/helper-compilation-targets": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-validator-option": "^7.18.6", + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.6", + "@babel/plugin-proposal-async-generator-functions": "^7.18.6", + "@babel/plugin-proposal-class-properties": "^7.18.6", + "@babel/plugin-proposal-class-static-block": "^7.18.6", + "@babel/plugin-proposal-dynamic-import": "^7.18.6", + "@babel/plugin-proposal-export-namespace-from": "^7.18.6", + "@babel/plugin-proposal-json-strings": "^7.18.6", + "@babel/plugin-proposal-logical-assignment-operators": "^7.18.6", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6", + "@babel/plugin-proposal-numeric-separator": "^7.18.6", + "@babel/plugin-proposal-object-rest-spread": "^7.18.6", + "@babel/plugin-proposal-optional-catch-binding": "^7.18.6", + "@babel/plugin-proposal-optional-chaining": "^7.18.6", + "@babel/plugin-proposal-private-methods": "^7.18.6", + "@babel/plugin-proposal-private-property-in-object": "^7.18.6", + "@babel/plugin-proposal-unicode-property-regex": "^7.18.6", + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-class-properties": "^7.12.13", + "@babel/plugin-syntax-class-static-block": "^7.14.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3", + "@babel/plugin-syntax-import-assertions": "^7.18.6", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.10.4", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5", + "@babel/plugin-syntax-top-level-await": "^7.14.5", + "@babel/plugin-transform-arrow-functions": "^7.18.6", + "@babel/plugin-transform-async-to-generator": "^7.18.6", + "@babel/plugin-transform-block-scoped-functions": "^7.18.6", + "@babel/plugin-transform-block-scoping": "^7.18.6", + "@babel/plugin-transform-classes": "^7.18.6", + "@babel/plugin-transform-computed-properties": "^7.18.6", + "@babel/plugin-transform-destructuring": "^7.18.6", + "@babel/plugin-transform-dotall-regex": "^7.18.6", + "@babel/plugin-transform-duplicate-keys": "^7.18.6", + "@babel/plugin-transform-exponentiation-operator": "^7.18.6", + "@babel/plugin-transform-for-of": "^7.18.6", + "@babel/plugin-transform-function-name": "^7.18.6", + "@babel/plugin-transform-literals": "^7.18.6", + "@babel/plugin-transform-member-expression-literals": "^7.18.6", + "@babel/plugin-transform-modules-amd": "^7.18.6", + "@babel/plugin-transform-modules-commonjs": "^7.18.6", + "@babel/plugin-transform-modules-systemjs": "^7.18.6", + "@babel/plugin-transform-modules-umd": "^7.18.6", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.18.6", + "@babel/plugin-transform-new-target": "^7.18.6", + "@babel/plugin-transform-object-super": "^7.18.6", + "@babel/plugin-transform-parameters": "^7.18.6", + "@babel/plugin-transform-property-literals": "^7.18.6", + "@babel/plugin-transform-regenerator": "^7.18.6", + "@babel/plugin-transform-reserved-words": "^7.18.6", + "@babel/plugin-transform-shorthand-properties": "^7.18.6", + "@babel/plugin-transform-spread": "^7.18.6", + "@babel/plugin-transform-sticky-regex": "^7.18.6", + "@babel/plugin-transform-template-literals": "^7.18.6", + "@babel/plugin-transform-typeof-symbol": "^7.18.6", + "@babel/plugin-transform-unicode-escapes": "^7.18.6", + "@babel/plugin-transform-unicode-regex": "^7.18.6", + "@babel/preset-modules": "^0.1.5", + "@babel/types": "^7.18.6", + "babel-plugin-polyfill-corejs2": "^0.3.1", + "babel-plugin-polyfill-corejs3": "^0.5.2", + "babel-plugin-polyfill-regenerator": "^0.3.1", + "core-js-compat": "^3.22.1", + "semver": "^6.3.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/preset-flow": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7", + "@babel/helper-validator-option": "^7.16.7", + "@babel/plugin-transform-flow-strip-types": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/preset-modules": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz", + "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==", + "dev": true, + "peer": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-proposal-unicode-property-regex": "^7.4.4", + "@babel/plugin-transform-dotall-regex": "^7.4.4", + "@babel/types": "^7.4.4", + "esutils": "^2.0.2" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/preset-typescript": { + "version": "7.16.7", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7", + "@babel/helper-validator-option": "^7.16.7", + "@babel/plugin-transform-typescript": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/register": { + "version": "7.16.9", + "dev": true, + "license": "MIT", + "dependencies": { + "clone-deep": "^4.0.1", + "find-cache-dir": "^2.0.0", + "make-dir": "^2.1.0", + "pirates": "^4.0.0", + "source-map-support": "^0.5.16" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/runtime": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.18.6.tgz", + "integrity": "sha512-t9wi7/AW6XtKahAe20Yw0/mMljKq0B1r2fPdvaAdV/KPDZewFXdaaa6K7lxmZBZ8FBNpCiAT6iHPmd6QO9bKfQ==", + "dev": true, + "dependencies": { + "regenerator-runtime": "^0.13.4" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/template": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.18.6.tgz", + "integrity": "sha512-JoDWzPe+wgBsTTgdnIma3iHNFC7YVJoPssVBDjiHfNlyt4YcunDtcDOUmfVDfCK5MfdsaIoX9PkijPhjH3nYUw==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.18.6", + "@babel/parser": "^7.18.6", + "@babel/types": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.18.6.tgz", + "integrity": "sha512-zS/OKyqmD7lslOtFqbscH6gMLFYOfG1YPqCKfAW5KrTeolKqvB8UelR49Fpr6y93kYkW2Ik00mT1LOGiAGvizw==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.18.6", + "@babel/generator": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-function-name": "^7.18.6", + "@babel/helper-hoist-variables": "^7.18.6", + "@babel/helper-split-export-declaration": "^7.18.6", + "@babel/parser": "^7.18.6", + "@babel/types": "^7.18.6", + "debug": "^4.1.0", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse/node_modules/debug": { + "version": "4.3.3", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@babel/traverse/node_modules/ms": { + "version": "2.1.2", + "dev": true, + "license": "MIT" + }, + "node_modules/@babel/types": { + "version": "7.18.7", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.18.7.tgz", + "integrity": "sha512-QG3yxTcTIBoAcQmkCs+wAPYZhu7Dk9rXKacINfNbdJDNERTbLQbHGyVG8q/YGMPeCJRIhSY0+fTc5+xuh6WPSQ==", + "dev": true, + "dependencies": { + "@babel/helper-validator-identifier": "^7.18.6", + "to-fast-properties": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@cnakazawa/watch": { + "version": "1.0.4", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "exec-sh": "^0.3.2", + "minimist": "^1.2.0" + }, + "bin": { + "watch": "cli.js" + }, + "engines": { + "node": ">=0.1.95" + } + }, + "node_modules/@hapi/hoek": { + "version": "9.2.1", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/@hapi/topo": { + "version": "5.1.0", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "@hapi/hoek": "^9.0.0" + } + }, + "node_modules/@jest/create-cache-key-function": { + "version": "27.4.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@jest/types": "^27.4.2" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/types": { + "version": "27.4.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^3.0.0", + "@types/node": "*", + "@types/yargs": "^16.0.0", + "chalk": "^4.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", + "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", + "dev": true, + "dependencies": { + "@jridgewell/set-array": "^1.0.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.9" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.0.8", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.0.8.tgz", + "integrity": "sha512-YK5G9LaddzGbcucK4c8h5tWFmMPBvRZ/uyWmN1/SbBdIvqGUdWGkJ5BAaccgs6XbzVLsqbPJrBSFwKv3kT9i7w==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", + "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.4.14", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", + "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", + "dev": true + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.14", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz", + "integrity": "sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ==", + "dev": true, + "dependencies": { + "@jridgewell/resolve-uri": "^3.0.3", + "@jridgewell/sourcemap-codec": "^1.4.10" + } + }, + "node_modules/@react-native-community/cli-debugger-ui": { + "version": "6.0.0-rc.0", + "dev": true, + "license": "MIT", + "dependencies": { + "serve-static": "^1.13.1" + } + }, + "node_modules/@react-native-community/cli-hermes": { + "version": "6.3.0", + "dev": true, + "license": "MIT", + "dependencies": { + "@react-native-community/cli-platform-android": "^6.3.0", + "@react-native-community/cli-tools": "^6.2.0", + "chalk": "^4.1.2", + "hermes-profile-transformer": "^0.0.6", + "ip": "^1.1.5" + } + }, + "node_modules/@react-native-community/cli-platform-android": { + "version": "6.3.0", + "dev": true, + "license": "MIT", + "dependencies": { + "@react-native-community/cli-tools": "^6.2.0", + "chalk": "^4.1.2", + "execa": "^1.0.0", + "fs-extra": "^8.1.0", + "glob": "^7.1.3", + "jetifier": "^1.6.2", + "lodash": "^4.17.15", + "logkitty": "^0.7.1", + "slash": "^3.0.0", + "xmldoc": "^1.1.2" + } + }, + "node_modules/@react-native-community/cli-platform-ios": { + "version": "6.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "@react-native-community/cli-tools": "^6.2.0", + "chalk": "^4.1.2", + "glob": "^7.1.3", + "js-yaml": "^3.13.1", + "lodash": "^4.17.15", + "ora": "^3.4.0", + "plist": "^3.0.2", + "xcode": "^2.0.0" + } + }, + "node_modules/@react-native-community/cli-plugin-metro": { + "version": "6.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "@react-native-community/cli-server-api": "^6.2.0", + "@react-native-community/cli-tools": "^6.2.0", + "chalk": "^4.1.2", + "metro": "^0.66.1", + "metro-config": "^0.66.1", + "metro-core": "^0.66.1", + "metro-react-native-babel-transformer": "^0.66.1", + "metro-resolver": "^0.66.1", + "metro-runtime": "^0.66.1", + "readline": "^1.3.0" + } + }, + "node_modules/@react-native-community/cli-server-api": { + "version": "6.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "@react-native-community/cli-debugger-ui": "^6.0.0-rc.0", + "@react-native-community/cli-tools": "^6.2.0", + "compression": "^1.7.1", + "connect": "^3.6.5", + "errorhandler": "^1.5.0", + "nocache": "^2.1.0", + "pretty-format": "^26.6.2", + "serve-static": "^1.13.1", + "ws": "^1.1.0" + } + }, + "node_modules/@react-native-community/cli-server-api/node_modules/ws": { + "version": "1.1.5", + "dev": true, + "license": "MIT", + "dependencies": { + "options": ">=0.0.5", + "ultron": "1.0.x" + } + }, + "node_modules/@react-native-community/cli-tools": { + "version": "6.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "appdirsjs": "^1.2.4", + "chalk": "^4.1.2", + "lodash": "^4.17.15", + "mime": "^2.4.1", + "node-fetch": "^2.6.0", + "open": "^6.2.0", + "semver": "^6.3.0", + "shell-quote": "1.6.1" + } + }, + "node_modules/@react-native-community/cli-tools/node_modules/mime": { + "version": "2.6.0", + "dev": true, + "license": "MIT", + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/@react-native-community/cli-types": { + "version": "6.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "ora": "^3.4.0" + } + }, + "node_modules/@react-native/assets": { + "version": "1.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/@react-native/normalize-color": { + "version": "1.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/@react-native/polyfills": { + "version": "2.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/@sideway/address": { + "version": "4.1.3", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "@hapi/hoek": "^9.0.0" + } + }, + "node_modules/@sideway/formula": { + "version": "3.0.0", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/@sideway/pinpoint": { + "version": "2.0.0", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/@types/graceful-fs": { + "version": "4.1.5", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/istanbul-lib-coverage": { + "version": "2.0.4", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/istanbul-lib-report": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/istanbul-lib-coverage": "*" + } + }, + "node_modules/@types/istanbul-reports": { + "version": "3.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/istanbul-lib-report": "*" + } + }, + "node_modules/@types/node": { + "version": "17.0.8", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/prop-types": { + "version": "15.7.5", + "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.5.tgz", + "integrity": "sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==", + "dev": true + }, + "node_modules/@types/react": { + "version": "18.0.14", + "resolved": "https://registry.npmjs.org/@types/react/-/react-18.0.14.tgz", + "integrity": "sha512-x4gGuASSiWmo0xjDLpm5mPb52syZHJx02VKbqUKdLmKtAwIh63XClGsiTI1K6DO5q7ox4xAsQrU+Gl3+gGXF9Q==", + "dev": true, + "dependencies": { + "@types/prop-types": "*", + "@types/scheduler": "*", + "csstype": "^3.0.2" + } + }, + "node_modules/@types/react-native": { + "version": "0.69.2", + "resolved": "https://registry.npmjs.org/@types/react-native/-/react-native-0.69.2.tgz", + "integrity": "sha512-AVdWv4B8/++T5QQdnpveb2OVqD+0i8SOoT63ZRD+lNtQIYxzDak91V0k6olthy+H261d4t/MRBC1cfX1Rwsb6A==", + "dev": true, + "dependencies": { + "@types/react": "*" + } + }, + "node_modules/@types/scheduler": { + "version": "0.16.2", + "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", + "integrity": "sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew==", + "dev": true + }, + "node_modules/@types/yargs": { + "version": "16.0.4", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/yargs-parser": "*" + } + }, + "node_modules/@types/yargs-parser": { + "version": "20.2.1", + "dev": true, + "license": "MIT" + }, + "node_modules/abort-controller": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "event-target-shim": "^5.0.0" + }, + "engines": { + "node": ">=6.5" + } + }, + "node_modules/absolute-path": { + "version": "0.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/accepts": { + "version": "1.3.7", + "dev": true, + "license": "MIT", + "dependencies": { + "mime-types": "~2.1.24", + "negotiator": "0.6.2" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/anser": { + "version": "1.4.10", + "dev": true, + "license": "MIT" + }, + "node_modules/ansi-fragments": { + "version": "0.2.1", + "dev": true, + "license": "MIT", + "dependencies": { + "colorette": "^1.0.7", + "slice-ansi": "^2.0.0", + "strip-ansi": "^5.0.0" + } + }, + "node_modules/ansi-regex": { + "version": "4.1.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/ansi-styles": { + "version": "4.3.0", + "dev": true, + "license": "MIT", + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/anymatch": { + "version": "3.1.0", + "dev": true, + "license": "ISC", + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/appdirsjs": { + "version": "1.2.6", + "dev": true, + "license": "MIT" + }, + "node_modules/argparse": { + "version": "1.0.10", + "dev": true, + "license": "MIT", + "dependencies": { + "sprintf-js": "~1.0.2" + } + }, + "node_modules/arr-diff": { + "version": "4.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/arr-flatten": { + "version": "1.1.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/arr-union": { + "version": "3.1.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/array-filter": { + "version": "0.0.1", + "dev": true, + "license": "MIT" + }, + "node_modules/array-map": { + "version": "0.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/array-reduce": { + "version": "0.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/array-unique": { + "version": "0.3.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/asap": { + "version": "2.0.6", + "dev": true, + "license": "MIT" + }, + "node_modules/assign-symbols": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ast-types": { + "version": "0.14.2", + "dev": true, + "license": "MIT", + "dependencies": { + "tslib": "^2.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/astral-regex": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/async": { + "version": "2.6.3", + "dev": true, + "license": "MIT", + "dependencies": { + "lodash": "^4.17.14" + } + }, + "node_modules/async-limiter": { + "version": "1.0.1", + "dev": true, + "license": "MIT" + }, + "node_modules/atob": { + "version": "2.1.2", + "dev": true, + "license": "(MIT OR Apache-2.0)", + "bin": { + "atob": "bin/atob.js" + }, + "engines": { + "node": ">= 4.5.0" + } + }, + "node_modules/babel-core": { + "version": "7.0.0-bridge.0", + "dev": true, + "license": "MIT", + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/babel-plugin-dynamic-import-node": { + "version": "2.3.3", + "dev": true, + "license": "MIT", + "dependencies": { + "object.assign": "^4.1.0" + } + }, + "node_modules/babel-plugin-polyfill-corejs2": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.1.tgz", + "integrity": "sha512-v7/T6EQcNfVLfcN2X8Lulb7DjprieyLWJK/zOWH5DUYcAgex9sP3h25Q+DLsX9TloXe3y1O8l2q2Jv9q8UVB9w==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.13.11", + "@babel/helper-define-polyfill-provider": "^0.3.1", + "semver": "^6.1.1" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/babel-plugin-polyfill-corejs3": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.5.2.tgz", + "integrity": "sha512-G3uJih0XWiID451fpeFaYGVuxHEjzKTHtc9uGFEjR6hHrvNzeS/PX+LLLcetJcytsB5m4j+K3o/EpXJNb/5IEQ==", + "dev": true, + "dependencies": { + "@babel/helper-define-polyfill-provider": "^0.3.1", + "core-js-compat": "^3.21.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/babel-plugin-polyfill-regenerator": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.3.1.tgz", + "integrity": "sha512-Y2B06tvgHYt1x0yz17jGkGeeMr5FeKUu+ASJ+N6nB5lQ8Dapfg42i0OVrf8PNGJ3zKL4A23snMi1IRwrqqND7A==", + "dev": true, + "dependencies": { + "@babel/helper-define-polyfill-provider": "^0.3.1" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/babel-plugin-syntax-trailing-function-commas": { + "version": "7.0.0-beta.0", + "dev": true, + "license": "MIT" + }, + "node_modules/babel-preset-fbjs": { + "version": "3.4.0", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/plugin-proposal-class-properties": "^7.0.0", + "@babel/plugin-proposal-object-rest-spread": "^7.0.0", + "@babel/plugin-syntax-class-properties": "^7.0.0", + "@babel/plugin-syntax-flow": "^7.0.0", + "@babel/plugin-syntax-jsx": "^7.0.0", + "@babel/plugin-syntax-object-rest-spread": "^7.0.0", + "@babel/plugin-transform-arrow-functions": "^7.0.0", + "@babel/plugin-transform-block-scoped-functions": "^7.0.0", + "@babel/plugin-transform-block-scoping": "^7.0.0", + "@babel/plugin-transform-classes": "^7.0.0", + "@babel/plugin-transform-computed-properties": "^7.0.0", + "@babel/plugin-transform-destructuring": "^7.0.0", + "@babel/plugin-transform-flow-strip-types": "^7.0.0", + "@babel/plugin-transform-for-of": "^7.0.0", + "@babel/plugin-transform-function-name": "^7.0.0", + "@babel/plugin-transform-literals": "^7.0.0", + "@babel/plugin-transform-member-expression-literals": "^7.0.0", + "@babel/plugin-transform-modules-commonjs": "^7.0.0", + "@babel/plugin-transform-object-super": "^7.0.0", + "@babel/plugin-transform-parameters": "^7.0.0", + "@babel/plugin-transform-property-literals": "^7.0.0", + "@babel/plugin-transform-react-display-name": "^7.0.0", + "@babel/plugin-transform-react-jsx": "^7.0.0", + "@babel/plugin-transform-shorthand-properties": "^7.0.0", + "@babel/plugin-transform-spread": "^7.0.0", + "@babel/plugin-transform-template-literals": "^7.0.0", + "babel-plugin-syntax-trailing-function-commas": "^7.0.0-beta.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "dev": true, + "license": "MIT" + }, + "node_modules/base": { + "version": "0.11.2", + "dev": true, + "license": "MIT", + "dependencies": { + "cache-base": "^1.0.1", + "class-utils": "^0.3.5", + "component-emitter": "^1.2.1", + "define-property": "^1.0.0", + "isobject": "^3.0.1", + "mixin-deep": "^1.2.0", + "pascalcase": "^0.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/base/node_modules/define-property": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "is-descriptor": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/base/node_modules/is-accessor-descriptor": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^6.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/base/node_modules/is-data-descriptor": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^6.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/base/node_modules/is-descriptor": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/base64-js": { + "version": "1.5.1", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "MIT" + }, + "node_modules/big-integer": { + "version": "1.6.51", + "dev": true, + "license": "Unlicense", + "engines": { + "node": ">=0.6" + } + }, + "node_modules/binary-extensions": { + "version": "2.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/bplist-creator": { + "version": "0.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "stream-buffers": "2.2.x" + } + }, + "node_modules/bplist-parser": { + "version": "0.3.0", + "dev": true, + "license": "MIT", + "dependencies": { + "big-integer": "1.6.x" + }, + "engines": { + "node": ">= 5.10.0" + } + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/braces": { + "version": "3.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "fill-range": "^7.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/browserslist": { + "version": "4.21.1", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.1.tgz", + "integrity": "sha512-Nq8MFCSrnJXSc88yliwlzQe3qNe3VntIjhsArW9IJOEPSHNx23FalwApUVbzAWABLhYJJ7y8AynWI/XM8OdfjQ==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + } + ], + "dependencies": { + "caniuse-lite": "^1.0.30001359", + "electron-to-chromium": "^1.4.172", + "node-releases": "^2.0.5", + "update-browserslist-db": "^1.0.4" + }, + "bin": { + "browserslist": "cli.js" + }, + "engines": { + "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" + } + }, + "node_modules/bser": { + "version": "2.1.1", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "node-int64": "^0.4.0" + } + }, + "node_modules/buffer-from": { + "version": "1.1.2", + "dev": true, + "license": "MIT" + }, + "node_modules/bytes": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/cache-base": { + "version": "1.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "collection-visit": "^1.0.0", + "component-emitter": "^1.2.1", + "get-value": "^2.0.6", + "has-value": "^1.0.0", + "isobject": "^3.0.1", + "set-value": "^2.0.0", + "to-object-path": "^0.3.0", + "union-value": "^1.0.0", + "unset-value": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/call-bind": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/caller-callsite": { + "version": "2.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "callsites": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/caller-path": { + "version": "2.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "caller-callsite": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/callsites": { + "version": "2.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/camelcase": { + "version": "5.3.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/caniuse-lite": { + "version": "1.0.30001363", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001363.tgz", + "integrity": "sha512-HpQhpzTGGPVMnCjIomjt+jvyUu8vNFo3TaDiZ/RcoTrlOq/5+tC8zHdsbgFB6MxmaY+jCpsH09aD80Bb4Ow3Sg==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/caniuse-lite" + } + ] + }, + "node_modules/capture-exit": { + "version": "2.0.0", + "dev": true, + "license": "ISC", + "dependencies": { + "rsvp": "^4.8.4" + }, + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/chalk": { + "version": "4.1.2", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/chokidar": { + "version": "3.1.1", + "dev": true, + "license": "MIT", + "dependencies": { + "anymatch": "^3.1.0", + "braces": "^3.0.2", + "glob-parent": "^5.0.0", + "is-binary-path": "^2.1.0", + "is-glob": "^4.0.1", + "normalize-path": "^3.0.0", + "readdirp": "^3.1.1" + }, + "engines": { + "node": ">= 8" + }, + "optionalDependencies": { + "fsevents": "^2.0.6" + } + }, + "node_modules/ci-info": { + "version": "2.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/class-utils": { + "version": "0.3.6", + "dev": true, + "license": "MIT", + "dependencies": { + "arr-union": "^3.1.0", + "define-property": "^0.2.5", + "isobject": "^3.0.0", + "static-extend": "^0.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/class-utils/node_modules/define-property": { + "version": "0.2.5", + "dev": true, + "license": "MIT", + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/cli-cursor": { + "version": "2.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "restore-cursor": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/cli-spinners": { + "version": "2.6.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/cliui": { + "version": "6.0.0", + "dev": true, + "license": "ISC", + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^6.2.0" + } + }, + "node_modules/cliui/node_modules/ansi-regex": { + "version": "5.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/strip-ansi": { + "version": "6.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/clone": { + "version": "1.0.4", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.8" + } + }, + "node_modules/clone-deep": { + "version": "4.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-plain-object": "^2.0.4", + "kind-of": "^6.0.2", + "shallow-clone": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/collection-visit": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "map-visit": "^1.0.0", + "object-visit": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/color-convert": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/color-name": { + "version": "1.1.4", + "dev": true, + "license": "MIT" + }, + "node_modules/colorette": { + "version": "1.4.0", + "dev": true, + "license": "MIT" + }, + "node_modules/colors": { + "version": "1.4.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.1.90" + } + }, + "node_modules/command-exists": { + "version": "1.2.9", + "dev": true, + "license": "MIT" + }, + "node_modules/commander": { + "version": "2.20.3", + "dev": true, + "license": "MIT" + }, + "node_modules/commondir": { + "version": "1.0.1", + "dev": true, + "license": "MIT" + }, + "node_modules/component-emitter": { + "version": "1.3.0", + "dev": true, + "license": "MIT" + }, + "node_modules/compressible": { + "version": "2.0.18", + "dev": true, + "license": "MIT", + "dependencies": { + "mime-db": ">= 1.43.0 < 2" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/compression": { + "version": "1.7.4", + "dev": true, + "license": "MIT", + "dependencies": { + "accepts": "~1.3.5", + "bytes": "3.0.0", + "compressible": "~2.0.16", + "debug": "2.6.9", + "on-headers": "~1.0.2", + "safe-buffer": "5.1.2", + "vary": "~1.1.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/concat-map": { + "version": "0.0.1", + "dev": true, + "license": "MIT" + }, + "node_modules/connect": { + "version": "3.7.0", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "2.6.9", + "finalhandler": "1.1.2", + "parseurl": "~1.3.3", + "utils-merge": "1.0.1" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/convert-source-map": { + "version": "1.8.0", + "dev": true, + "license": "MIT", + "dependencies": { + "safe-buffer": "~5.1.1" + } + }, + "node_modules/copy-descriptor": { + "version": "0.1.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/core-js-compat": { + "version": "3.23.3", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.23.3.tgz", + "integrity": "sha512-WSzUs2h2vvmKsacLHNTdpyOC9k43AEhcGoFlVgCY4L7aw98oSBKtPL6vD0/TqZjRWRQYdDSLkzZIni4Crbbiqw==", + "dev": true, + "dependencies": { + "browserslist": "^4.21.0", + "semver": "7.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/core-js" + } + }, + "node_modules/core-js-compat/node_modules/semver": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", + "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/core-util-is": { + "version": "1.0.3", + "dev": true, + "license": "MIT" + }, + "node_modules/cosmiconfig": { + "version": "5.2.1", + "dev": true, + "license": "MIT", + "dependencies": { + "import-fresh": "^2.0.0", + "is-directory": "^0.3.1", + "js-yaml": "^3.13.1", + "parse-json": "^4.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/cross-spawn": { + "version": "6.0.5", + "dev": true, + "license": "MIT", + "dependencies": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + }, + "engines": { + "node": ">=4.8" + } + }, + "node_modules/cross-spawn/node_modules/semver": { + "version": "5.7.1", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/csstype": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.0.tgz", + "integrity": "sha512-uX1KG+x9h5hIJsaKR9xHUeUraxf8IODOwq9JLNPq6BwB04a/xgpq3rcx47l5BZu5zBPlgD342tdke3Hom/nJRA==", + "dev": true + }, + "node_modules/dayjs": { + "version": "1.10.7", + "dev": true, + "license": "MIT" + }, + "node_modules/debug": { + "version": "2.6.9", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/debug/node_modules/ms": { + "version": "2.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/decamelize": { + "version": "1.2.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/decode-uri-component": { + "version": "0.2.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10" + } + }, + "node_modules/deepmerge": { + "version": "3.3.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/defaults": { + "version": "1.0.3", + "dev": true, + "license": "MIT", + "dependencies": { + "clone": "^1.0.2" + } + }, + "node_modules/define-properties": { + "version": "1.1.3", + "dev": true, + "license": "MIT", + "dependencies": { + "object-keys": "^1.0.12" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/define-property": { + "version": "2.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-descriptor": "^1.0.2", + "isobject": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/define-property/node_modules/is-accessor-descriptor": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^6.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/define-property/node_modules/is-data-descriptor": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^6.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/define-property/node_modules/is-descriptor": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/denodeify": { + "version": "1.2.1", + "dev": true, + "license": "MIT" + }, + "node_modules/depd": { + "version": "1.1.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/destroy": { + "version": "1.0.4", + "dev": true, + "license": "MIT" + }, + "node_modules/ee-first": { + "version": "1.1.1", + "dev": true, + "license": "MIT" + }, + "node_modules/electron-to-chromium": { + "version": "1.4.179", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.179.tgz", + "integrity": "sha512-1XeTb/U/8Xgh2YgPOqhakLYsvCcU4U7jUjTMbEnhIJoIWd/Qt3yC8y0cbG+fHzn4zUNF99Ey1xiPf20bwgLO3Q==", + "dev": true + }, + "node_modules/emoji-regex": { + "version": "8.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/encodeurl": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/end-of-stream": { + "version": "1.4.4", + "dev": true, + "license": "MIT", + "dependencies": { + "once": "^1.4.0" + } + }, + "node_modules/envinfo": { + "version": "7.8.1", + "dev": true, + "license": "MIT", + "bin": { + "envinfo": "dist/cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/error-ex": { + "version": "1.3.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-arrayish": "^0.2.1" + } + }, + "node_modules/error-stack-parser": { + "version": "2.0.6", + "dev": true, + "license": "MIT", + "dependencies": { + "stackframe": "^1.1.1" + } + }, + "node_modules/errorhandler": { + "version": "1.5.1", + "dev": true, + "license": "MIT", + "dependencies": { + "accepts": "~1.3.7", + "escape-html": "~1.0.3" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/escalade": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", + "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-html": { + "version": "1.0.3", + "dev": true, + "license": "MIT" + }, + "node_modules/escape-string-regexp": { + "version": "1.0.5", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/esprima": { + "version": "4.0.1", + "dev": true, + "license": "BSD-2-Clause", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "peer": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/etag": { + "version": "1.8.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/event-target-shim": { + "version": "5.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/exec-sh": { + "version": "0.3.6", + "dev": true, + "license": "MIT" + }, + "node_modules/execa": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "cross-spawn": "^6.0.0", + "get-stream": "^4.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/expand-brackets": { + "version": "2.1.4", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/expand-brackets/node_modules/define-property": { + "version": "0.2.5", + "dev": true, + "license": "MIT", + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/expand-brackets/node_modules/extend-shallow": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extend-shallow": { + "version": "3.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "assign-symbols": "^1.0.0", + "is-extendable": "^1.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extend-shallow/node_modules/is-extendable": { + "version": "1.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-plain-object": "^2.0.4" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob": { + "version": "2.0.4", + "dev": true, + "license": "MIT", + "dependencies": { + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob/node_modules/define-property": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "is-descriptor": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob/node_modules/extend-shallow": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob/node_modules/is-accessor-descriptor": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^6.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob/node_modules/is-data-descriptor": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^6.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob/node_modules/is-descriptor": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/fb-watchman": { + "version": "2.0.1", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "bser": "2.1.1" + } + }, + "node_modules/fill-range": { + "version": "7.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/finalhandler": { + "version": "1.1.2", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "2.6.9", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "statuses": "~1.5.0", + "unpipe": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/find-cache-dir": { + "version": "2.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/find-up": { + "version": "4.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/flow-parser": { + "version": "0.121.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/for-in": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/fragment-cache": { + "version": "0.2.1", + "dev": true, + "license": "MIT", + "dependencies": { + "map-cache": "^0.2.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/fresh": { + "version": "0.5.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/fs-extra": { + "version": "8.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "graceful-fs": "^4.2.0", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + }, + "engines": { + "node": ">=6 <7 || >=8" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "dev": true, + "license": "ISC" + }, + "node_modules/fsevents": { + "version": "2.0.7", + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/function-bind": { + "version": "1.1.1", + "dev": true, + "license": "MIT" + }, + "node_modules/gensync": { + "version": "1.0.0-beta.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/get-caller-file": { + "version": "2.0.5", + "dev": true, + "license": "ISC", + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/get-intrinsic": { + "version": "1.1.1", + "dev": true, + "license": "MIT", + "dependencies": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-stream": { + "version": "4.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "pump": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/get-value": { + "version": "2.0.6", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/glob": { + "version": "7.2.0", + "dev": true, + "license": "ISC", + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "5.1.0", + "dev": true, + "license": "ISC", + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/globals": { + "version": "11.12.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.9", + "dev": true, + "license": "ISC" + }, + "node_modules/has": { + "version": "1.0.3", + "dev": true, + "license": "MIT", + "dependencies": { + "function-bind": "^1.1.1" + }, + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/has-flag": { + "version": "4.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/has-symbols": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-value": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "get-value": "^2.0.6", + "has-values": "^1.0.0", + "isobject": "^3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/has-values": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "is-number": "^3.0.0", + "kind-of": "^4.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/has-values/node_modules/is-number": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/has-values/node_modules/is-number/node_modules/kind-of": { + "version": "3.2.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/has-values/node_modules/kind-of": { + "version": "4.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/hermes-engine": { + "version": "0.9.0", + "dev": true, + "license": "MIT" + }, + "node_modules/hermes-parser": { + "version": "0.4.7", + "dev": true, + "license": "MIT" + }, + "node_modules/hermes-profile-transformer": { + "version": "0.0.6", + "dev": true, + "license": "MIT", + "dependencies": { + "source-map": "^0.7.3" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/http-errors": { + "version": "1.8.1", + "dev": true, + "license": "MIT", + "dependencies": { + "depd": "~1.1.2", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": ">= 1.5.0 < 2", + "toidentifier": "1.0.1" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/image-size": { + "version": "0.6.3", + "dev": true, + "license": "MIT", + "bin": { + "image-size": "bin/image-size.js" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/import-fresh": { + "version": "2.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "caller-path": "^2.0.0", + "resolve-from": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/imurmurhash": { + "version": "0.1.4", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "dev": true, + "license": "ISC", + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "dev": true, + "license": "ISC" + }, + "node_modules/invariant": { + "version": "2.2.4", + "dev": true, + "license": "MIT", + "dependencies": { + "loose-envify": "^1.0.0" + } + }, + "node_modules/ip": { + "version": "1.1.5", + "dev": true, + "license": "MIT" + }, + "node_modules/is-accessor-descriptor": { + "version": "0.1.6", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-accessor-descriptor/node_modules/kind-of": { + "version": "3.2.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-arrayish": { + "version": "0.2.1", + "dev": true, + "license": "MIT" + }, + "node_modules/is-binary-path": { + "version": "2.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-buffer": { + "version": "1.1.6", + "dev": true, + "license": "MIT" + }, + "node_modules/is-ci": { + "version": "2.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "ci-info": "^2.0.0" + }, + "bin": { + "is-ci": "bin.js" + } + }, + "node_modules/is-core-module": { + "version": "2.9.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz", + "integrity": "sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==", + "dev": true, + "dependencies": { + "has": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-data-descriptor": { + "version": "0.1.4", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-data-descriptor/node_modules/kind-of": { + "version": "3.2.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-descriptor": { + "version": "0.1.6", + "dev": true, + "license": "MIT", + "dependencies": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-descriptor/node_modules/kind-of": { + "version": "5.1.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-directory": { + "version": "0.3.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-extendable": { + "version": "0.1.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "2.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/is-glob": { + "version": "4.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-number": { + "version": "7.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/is-plain-object": { + "version": "2.0.4", + "dev": true, + "license": "MIT", + "dependencies": { + "isobject": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-stream": { + "version": "1.1.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-windows": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-wsl": { + "version": "1.1.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/isarray": { + "version": "1.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/isexe": { + "version": "2.0.0", + "dev": true, + "license": "ISC" + }, + "node_modules/isobject": { + "version": "3.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/jest-get-type": { + "version": "26.3.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 10.14.2" + } + }, + "node_modules/jest-haste-map": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@jest/types": "^26.6.2", + "@types/graceful-fs": "^4.1.2", + "@types/node": "*", + "anymatch": "^3.0.3", + "fb-watchman": "^2.0.0", + "graceful-fs": "^4.2.4", + "jest-regex-util": "^26.0.0", + "jest-serializer": "^26.6.2", + "jest-util": "^26.6.2", + "jest-worker": "^26.6.2", + "micromatch": "^4.0.2", + "sane": "^4.0.3", + "walker": "^1.0.7" + }, + "engines": { + "node": ">= 10.14.2" + }, + "optionalDependencies": { + "fsevents": "^2.1.2" + } + }, + "node_modules/jest-haste-map/node_modules/@jest/types": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^3.0.0", + "@types/node": "*", + "@types/yargs": "^15.0.0", + "chalk": "^4.0.0" + }, + "engines": { + "node": ">= 10.14.2" + } + }, + "node_modules/jest-haste-map/node_modules/@types/yargs": { + "version": "15.0.14", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/yargs-parser": "*" + } + }, + "node_modules/jest-haste-map/node_modules/fsevents": { + "version": "2.3.2", + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/jest-regex-util": { + "version": "26.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 10.14.2" + } + }, + "node_modules/jest-serializer": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/node": "*", + "graceful-fs": "^4.2.4" + }, + "engines": { + "node": ">= 10.14.2" + } + }, + "node_modules/jest-util": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@jest/types": "^26.6.2", + "@types/node": "*", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.4", + "is-ci": "^2.0.0", + "micromatch": "^4.0.2" + }, + "engines": { + "node": ">= 10.14.2" + } + }, + "node_modules/jest-util/node_modules/@jest/types": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^3.0.0", + "@types/node": "*", + "@types/yargs": "^15.0.0", + "chalk": "^4.0.0" + }, + "engines": { + "node": ">= 10.14.2" + } + }, + "node_modules/jest-util/node_modules/@types/yargs": { + "version": "15.0.14", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/yargs-parser": "*" + } + }, + "node_modules/jest-validate": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@jest/types": "^26.6.2", + "camelcase": "^6.0.0", + "chalk": "^4.0.0", + "jest-get-type": "^26.3.0", + "leven": "^3.1.0", + "pretty-format": "^26.6.2" + }, + "engines": { + "node": ">= 10.14.2" + } + }, + "node_modules/jest-validate/node_modules/@jest/types": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^3.0.0", + "@types/node": "*", + "@types/yargs": "^15.0.0", + "chalk": "^4.0.0" + }, + "engines": { + "node": ">= 10.14.2" + } + }, + "node_modules/jest-validate/node_modules/@types/yargs": { + "version": "15.0.14", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/yargs-parser": "*" + } + }, + "node_modules/jest-validate/node_modules/camelcase": { + "version": "6.3.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/jest-worker": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/node": "*", + "merge-stream": "^2.0.0", + "supports-color": "^7.0.0" + }, + "engines": { + "node": ">= 10.13.0" + } + }, + "node_modules/jetifier": { + "version": "1.6.8", + "dev": true, + "license": "MIT", + "bin": { + "jetifier": "bin/jetify", + "jetifier-standalone": "bin/jetifier-standalone", + "jetify": "bin/jetify" + } + }, + "node_modules/joi": { + "version": "17.5.0", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "@hapi/hoek": "^9.0.0", + "@hapi/topo": "^5.0.0", + "@sideway/address": "^4.1.3", + "@sideway/formula": "^3.0.0", + "@sideway/pinpoint": "^2.0.0" + } + }, + "node_modules/js-tokens": { + "version": "4.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/js-yaml": { + "version": "3.14.1", + "dev": true, + "license": "MIT", + "dependencies": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsc-android": { + "version": "250230.2.1", + "dev": true, + "license": "BSD-2-Clause" + }, + "node_modules/jscodeshift": { + "version": "0.11.0", + "dev": true, + "dependencies": { + "@babel/core": "^7.1.6", + "@babel/parser": "^7.1.6", + "@babel/plugin-proposal-class-properties": "^7.1.0", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.1.0", + "@babel/plugin-proposal-optional-chaining": "^7.1.0", + "@babel/plugin-transform-modules-commonjs": "^7.1.0", + "@babel/preset-flow": "^7.0.0", + "@babel/preset-typescript": "^7.1.0", + "@babel/register": "^7.0.0", + "babel-core": "^7.0.0-bridge.0", + "colors": "^1.1.2", + "flow-parser": "0.*", + "graceful-fs": "^4.2.4", + "micromatch": "^3.1.10", + "neo-async": "^2.5.0", + "node-dir": "^0.1.17", + "recast": "^0.20.3", + "temp": "^0.8.1", + "write-file-atomic": "^2.3.0" + }, + "bin": { + "jscodeshift": "bin/jscodeshift.js" + }, + "peerDependencies": { + "@babel/preset-env": "^7.1.6" + } + }, + "node_modules/jscodeshift/node_modules/braces": { + "version": "2.3.2", + "dev": true, + "license": "MIT", + "dependencies": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/jscodeshift/node_modules/braces/node_modules/extend-shallow": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/jscodeshift/node_modules/fill-range": { + "version": "4.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/jscodeshift/node_modules/fill-range/node_modules/extend-shallow": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/jscodeshift/node_modules/is-number": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/jscodeshift/node_modules/is-number/node_modules/kind-of": { + "version": "3.2.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/jscodeshift/node_modules/micromatch": { + "version": "3.1.10", + "dev": true, + "license": "MIT", + "dependencies": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/jscodeshift/node_modules/to-regex-range": { + "version": "2.1.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/jsesc": { + "version": "2.5.2", + "dev": true, + "license": "MIT", + "bin": { + "jsesc": "bin/jsesc" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/json-parse-better-errors": { + "version": "1.0.2", + "dev": true, + "license": "MIT" + }, + "node_modules/json5": { + "version": "2.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "minimist": "^1.2.5" + }, + "bin": { + "json5": "lib/cli.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/jsonfile": { + "version": "4.0.0", + "dev": true, + "license": "MIT", + "optionalDependencies": { + "graceful-fs": "^4.1.6" + } + }, + "node_modules/jsonify": { + "version": "0.0.0", + "dev": true, + "license": "Public Domain" + }, + "node_modules/kind-of": { + "version": "6.0.3", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/klaw": { + "version": "1.3.1", + "dev": true, + "license": "MIT", + "optionalDependencies": { + "graceful-fs": "^4.1.9" + } + }, + "node_modules/kleur": { + "version": "3.0.3", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/leven": { + "version": "3.1.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/locate-path": { + "version": "5.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "p-locate": "^4.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/lodash": { + "version": "4.17.21", + "dev": true, + "license": "MIT" + }, + "node_modules/lodash.debounce": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", + "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==", + "dev": true + }, + "node_modules/lodash.throttle": { + "version": "4.1.1", + "dev": true, + "license": "MIT" + }, + "node_modules/log-symbols": { + "version": "2.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "chalk": "^2.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/log-symbols/node_modules/ansi-styles": { + "version": "3.2.1", + "dev": true, + "license": "MIT", + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/log-symbols/node_modules/chalk": { + "version": "2.4.2", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/log-symbols/node_modules/color-convert": { + "version": "1.9.3", + "dev": true, + "license": "MIT", + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/log-symbols/node_modules/color-name": { + "version": "1.1.3", + "dev": true, + "license": "MIT" + }, + "node_modules/log-symbols/node_modules/has-flag": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/log-symbols/node_modules/supports-color": { + "version": "5.5.0", + "dev": true, + "license": "MIT", + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/logkitty": { + "version": "0.7.1", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-fragments": "^0.2.1", + "dayjs": "^1.8.15", + "yargs": "^15.1.0" + }, + "bin": { + "logkitty": "bin/logkitty.js" + } + }, + "node_modules/loose-envify": { + "version": "1.4.0", + "dev": true, + "license": "MIT", + "dependencies": { + "js-tokens": "^3.0.0 || ^4.0.0" + }, + "bin": { + "loose-envify": "cli.js" + } + }, + "node_modules/make-dir": { + "version": "2.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/make-dir/node_modules/semver": { + "version": "5.7.1", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/makeerror": { + "version": "1.0.12", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "tmpl": "1.0.5" + } + }, + "node_modules/map-cache": { + "version": "0.2.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/map-visit": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "object-visit": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/merge-stream": { + "version": "2.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/metro": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/code-frame": "^7.0.0", + "@babel/core": "^7.14.0", + "@babel/generator": "^7.14.0", + "@babel/parser": "^7.14.0", + "@babel/template": "^7.0.0", + "@babel/traverse": "^7.14.0", + "@babel/types": "^7.0.0", + "absolute-path": "^0.0.0", + "accepts": "^1.3.7", + "async": "^2.4.0", + "chalk": "^4.0.0", + "ci-info": "^2.0.0", + "connect": "^3.6.5", + "debug": "^2.2.0", + "denodeify": "^1.2.1", + "error-stack-parser": "^2.0.6", + "fs-extra": "^1.0.0", + "graceful-fs": "^4.1.3", + "hermes-parser": "0.4.7", + "image-size": "^0.6.0", + "invariant": "^2.2.4", + "jest-haste-map": "^26.5.2", + "jest-worker": "^26.0.0", + "lodash.throttle": "^4.1.1", + "metro-babel-register": "0.66.2", + "metro-babel-transformer": "0.66.2", + "metro-cache": "0.66.2", + "metro-cache-key": "0.66.2", + "metro-config": "0.66.2", + "metro-core": "0.66.2", + "metro-hermes-compiler": "0.66.2", + "metro-inspector-proxy": "0.66.2", + "metro-minify-uglify": "0.66.2", + "metro-react-native-babel-preset": "0.66.2", + "metro-resolver": "0.66.2", + "metro-runtime": "0.66.2", + "metro-source-map": "0.66.2", + "metro-symbolicate": "0.66.2", + "metro-transform-plugins": "0.66.2", + "metro-transform-worker": "0.66.2", + "mime-types": "^2.1.27", + "mkdirp": "^0.5.1", + "node-fetch": "^2.2.0", + "nullthrows": "^1.1.1", + "rimraf": "^2.5.4", + "serialize-error": "^2.1.0", + "source-map": "^0.5.6", + "strip-ansi": "^6.0.0", + "temp": "0.8.3", + "throat": "^5.0.0", + "ws": "^1.1.5", + "yargs": "^15.3.1" + }, + "bin": { + "metro": "src/cli.js" + } + }, + "node_modules/metro-babel-register": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/core": "^7.14.0", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.0.0", + "@babel/plugin-proposal-optional-chaining": "^7.0.0", + "@babel/plugin-syntax-class-properties": "^7.0.0", + "@babel/plugin-transform-flow-strip-types": "^7.0.0", + "@babel/plugin-transform-modules-commonjs": "^7.0.0", + "@babel/register": "^7.0.0", + "escape-string-regexp": "^1.0.5" + } + }, + "node_modules/metro-babel-transformer": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/core": "^7.14.0", + "hermes-parser": "0.4.7", + "metro-source-map": "0.66.2", + "nullthrows": "^1.1.1" + } + }, + "node_modules/metro-cache": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "metro-core": "0.66.2", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4" + } + }, + "node_modules/metro-cache-key": { + "version": "0.66.2", + "dev": true, + "license": "MIT" + }, + "node_modules/metro-config": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "cosmiconfig": "^5.0.5", + "jest-validate": "^26.5.2", + "metro": "0.66.2", + "metro-cache": "0.66.2", + "metro-core": "0.66.2", + "metro-runtime": "0.66.2" + } + }, + "node_modules/metro-core": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "jest-haste-map": "^26.5.2", + "lodash.throttle": "^4.1.1", + "metro-resolver": "0.66.2" + } + }, + "node_modules/metro-hermes-compiler": { + "version": "0.66.2", + "dev": true, + "license": "MIT" + }, + "node_modules/metro-inspector-proxy": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "connect": "^3.6.5", + "debug": "^2.2.0", + "ws": "^1.1.5", + "yargs": "^15.3.1" + }, + "bin": { + "metro-inspector-proxy": "src/cli.js" + } + }, + "node_modules/metro-inspector-proxy/node_modules/ws": { + "version": "1.1.5", + "dev": true, + "license": "MIT", + "dependencies": { + "options": ">=0.0.5", + "ultron": "1.0.x" + } + }, + "node_modules/metro-minify-uglify": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "uglify-es": "^3.1.9" + } + }, + "node_modules/metro-react-native-babel-preset": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/core": "^7.14.0", + "@babel/plugin-proposal-class-properties": "^7.0.0", + "@babel/plugin-proposal-export-default-from": "^7.0.0", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.0.0", + "@babel/plugin-proposal-object-rest-spread": "^7.0.0", + "@babel/plugin-proposal-optional-catch-binding": "^7.0.0", + "@babel/plugin-proposal-optional-chaining": "^7.0.0", + "@babel/plugin-syntax-dynamic-import": "^7.0.0", + "@babel/plugin-syntax-export-default-from": "^7.0.0", + "@babel/plugin-syntax-flow": "^7.2.0", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.0.0", + "@babel/plugin-syntax-optional-chaining": "^7.0.0", + "@babel/plugin-transform-arrow-functions": "^7.0.0", + "@babel/plugin-transform-async-to-generator": "^7.0.0", + "@babel/plugin-transform-block-scoping": "^7.0.0", + "@babel/plugin-transform-classes": "^7.0.0", + "@babel/plugin-transform-computed-properties": "^7.0.0", + "@babel/plugin-transform-destructuring": "^7.0.0", + "@babel/plugin-transform-exponentiation-operator": "^7.0.0", + "@babel/plugin-transform-flow-strip-types": "^7.0.0", + "@babel/plugin-transform-for-of": "^7.0.0", + "@babel/plugin-transform-function-name": "^7.0.0", + "@babel/plugin-transform-literals": "^7.0.0", + "@babel/plugin-transform-modules-commonjs": "^7.0.0", + "@babel/plugin-transform-object-assign": "^7.0.0", + "@babel/plugin-transform-parameters": "^7.0.0", + "@babel/plugin-transform-react-display-name": "^7.0.0", + "@babel/plugin-transform-react-jsx": "^7.0.0", + "@babel/plugin-transform-react-jsx-self": "^7.0.0", + "@babel/plugin-transform-react-jsx-source": "^7.0.0", + "@babel/plugin-transform-regenerator": "^7.0.0", + "@babel/plugin-transform-runtime": "^7.0.0", + "@babel/plugin-transform-shorthand-properties": "^7.0.0", + "@babel/plugin-transform-spread": "^7.0.0", + "@babel/plugin-transform-sticky-regex": "^7.0.0", + "@babel/plugin-transform-template-literals": "^7.0.0", + "@babel/plugin-transform-typescript": "^7.5.0", + "@babel/plugin-transform-unicode-regex": "^7.0.0", + "@babel/template": "^7.0.0", + "react-refresh": "^0.4.0" + }, + "peerDependencies": { + "@babel/core": "*" + } + }, + "node_modules/metro-react-native-babel-transformer": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/core": "^7.14.0", + "babel-preset-fbjs": "^3.4.0", + "hermes-parser": "0.4.7", + "metro-babel-transformer": "0.66.2", + "metro-react-native-babel-preset": "0.66.2", + "metro-source-map": "0.66.2", + "nullthrows": "^1.1.1" + }, + "peerDependencies": { + "@babel/core": "*" + } + }, + "node_modules/metro-resolver": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "absolute-path": "^0.0.0" + } + }, + "node_modules/metro-runtime": { + "version": "0.66.2", + "dev": true, + "license": "MIT" + }, + "node_modules/metro-source-map": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/traverse": "^7.14.0", + "@babel/types": "^7.0.0", + "invariant": "^2.2.4", + "metro-symbolicate": "0.66.2", + "nullthrows": "^1.1.1", + "ob1": "0.66.2", + "source-map": "^0.5.6", + "vlq": "^1.0.0" + } + }, + "node_modules/metro-source-map/node_modules/source-map": { + "version": "0.5.7", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/metro-symbolicate": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "invariant": "^2.2.4", + "metro-source-map": "0.66.2", + "nullthrows": "^1.1.1", + "source-map": "^0.5.6", + "through2": "^2.0.1", + "vlq": "^1.0.0" + }, + "bin": { + "metro-symbolicate": "src/index.js" + }, + "engines": { + "node": ">=8.3" + } + }, + "node_modules/metro-symbolicate/node_modules/source-map": { + "version": "0.5.7", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/metro-transform-plugins": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/core": "^7.14.0", + "@babel/generator": "^7.14.0", + "@babel/template": "^7.0.0", + "@babel/traverse": "^7.14.0", + "nullthrows": "^1.1.1" + } + }, + "node_modules/metro-transform-worker": { + "version": "0.66.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/core": "^7.14.0", + "@babel/generator": "^7.14.0", + "@babel/parser": "^7.14.0", + "@babel/types": "^7.0.0", + "babel-preset-fbjs": "^3.4.0", + "metro": "0.66.2", + "metro-babel-transformer": "0.66.2", + "metro-cache": "0.66.2", + "metro-cache-key": "0.66.2", + "metro-hermes-compiler": "0.66.2", + "metro-source-map": "0.66.2", + "metro-transform-plugins": "0.66.2", + "nullthrows": "^1.1.1" + } + }, + "node_modules/metro/node_modules/ansi-regex": { + "version": "5.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/metro/node_modules/fs-extra": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "graceful-fs": "^4.1.2", + "jsonfile": "^2.1.0", + "klaw": "^1.0.0" + } + }, + "node_modules/metro/node_modules/jsonfile": { + "version": "2.4.0", + "dev": true, + "license": "MIT", + "optionalDependencies": { + "graceful-fs": "^4.1.6" + } + }, + "node_modules/metro/node_modules/source-map": { + "version": "0.5.7", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/metro/node_modules/strip-ansi": { + "version": "6.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/metro/node_modules/ws": { + "version": "1.1.5", + "dev": true, + "license": "MIT", + "dependencies": { + "options": ">=0.0.5", + "ultron": "1.0.x" + } + }, + "node_modules/micromatch": { + "version": "4.0.4", + "dev": true, + "license": "MIT", + "dependencies": { + "braces": "^3.0.1", + "picomatch": "^2.2.3" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/micromatch/node_modules/picomatch": { + "version": "2.3.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/mime": { + "version": "1.6.0", + "dev": true, + "license": "MIT", + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/mime-db": { + "version": "1.51.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.34", + "dev": true, + "license": "MIT", + "dependencies": { + "mime-db": "1.51.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mimic-fn": { + "version": "1.2.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/minimatch": { + "version": "3.0.4", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/minimist": { + "version": "1.2.5", + "dev": true, + "license": "MIT" + }, + "node_modules/mixin-deep": { + "version": "1.3.2", + "dev": true, + "license": "MIT", + "dependencies": { + "for-in": "^1.0.2", + "is-extendable": "^1.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/mixin-deep/node_modules/is-extendable": { + "version": "1.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-plain-object": "^2.0.4" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/mkdirp": { + "version": "0.5.5", + "dev": true, + "license": "MIT", + "dependencies": { + "minimist": "^1.2.5" + }, + "bin": { + "mkdirp": "bin/cmd.js" + } + }, + "node_modules/ms": { + "version": "2.1.3", + "dev": true, + "license": "MIT" + }, + "node_modules/nanomatch": { + "version": "1.2.13", + "dev": true, + "license": "MIT", + "dependencies": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "fragment-cache": "^0.2.1", + "is-windows": "^1.0.2", + "kind-of": "^6.0.2", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/negotiator": { + "version": "0.6.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/neo-async": { + "version": "2.6.2", + "dev": true, + "license": "MIT" + }, + "node_modules/nice-try": { + "version": "1.0.5", + "dev": true, + "license": "MIT" + }, + "node_modules/nocache": { + "version": "2.1.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/node-dir": { + "version": "0.1.17", + "dev": true, + "license": "MIT", + "dependencies": { + "minimatch": "^3.0.2" + }, + "engines": { + "node": ">= 0.10.5" + } + }, + "node_modules/node-fetch": { + "version": "2.6.6", + "dev": true, + "license": "MIT", + "dependencies": { + "whatwg-url": "^5.0.0" + }, + "engines": { + "node": "4.x || >=6.0.0" + } + }, + "node_modules/node-int64": { + "version": "0.4.0", + "dev": true, + "license": "MIT" + }, + "node_modules/node-releases": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.5.tgz", + "integrity": "sha512-U9h1NLROZTq9uE1SNffn6WuPDg8icmi3ns4rEl/oTfIle4iLjTliCzgTsbaIFMq/Xn078/lfY/BL0GWZ+psK4Q==", + "dev": true + }, + "node_modules/node-stream-zip": { + "version": "1.15.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.12.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/antelle" + } + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/npm-run-path": { + "version": "2.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "path-key": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/nullthrows": { + "version": "1.1.1", + "dev": true, + "license": "MIT" + }, + "node_modules/ob1": { + "version": "0.66.2", + "dev": true, + "license": "MIT" + }, + "node_modules/object-assign": { + "version": "4.1.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-copy": { + "version": "0.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "copy-descriptor": "^0.1.0", + "define-property": "^0.2.5", + "kind-of": "^3.0.3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-copy/node_modules/define-property": { + "version": "0.2.5", + "dev": true, + "license": "MIT", + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-copy/node_modules/kind-of": { + "version": "3.2.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-keys": { + "version": "1.1.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object-visit": { + "version": "1.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "isobject": "^3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object.assign": { + "version": "4.1.2", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.0", + "define-properties": "^1.1.3", + "has-symbols": "^1.0.1", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.pick": { + "version": "1.3.0", + "dev": true, + "license": "MIT", + "dependencies": { + "isobject": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/on-finished": { + "version": "2.3.0", + "dev": true, + "license": "MIT", + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/on-headers": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/once": { + "version": "1.4.0", + "dev": true, + "license": "ISC", + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/onetime": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "mimic-fn": "^1.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/open": { + "version": "6.4.0", + "dev": true, + "license": "MIT", + "dependencies": { + "is-wsl": "^1.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/options": { + "version": "0.0.6", + "dev": true, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/ora": { + "version": "3.4.0", + "dev": true, + "license": "MIT", + "dependencies": { + "chalk": "^2.4.2", + "cli-cursor": "^2.1.0", + "cli-spinners": "^2.0.0", + "log-symbols": "^2.2.0", + "strip-ansi": "^5.2.0", + "wcwidth": "^1.0.1" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/ora/node_modules/ansi-styles": { + "version": "3.2.1", + "dev": true, + "license": "MIT", + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/ora/node_modules/chalk": { + "version": "2.4.2", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/ora/node_modules/color-convert": { + "version": "1.9.3", + "dev": true, + "license": "MIT", + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/ora/node_modules/color-name": { + "version": "1.1.3", + "dev": true, + "license": "MIT" + }, + "node_modules/ora/node_modules/has-flag": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/ora/node_modules/supports-color": { + "version": "5.5.0", + "dev": true, + "license": "MIT", + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/os-tmpdir": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/p-finally": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/p-limit": { + "version": "2.3.0", + "dev": true, + "license": "MIT", + "dependencies": { + "p-try": "^2.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "4.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "p-limit": "^2.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/p-try": { + "version": "2.2.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/parse-json": { + "version": "4.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/parseurl": { + "version": "1.3.3", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/pascalcase": { + "version": "0.1.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-exists": { + "version": "4.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-key": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "node_modules/picocolors": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", + "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", + "dev": true + }, + "node_modules/picomatch": { + "version": "2.0.7", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/pify": { + "version": "4.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/pirates": { + "version": "4.0.4", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 6" + } + }, + "node_modules/pkg-dir": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "find-up": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/pkg-dir/node_modules/find-up": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "locate-path": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/pkg-dir/node_modules/locate-path": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/pkg-dir/node_modules/p-locate": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "p-limit": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/pkg-dir/node_modules/path-exists": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/plist": { + "version": "3.0.4", + "dev": true, + "license": "MIT", + "dependencies": { + "base64-js": "^1.5.1", + "xmlbuilder": "^9.0.7" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/posix-character-classes": { + "version": "0.1.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/pretty-format": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@jest/types": "^26.6.2", + "ansi-regex": "^5.0.0", + "ansi-styles": "^4.0.0", + "react-is": "^17.0.1" + }, + "engines": { + "node": ">= 10" + } + }, + "node_modules/pretty-format/node_modules/@jest/types": { + "version": "26.6.2", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^3.0.0", + "@types/node": "*", + "@types/yargs": "^15.0.0", + "chalk": "^4.0.0" + }, + "engines": { + "node": ">= 10.14.2" + } + }, + "node_modules/pretty-format/node_modules/@types/yargs": { + "version": "15.0.14", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/yargs-parser": "*" + } + }, + "node_modules/pretty-format/node_modules/ansi-regex": { + "version": "5.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/process-nextick-args": { + "version": "2.0.1", + "dev": true, + "license": "MIT" + }, + "node_modules/promise": { + "version": "8.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "asap": "~2.0.6" + } + }, + "node_modules/prompts": { + "version": "2.4.2", + "dev": true, + "license": "MIT", + "dependencies": { + "kleur": "^3.0.3", + "sisteransi": "^1.0.5" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/prop-types": { + "version": "15.8.1", + "dev": true, + "license": "MIT", + "dependencies": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.13.1" + } + }, + "node_modules/prop-types/node_modules/react-is": { + "version": "16.13.1", + "dev": true, + "license": "MIT" + }, + "node_modules/pump": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "node_modules/range-parser": { + "version": "1.2.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/react": { + "version": "17.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/react-devtools-core": { + "version": "4.22.1", + "dev": true, + "license": "MIT", + "dependencies": { + "shell-quote": "^1.6.1", + "ws": "^7" + } + }, + "node_modules/react-devtools-core/node_modules/ws": { + "version": "7.5.6", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8.3.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": "^5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/react-is": { + "version": "17.0.2", + "dev": true, + "license": "MIT" + }, + "node_modules/react-native": { + "version": "0.66.4", + "dev": true, + "license": "MIT", + "dependencies": { + "@jest/create-cache-key-function": "^27.0.1", + "@react-native-community/cli": "^6.0.0", + "@react-native-community/cli-platform-android": "^6.0.0", + "@react-native-community/cli-platform-ios": "^6.0.0", + "@react-native/assets": "1.0.0", + "@react-native/normalize-color": "1.0.0", + "@react-native/polyfills": "2.0.0", + "abort-controller": "^3.0.0", + "anser": "^1.4.9", + "base64-js": "^1.1.2", + "event-target-shim": "^5.0.1", + "hermes-engine": "~0.9.0", + "invariant": "^2.2.4", + "jsc-android": "^250230.2.1", + "metro-babel-register": "0.66.2", + "metro-react-native-babel-transformer": "0.66.2", + "metro-runtime": "0.66.2", + "metro-source-map": "0.66.2", + "nullthrows": "^1.1.1", + "pretty-format": "^26.5.2", + "promise": "^8.0.3", + "prop-types": "^15.7.2", + "react-devtools-core": "^4.13.0", + "react-native-codegen": "^0.0.7", + "react-refresh": "^0.4.0", + "regenerator-runtime": "^0.13.2", + "scheduler": "^0.20.2", + "stacktrace-parser": "^0.1.3", + "use-subscription": "^1.0.0", + "whatwg-fetch": "^3.0.0", + "ws": "^6.1.4" + }, + "bin": { + "react-native": "cli.js" + }, + "engines": { + "node": ">=12" + }, + "peerDependencies": { + "react": "17.0.2" + } + }, + "node_modules/react-native-codegen": { + "version": "0.0.7", + "dev": true, + "license": "MIT", + "dependencies": { + "flow-parser": "^0.121.0", + "jscodeshift": "^0.11.0", + "nullthrows": "^1.1.1" + } + }, + "node_modules/react-native/node_modules/@react-native-community/cli": { + "version": "6.3.1", + "dev": true, + "license": "MIT", + "dependencies": { + "@react-native-community/cli-debugger-ui": "^6.0.0-rc.0", + "@react-native-community/cli-hermes": "^6.3.0", + "@react-native-community/cli-plugin-metro": "^6.2.0", + "@react-native-community/cli-server-api": "^6.2.0", + "@react-native-community/cli-tools": "^6.2.0", + "@react-native-community/cli-types": "^6.0.0", + "appdirsjs": "^1.2.4", + "chalk": "^4.1.2", + "command-exists": "^1.2.8", + "commander": "^2.19.0", + "cosmiconfig": "^5.1.0", + "deepmerge": "^3.2.0", + "envinfo": "^7.7.2", + "execa": "^1.0.0", + "find-up": "^4.1.0", + "fs-extra": "^8.1.0", + "glob": "^7.1.3", + "graceful-fs": "^4.1.3", + "joi": "^17.2.1", + "leven": "^3.1.0", + "lodash": "^4.17.15", + "minimist": "^1.2.0", + "node-stream-zip": "^1.9.1", + "ora": "^3.4.0", + "pretty-format": "^26.6.2", + "prompts": "^2.4.0", + "semver": "^6.3.0", + "serve-static": "^1.13.1", + "strip-ansi": "^5.2.0", + "sudo-prompt": "^9.0.0", + "wcwidth": "^1.0.1" + }, + "bin": { + "react-native": "build/bin.js" + }, + "engines": { + "node": ">=12" + }, + "peerDependencies": { + "react-native": "*" + } + }, + "node_modules/react-refresh": { + "version": "0.4.3", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/readable-stream": { + "version": "2.3.7", + "dev": true, + "license": "MIT", + "dependencies": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "node_modules/readdirp": { + "version": "3.1.2", + "dev": true, + "license": "MIT", + "dependencies": { + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/readline": { + "version": "1.3.0", + "dev": true, + "license": "BSD" + }, + "node_modules/recast": { + "version": "0.20.5", + "dev": true, + "license": "MIT", + "dependencies": { + "ast-types": "0.14.2", + "esprima": "~4.0.0", + "source-map": "~0.6.1", + "tslib": "^2.0.1" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/recast/node_modules/source-map": { + "version": "0.6.1", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/regenerate": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz", + "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==", + "dev": true + }, + "node_modules/regenerate-unicode-properties": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.0.1.tgz", + "integrity": "sha512-vn5DU6yg6h8hP/2OkQo3K7uVILvY4iu0oI4t3HFa81UPkhGJwkRwM10JEc3upjdhHjs/k8GJY1sRBhk5sr69Bw==", + "dev": true, + "dependencies": { + "regenerate": "^1.4.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/regenerator-runtime": { + "version": "0.13.9", + "dev": true, + "license": "MIT" + }, + "node_modules/regenerator-transform": { + "version": "0.15.0", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.0.tgz", + "integrity": "sha512-LsrGtPmbYg19bcPHwdtmXwbW+TqNvtY4riE3P83foeHRroMbH6/2ddFBfab3t7kbzc7v7p4wbkIecHImqt0QNg==", + "dev": true, + "dependencies": { + "@babel/runtime": "^7.8.4" + } + }, + "node_modules/regex-not": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "extend-shallow": "^3.0.2", + "safe-regex": "^1.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/regexpu-core": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.1.0.tgz", + "integrity": "sha512-bb6hk+xWd2PEOkj5It46A16zFMs2mv86Iwpdu94la4S3sJ7C973h2dHpYKwIBGaWSO7cIRJ+UX0IeMaWcO4qwA==", + "dev": true, + "dependencies": { + "regenerate": "^1.4.2", + "regenerate-unicode-properties": "^10.0.1", + "regjsgen": "^0.6.0", + "regjsparser": "^0.8.2", + "unicode-match-property-ecmascript": "^2.0.0", + "unicode-match-property-value-ecmascript": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/regjsgen": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.6.0.tgz", + "integrity": "sha512-ozE883Uigtqj3bx7OhL1KNbCzGyW2NQZPl6Hs09WTvCuZD5sTI4JY58bkbQWa/Y9hxIsvJ3M8Nbf7j54IqeZbA==", + "dev": true + }, + "node_modules/regjsparser": { + "version": "0.8.4", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.8.4.tgz", + "integrity": "sha512-J3LABycON/VNEu3abOviqGHuB/LOtOQj8SKmfP9anY5GfAVw/SPjwzSjxGjbZXIxbGfqTHtJw58C2Li/WkStmA==", + "dev": true, + "dependencies": { + "jsesc": "~0.5.0" + }, + "bin": { + "regjsparser": "bin/parser" + } + }, + "node_modules/regjsparser/node_modules/jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==", + "dev": true, + "bin": { + "jsesc": "bin/jsesc" + } + }, + "node_modules/remove-trailing-separator": { + "version": "1.1.0", + "dev": true, + "license": "ISC" + }, + "node_modules/repeat-element": { + "version": "1.1.4", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/repeat-string": { + "version": "1.6.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10" + } + }, + "node_modules/require-directory": { + "version": "2.1.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/require-main-filename": { + "version": "2.0.0", + "dev": true, + "license": "ISC" + }, + "node_modules/resolve": { + "version": "1.22.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", + "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", + "dev": true, + "dependencies": { + "is-core-module": "^2.9.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-from": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/resolve-url": { + "version": "0.2.1", + "dev": true, + "license": "MIT" + }, + "node_modules/restore-cursor": { + "version": "2.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "onetime": "^2.0.0", + "signal-exit": "^3.0.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/ret": { + "version": "0.1.15", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.12" + } + }, + "node_modules/rimraf": { + "version": "2.7.1", + "dev": true, + "license": "ISC", + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + } + }, + "node_modules/rsvp": { + "version": "4.8.5", + "dev": true, + "license": "MIT", + "engines": { + "node": "6.* || >= 7.*" + } + }, + "node_modules/rxjs": { + "version": "7.5.5", + "license": "Apache-2.0", + "peer": true, + "dependencies": { + "tslib": "^2.1.0" + } + }, + "node_modules/safe-buffer": { + "version": "5.1.2", + "dev": true, + "license": "MIT" + }, + "node_modules/safe-regex": { + "version": "1.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "ret": "~0.1.10" + } + }, + "node_modules/sane": { + "version": "4.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "@cnakazawa/watch": "^1.0.3", + "anymatch": "^2.0.0", + "capture-exit": "^2.0.0", + "exec-sh": "^0.3.2", + "execa": "^1.0.0", + "fb-watchman": "^2.0.0", + "micromatch": "^3.1.4", + "minimist": "^1.1.1", + "walker": "~1.0.5" + }, + "bin": { + "sane": "src/cli.js" + }, + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/sane/node_modules/anymatch": { + "version": "2.0.0", + "dev": true, + "license": "ISC", + "dependencies": { + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + } + }, + "node_modules/sane/node_modules/braces": { + "version": "2.3.2", + "dev": true, + "license": "MIT", + "dependencies": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sane/node_modules/braces/node_modules/extend-shallow": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sane/node_modules/fill-range": { + "version": "4.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sane/node_modules/fill-range/node_modules/extend-shallow": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sane/node_modules/is-number": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sane/node_modules/is-number/node_modules/kind-of": { + "version": "3.2.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sane/node_modules/micromatch": { + "version": "3.1.10", + "dev": true, + "license": "MIT", + "dependencies": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sane/node_modules/normalize-path": { + "version": "2.1.1", + "dev": true, + "license": "MIT", + "dependencies": { + "remove-trailing-separator": "^1.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sane/node_modules/to-regex-range": { + "version": "2.1.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sax": { + "version": "1.2.4", + "dev": true, + "license": "ISC" + }, + "node_modules/scheduler": { + "version": "0.20.2", + "dev": true, + "license": "MIT", + "dependencies": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1" + } + }, + "node_modules/semver": { + "version": "6.3.0", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/send": { + "version": "0.17.2", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "2.6.9", + "depd": "~1.1.2", + "destroy": "~1.0.4", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "1.8.1", + "mime": "1.6.0", + "ms": "2.1.3", + "on-finished": "~2.3.0", + "range-parser": "~1.2.1", + "statuses": "~1.5.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/serialize-error": { + "version": "2.1.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/serve-static": { + "version": "1.14.2", + "dev": true, + "license": "MIT", + "dependencies": { + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "parseurl": "~1.3.3", + "send": "0.17.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/set-blocking": { + "version": "2.0.0", + "dev": true, + "license": "ISC" + }, + "node_modules/set-value": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.3", + "split-string": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/set-value/node_modules/extend-shallow": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/setprototypeof": { + "version": "1.2.0", + "dev": true, + "license": "ISC" + }, + "node_modules/shallow-clone": { + "version": "3.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^6.0.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/shebang-command": { + "version": "1.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "shebang-regex": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/shebang-regex": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/shell-quote": { + "version": "1.6.1", + "dev": true, + "license": "MIT", + "dependencies": { + "array-filter": "~0.0.0", + "array-map": "~0.0.0", + "array-reduce": "~0.0.0", + "jsonify": "~0.0.0" + } + }, + "node_modules/signal-exit": { + "version": "3.0.6", + "dev": true, + "license": "ISC" + }, + "node_modules/simple-plist": { + "version": "1.3.0", + "dev": true, + "license": "MIT", + "dependencies": { + "bplist-creator": "0.1.0", + "bplist-parser": "0.3.0", + "plist": "^3.0.4" + } + }, + "node_modules/sisteransi": { + "version": "1.0.5", + "dev": true, + "license": "MIT" + }, + "node_modules/slash": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/slice-ansi": { + "version": "2.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^3.2.0", + "astral-regex": "^1.0.0", + "is-fullwidth-code-point": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/slice-ansi/node_modules/ansi-styles": { + "version": "3.2.1", + "dev": true, + "license": "MIT", + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/slice-ansi/node_modules/color-convert": { + "version": "1.9.3", + "dev": true, + "license": "MIT", + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/slice-ansi/node_modules/color-name": { + "version": "1.1.3", + "dev": true, + "license": "MIT" + }, + "node_modules/snapdragon": { + "version": "0.8.2", + "dev": true, + "license": "MIT", + "dependencies": { + "base": "^0.11.1", + "debug": "^2.2.0", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "map-cache": "^0.2.2", + "source-map": "^0.5.6", + "source-map-resolve": "^0.5.0", + "use": "^3.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-node": { + "version": "2.1.1", + "dev": true, + "license": "MIT", + "dependencies": { + "define-property": "^1.0.0", + "isobject": "^3.0.0", + "snapdragon-util": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-node/node_modules/define-property": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "is-descriptor": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-node/node_modules/is-accessor-descriptor": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^6.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-node/node_modules/is-data-descriptor": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^6.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-node/node_modules/is-descriptor": { + "version": "1.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-util": { + "version": "3.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^3.2.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-util/node_modules/kind-of": { + "version": "3.2.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon/node_modules/define-property": { + "version": "0.2.5", + "dev": true, + "license": "MIT", + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon/node_modules/extend-shallow": { + "version": "2.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon/node_modules/source-map": { + "version": "0.5.7", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/source-map": { + "version": "0.7.3", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">= 8" + } + }, + "node_modules/source-map-resolve": { + "version": "0.5.3", + "dev": true, + "license": "MIT", + "dependencies": { + "atob": "^2.1.2", + "decode-uri-component": "^0.2.0", + "resolve-url": "^0.2.1", + "source-map-url": "^0.4.0", + "urix": "^0.1.0" + } + }, + "node_modules/source-map-support": { + "version": "0.5.21", + "dev": true, + "license": "MIT", + "dependencies": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, + "node_modules/source-map-support/node_modules/source-map": { + "version": "0.6.1", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/source-map-url": { + "version": "0.4.1", + "dev": true, + "license": "MIT" + }, + "node_modules/split-string": { + "version": "3.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "extend-shallow": "^3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sprintf-js": { + "version": "1.0.3", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/stackframe": { + "version": "1.2.0", + "dev": true, + "license": "MIT" + }, + "node_modules/stacktrace-parser": { + "version": "0.1.10", + "dev": true, + "license": "MIT", + "dependencies": { + "type-fest": "^0.7.1" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/static-extend": { + "version": "0.1.2", + "dev": true, + "license": "MIT", + "dependencies": { + "define-property": "^0.2.5", + "object-copy": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/static-extend/node_modules/define-property": { + "version": "0.2.5", + "dev": true, + "license": "MIT", + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/statuses": { + "version": "1.5.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/stream-buffers": { + "version": "2.2.0", + "dev": true, + "license": "Unlicense", + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/string_decoder": { + "version": "1.1.1", + "dev": true, + "license": "MIT", + "dependencies": { + "safe-buffer": "~5.1.0" + } + }, + "node_modules/string-width": { + "version": "4.2.3", + "dev": true, + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/string-width/node_modules/ansi-regex": { + "version": "5.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/string-width/node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/string-width/node_modules/strip-ansi": { + "version": "6.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-ansi": { + "version": "5.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-regex": "^4.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/strip-eof": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sudo-prompt": { + "version": "9.2.1", + "dev": true, + "license": "MIT" + }, + "node_modules/supports-color": { + "version": "7.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/temp": { + "version": "0.8.3", + "dev": true, + "engines": [ + "node >=0.8.0" + ], + "license": "MIT", + "dependencies": { + "os-tmpdir": "^1.0.0", + "rimraf": "~2.2.6" + } + }, + "node_modules/temp/node_modules/rimraf": { + "version": "2.2.8", + "dev": true, + "license": "MIT", + "bin": { + "rimraf": "bin.js" + } + }, + "node_modules/throat": { + "version": "5.0.0", + "dev": true, + "license": "MIT" + }, + "node_modules/through2": { + "version": "2.0.5", + "dev": true, + "license": "MIT", + "dependencies": { + "readable-stream": "~2.3.6", + "xtend": "~4.0.1" + } + }, + "node_modules/tmpl": { + "version": "1.0.5", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/to-fast-properties": { + "version": "2.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/to-object-path": { + "version": "0.3.0", + "dev": true, + "license": "MIT", + "dependencies": { + "kind-of": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/to-object-path/node_modules/kind-of": { + "version": "3.2.2", + "dev": true, + "license": "MIT", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/to-regex": { + "version": "3.0.2", + "dev": true, + "license": "MIT", + "dependencies": { + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "regex-not": "^1.0.2", + "safe-regex": "^1.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/to-regex-range": { + "version": "5.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/toidentifier": { + "version": "1.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.6" + } + }, + "node_modules/tr46": { + "version": "0.0.3", + "dev": true, + "license": "MIT" + }, + "node_modules/tslib": { + "version": "2.3.1", + "license": "0BSD" + }, + "node_modules/type-fest": { + "version": "0.7.1", + "dev": true, + "license": "(MIT OR CC0-1.0)", + "engines": { + "node": ">=8" + } + }, + "node_modules/typescript": { + "version": "4.6.2", + "dev": true, + "license": "Apache-2.0", + "bin": { + "tsc": "bin/tsc", + "tsserver": "bin/tsserver" + }, + "engines": { + "node": ">=4.2.0" + } + }, + "node_modules/uglify-es": { + "version": "3.3.9", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "commander": "~2.13.0", + "source-map": "~0.6.1" + }, + "bin": { + "uglifyjs": "bin/uglifyjs" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/uglify-es/node_modules/commander": { + "version": "2.13.0", + "dev": true, + "license": "MIT" + }, + "node_modules/uglify-es/node_modules/source-map": { + "version": "0.6.1", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ultron": { + "version": "1.0.2", + "dev": true, + "license": "MIT" + }, + "node_modules/unicode-canonical-property-names-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz", + "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicode-match-property-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz", + "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==", + "dev": true, + "dependencies": { + "unicode-canonical-property-names-ecmascript": "^2.0.0", + "unicode-property-aliases-ecmascript": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicode-match-property-value-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.0.0.tgz", + "integrity": "sha512-7Yhkc0Ye+t4PNYzOGKedDhXbYIBe1XEQYQxOPyhcXNMJ0WCABqqj6ckydd6pWRZTHV4GuCPKdBAUiMc60tsKVw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicode-property-aliases-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.0.0.tgz", + "integrity": "sha512-5Zfuy9q/DFr4tfO7ZPeVXb1aPoeQSdeFMLpYuFebehDAhbuevLs5yxSZmIFN1tP5F9Wl4IpJrYojg85/zgyZHQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/union-value": { + "version": "1.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "arr-union": "^3.1.0", + "get-value": "^2.0.6", + "is-extendable": "^0.1.1", + "set-value": "^2.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/universalify": { + "version": "0.1.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 4.0.0" + } + }, + "node_modules/unpipe": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/unset-value": { + "version": "1.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "has-value": "^0.3.1", + "isobject": "^3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/unset-value/node_modules/has-value": { + "version": "0.3.1", + "dev": true, + "license": "MIT", + "dependencies": { + "get-value": "^2.0.3", + "has-values": "^0.1.4", + "isobject": "^2.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/unset-value/node_modules/has-value/node_modules/isobject": { + "version": "2.1.0", + "dev": true, + "license": "MIT", + "dependencies": { + "isarray": "1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/unset-value/node_modules/has-values": { + "version": "0.1.4", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/update-browserslist-db": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.4.tgz", + "integrity": "sha512-jnmO2BEGUjsMOe/Fg9u0oczOe/ppIDZPebzccl1yDWGLFP16Pa1/RM5wEoKYPG2zstNcDuAStejyxsOuKINdGA==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + } + ], + "dependencies": { + "escalade": "^3.1.1", + "picocolors": "^1.0.0" + }, + "bin": { + "browserslist-lint": "cli.js" + }, + "peerDependencies": { + "browserslist": ">= 4.21.0" + } + }, + "node_modules/urix": { + "version": "0.1.0", + "dev": true, + "license": "MIT" + }, + "node_modules/use": { + "version": "3.1.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/use-subscription": { + "version": "1.5.1", + "dev": true, + "license": "MIT", + "dependencies": { + "object-assign": "^4.1.1" + }, + "peerDependencies": { + "react": "^16.8.0 || ^17.0.0" + } + }, + "node_modules/util-deprecate": { + "version": "1.0.2", + "dev": true, + "license": "MIT" + }, + "node_modules/utils-merge": { + "version": "1.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/uuid": { + "version": "3.4.0", + "dev": true, + "license": "MIT", + "bin": { + "uuid": "bin/uuid" + } + }, + "node_modules/vary": { + "version": "1.1.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/vlq": { + "version": "1.0.1", + "dev": true, + "license": "MIT" + }, + "node_modules/walker": { + "version": "1.0.8", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "makeerror": "1.0.12" + } + }, + "node_modules/wcwidth": { + "version": "1.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "defaults": "^1.0.3" + } + }, + "node_modules/webidl-conversions": { + "version": "3.0.1", + "dev": true, + "license": "BSD-2-Clause" + }, + "node_modules/whatwg-fetch": { + "version": "3.6.2", + "dev": true, + "license": "MIT" + }, + "node_modules/whatwg-url": { + "version": "5.0.0", + "dev": true, + "license": "MIT", + "dependencies": { + "tr46": "~0.0.3", + "webidl-conversions": "^3.0.0" + } + }, + "node_modules/which": { + "version": "1.3.1", + "dev": true, + "license": "ISC", + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "which": "bin/which" + } + }, + "node_modules/which-module": { + "version": "2.0.0", + "dev": true, + "license": "ISC" + }, + "node_modules/wrap-ansi": { + "version": "6.2.0", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi/node_modules/ansi-regex": { + "version": "5.0.1", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi/node_modules/strip-ansi": { + "version": "6.0.1", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrappy": { + "version": "1.0.2", + "dev": true, + "license": "ISC" + }, + "node_modules/write-file-atomic": { + "version": "2.4.3", + "dev": true, + "license": "ISC", + "dependencies": { + "graceful-fs": "^4.1.11", + "imurmurhash": "^0.1.4", + "signal-exit": "^3.0.2" + } + }, + "node_modules/ws": { + "version": "6.2.2", + "dev": true, + "license": "MIT", + "dependencies": { + "async-limiter": "~1.0.0" + } + }, + "node_modules/xcode": { + "version": "2.1.0", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "simple-plist": "^1.0.0", + "uuid": "^3.3.2" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/xmlbuilder": { + "version": "9.0.7", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4.0" + } + }, + "node_modules/xmldoc": { + "version": "1.1.2", + "dev": true, + "license": "MIT", + "dependencies": { + "sax": "^1.2.1" + } + }, + "node_modules/xtend": { + "version": "4.0.2", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.4" + } + }, + "node_modules/y18n": { + "version": "4.0.3", + "dev": true, + "license": "ISC" + }, + "node_modules/yargs": { + "version": "15.4.1", + "dev": true, + "license": "MIT", + "dependencies": { + "cliui": "^6.0.0", + "decamelize": "^1.2.0", + "find-up": "^4.1.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^4.2.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^18.1.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs-parser": { + "version": "18.1.3", + "dev": true, + "license": "ISC", + "dependencies": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + }, + "engines": { + "node": ">=6" + } + } + }, "dependencies": { "@babel/code-frame": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.16.7.tgz", - "integrity": "sha512-iAXqUn8IIeBTNd72xsFlgaXHkMBMt6y4HJp1tIaK465CWLT/fG1aqB7ykr95gHHmlBdGbFeWWfyB4NJJ0nmeIg==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", + "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", "dev": true, "requires": { - "@babel/highlight": "^7.16.7" + "@babel/highlight": "^7.18.6" } }, "@babel/compat-data": { - "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.16.8.tgz", - "integrity": "sha512-m7OkX0IdKLKPpBlJtF561YJal5y/jyI5fNfWbPxh2D/nbzzGI4qRyrD8xO2jB24u7l+5I2a43scCG2IrfjC50Q==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.18.6.tgz", + "integrity": "sha512-tzulrgDT0QD6U7BJ4TKVk2SDDg7wlP39P9yAx1RfLy7vP/7rsDRlWVfbWxElslu56+r7QOhB2NSDsabYYruoZQ==", "dev": true }, "@babel/core": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.16.7.tgz", - "integrity": "sha512-aeLaqcqThRNZYmbMqtulsetOQZ/5gbR/dWruUCJcpas4Qoyy+QeagfDsPdMrqwsPRDNxJvBlRiZxxX7THO7qtA==", "dev": true, "requires": { "@babel/code-frame": "^7.16.7", @@ -44,8 +7746,6 @@ "dependencies": { "debug": { "version": "4.3.3", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", - "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", "dev": true, "requires": { "ms": "2.1.2" @@ -53,97 +7753,85 @@ }, "ms": { "version": "2.1.2", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", "dev": true }, "source-map": { "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", "dev": true } } }, "@babel/generator": { - "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.16.8.tgz", - "integrity": "sha512-1ojZwE9+lOXzcWdWmO6TbUzDfqLD39CmEhN8+2cX9XkDo5yW1OpgfejfliysR2AWLpMamTiOiAp/mtroaymhpw==", + "version": "7.18.7", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.18.7.tgz", + "integrity": "sha512-shck+7VLlY72a2w9c3zYWuE1pwOKEiQHV7GTUbSnhyl5eu3i04t30tBY82ZRWrDfo3gkakCFtevExnxbkf2a3A==", "dev": true, "requires": { - "@babel/types": "^7.16.8", - "jsesc": "^2.5.1", - "source-map": "^0.5.0" - }, - "dependencies": { - "source-map": { - "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", - "dev": true - } + "@babel/types": "^7.18.7", + "@jridgewell/gen-mapping": "^0.3.2", + "jsesc": "^2.5.1" } }, "@babel/helper-annotate-as-pure": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.16.7.tgz", - "integrity": "sha512-s6t2w/IPQVTAET1HitoowRGXooX8mCgtuP5195wD/QJPV6wYjpujCGF7JuMODVX2ZAJOf1GT6DT9MHEZvLOFSw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz", + "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==", "dev": true, "requires": { - "@babel/types": "^7.16.7" + "@babel/types": "^7.18.6" } }, "@babel/helper-builder-binary-assignment-operator-visitor": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.16.7.tgz", - "integrity": "sha512-C6FdbRaxYjwVu/geKW4ZeQ0Q31AftgRcdSnZ5/jsH6BzCJbtvXvhpfkbkThYSuutZA7nCXpPR6AD9zd1dprMkA==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.6.tgz", + "integrity": "sha512-KT10c1oWEpmrIRYnthbzHgoOf6B+Xd6a5yhdbNtdhtG7aO1or5HViuf1TQR36xY/QprXA5nvxO6nAjhJ4y38jw==", "dev": true, "requires": { - "@babel/helper-explode-assignable-expression": "^7.16.7", - "@babel/types": "^7.16.7" + "@babel/helper-explode-assignable-expression": "^7.18.6", + "@babel/types": "^7.18.6" } }, "@babel/helper-compilation-targets": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.16.7.tgz", - "integrity": "sha512-mGojBwIWcwGD6rfqgRXVlVYmPAv7eOpIemUG3dGnDdCY4Pae70ROij3XmfrH6Fa1h1aiDylpglbZyktfzyo/hA==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.18.6.tgz", + "integrity": "sha512-vFjbfhNCzqdeAtZflUFrG5YIFqGTqsctrtkZ1D/NB0mDW9TwW3GmmUepYY4G9wCET5rY5ugz4OGTcLd614IzQg==", "dev": true, "requires": { - "@babel/compat-data": "^7.16.4", - "@babel/helper-validator-option": "^7.16.7", - "browserslist": "^4.17.5", + "@babel/compat-data": "^7.18.6", + "@babel/helper-validator-option": "^7.18.6", + "browserslist": "^4.20.2", "semver": "^6.3.0" } }, "@babel/helper-create-class-features-plugin": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.16.7.tgz", - "integrity": "sha512-kIFozAvVfK05DM4EVQYKK+zteWvY85BFdGBRQBytRyY3y+6PX0DkDOn/CZ3lEuczCfrCxEzwt0YtP/87YPTWSw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.18.6.tgz", + "integrity": "sha512-YfDzdnoxHGV8CzqHGyCbFvXg5QESPFkXlHtvdCkesLjjVMT2Adxe4FGUR5ChIb3DxSaXO12iIOCWoXdsUVwnqw==", "dev": true, "requires": { - "@babel/helper-annotate-as-pure": "^7.16.7", - "@babel/helper-environment-visitor": "^7.16.7", - "@babel/helper-function-name": "^7.16.7", - "@babel/helper-member-expression-to-functions": "^7.16.7", - "@babel/helper-optimise-call-expression": "^7.16.7", - "@babel/helper-replace-supers": "^7.16.7", - "@babel/helper-split-export-declaration": "^7.16.7" + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-function-name": "^7.18.6", + "@babel/helper-member-expression-to-functions": "^7.18.6", + "@babel/helper-optimise-call-expression": "^7.18.6", + "@babel/helper-replace-supers": "^7.18.6", + "@babel/helper-split-export-declaration": "^7.18.6" } }, "@babel/helper-create-regexp-features-plugin": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.16.7.tgz", - "integrity": "sha512-fk5A6ymfp+O5+p2yCkXAu5Kyj6v0xh0RBeNcAkYUMDvvAAoxvSKXn+Jb37t/yWFiQVDFK1ELpUTD8/aLhCPu+g==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.18.6.tgz", + "integrity": "sha512-7LcpH1wnQLGrI+4v+nPp+zUvIkF9x0ddv1Hkdue10tg3gmRnLy97DXh4STiOf1qeIInyD69Qv5kKSZzKD8B/7A==", "dev": true, "requires": { - "@babel/helper-annotate-as-pure": "^7.16.7", - "regexpu-core": "^4.7.1" + "@babel/helper-annotate-as-pure": "^7.18.6", + "regexpu-core": "^5.1.0" } }, "@babel/helper-define-polyfill-provider": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.0.tgz", - "integrity": "sha512-7hfT8lUljl/tM3h+izTX/pO3W3frz2ok6Pk+gzys8iJqDfZrZy2pXjRTZAvG2YmfHun1X4q8/UZRLatMfqc5Tg==", + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.1.tgz", + "integrity": "sha512-J9hGMpJQmtWmj46B3kBHmL38UhJGhYX7eqkcq+2gsstyYt341HmPeWspihX43yVRA0mS+8GGk2Gckc7bY/HCmA==", "dev": true, "requires": { "@babel/helper-compilation-targets": "^7.13.0", @@ -157,9 +7845,9 @@ }, "dependencies": { "debug": { - "version": "4.3.3", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", - "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", "dev": true, "requires": { "ms": "2.1.2" @@ -174,180 +7862,166 @@ } }, "@babel/helper-environment-visitor": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.16.7.tgz", - "integrity": "sha512-SLLb0AAn6PkUeAfKJCCOl9e1R53pQlGAfc4y4XuMRZfqeMYLE0dM1LMhqbGAlGQY0lfw5/ohoYWAe9V1yibRag==", - "dev": true, - "requires": { - "@babel/types": "^7.16.7" - } + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.6.tgz", + "integrity": "sha512-8n6gSfn2baOY+qlp+VSzsosjCVGFqWKmDF0cCWOybh52Dw3SEyoWR1KrhMJASjLwIEkkAufZ0xvr+SxLHSpy2Q==", + "dev": true }, "@babel/helper-explode-assignable-expression": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.16.7.tgz", - "integrity": "sha512-KyUenhWMC8VrxzkGP0Jizjo4/Zx+1nNZhgocs+gLzyZyB8SHidhoq9KK/8Ato4anhwsivfkBLftky7gvzbZMtQ==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz", + "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==", "dev": true, "requires": { - "@babel/types": "^7.16.7" + "@babel/types": "^7.18.6" } }, "@babel/helper-function-name": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.16.7.tgz", - "integrity": "sha512-QfDfEnIUyyBSR3HtrtGECuZ6DAyCkYFp7GHl75vFtTnn6pjKeK0T1DB5lLkFvBea8MdaiUABx3osbgLyInoejA==", - "dev": true, - "requires": { - "@babel/helper-get-function-arity": "^7.16.7", - "@babel/template": "^7.16.7", - "@babel/types": "^7.16.7" - } - }, - "@babel/helper-get-function-arity": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.16.7.tgz", - "integrity": "sha512-flc+RLSOBXzNzVhcLu6ujeHUrD6tANAOU5ojrRx/as+tbzf8+stUCj7+IfRRoAbEZqj/ahXEMsjhOhgeZsrnTw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.18.6.tgz", + "integrity": "sha512-0mWMxV1aC97dhjCah5U5Ua7668r5ZmSC2DLfH2EZnf9c3/dHZKiFa5pRLMH5tjSl471tY6496ZWk/kjNONBxhw==", "dev": true, "requires": { - "@babel/types": "^7.16.7" + "@babel/template": "^7.18.6", + "@babel/types": "^7.18.6" } }, "@babel/helper-hoist-variables": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.16.7.tgz", - "integrity": "sha512-m04d/0Op34H5v7pbZw6pSKP7weA6lsMvfiIAMeIvkY/R4xQtBSMFEigu9QTZ2qB/9l22vsxtM8a+Q8CzD255fg==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", + "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", "dev": true, "requires": { - "@babel/types": "^7.16.7" + "@babel/types": "^7.18.6" } }, "@babel/helper-member-expression-to-functions": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.16.7.tgz", - "integrity": "sha512-VtJ/65tYiU/6AbMTDwyoXGPKHgTsfRarivm+YbB5uAzKUyuPjgZSgAFeG87FCigc7KNHu2Pegh1XIT3lXjvz3Q==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.18.6.tgz", + "integrity": "sha512-CeHxqwwipekotzPDUuJOfIMtcIHBuc7WAzLmTYWctVigqS5RktNMQ5bEwQSuGewzYnCtTWa3BARXeiLxDTv+Ng==", "dev": true, "requires": { - "@babel/types": "^7.16.7" + "@babel/types": "^7.18.6" } }, "@babel/helper-module-imports": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.16.7.tgz", - "integrity": "sha512-LVtS6TqjJHFc+nYeITRo6VLXve70xmq7wPhWTqDJusJEgGmkAACWwMiTNrvfoQo6hEhFwAIixNkvB0jPXDL8Wg==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz", + "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==", "dev": true, "requires": { - "@babel/types": "^7.16.7" + "@babel/types": "^7.18.6" } }, "@babel/helper-module-transforms": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.16.7.tgz", - "integrity": "sha512-gaqtLDxJEFCeQbYp9aLAefjhkKdjKcdh6DB7jniIGU3Pz52WAmP268zK0VgPz9hUNkMSYeH976K2/Y6yPadpng==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.18.6.tgz", + "integrity": "sha512-L//phhB4al5uucwzlimruukHB3jRd5JGClwRMD/ROrVjXfLqovYnvQrK/JK36WYyVwGGO7OD3kMyVTjx+WVPhw==", "dev": true, "requires": { - "@babel/helper-environment-visitor": "^7.16.7", - "@babel/helper-module-imports": "^7.16.7", - "@babel/helper-simple-access": "^7.16.7", - "@babel/helper-split-export-declaration": "^7.16.7", - "@babel/helper-validator-identifier": "^7.16.7", - "@babel/template": "^7.16.7", - "@babel/traverse": "^7.16.7", - "@babel/types": "^7.16.7" + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-module-imports": "^7.18.6", + "@babel/helper-simple-access": "^7.18.6", + "@babel/helper-split-export-declaration": "^7.18.6", + "@babel/helper-validator-identifier": "^7.18.6", + "@babel/template": "^7.18.6", + "@babel/traverse": "^7.18.6", + "@babel/types": "^7.18.6" } }, "@babel/helper-optimise-call-expression": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.16.7.tgz", - "integrity": "sha512-EtgBhg7rd/JcnpZFXpBy0ze1YRfdm7BnBX4uKMBd3ixa3RGAE002JZB66FJyNH7g0F38U05pXmA5P8cBh7z+1w==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz", + "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==", "dev": true, "requires": { - "@babel/types": "^7.16.7" + "@babel/types": "^7.18.6" } }, "@babel/helper-plugin-utils": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.16.7.tgz", - "integrity": "sha512-Qg3Nk7ZxpgMrsox6HreY1ZNKdBq7K72tDSliA6dCl5f007jR4ne8iD5UzuNnCJH2xBf2BEEVGr+/OL6Gdp7RxA==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.18.6.tgz", + "integrity": "sha512-gvZnm1YAAxh13eJdkb9EWHBnF3eAub3XTLCZEehHT2kWxiKVRL64+ae5Y6Ivne0mVHmMYKT+xWgZO+gQhuLUBg==", "dev": true }, "@babel/helper-remap-async-to-generator": { - "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.16.8.tgz", - "integrity": "sha512-fm0gH7Flb8H51LqJHy3HJ3wnE1+qtYR2A99K06ahwrawLdOFsCEWjZOrYricXJHoPSudNKxrMBUPEIPxiIIvBw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.6.tgz", + "integrity": "sha512-z5wbmV55TveUPZlCLZvxWHtrjuJd+8inFhk7DG0WW87/oJuGDcjDiu7HIvGcpf5464L6xKCg3vNkmlVVz9hwyQ==", "dev": true, "requires": { - "@babel/helper-annotate-as-pure": "^7.16.7", - "@babel/helper-wrap-function": "^7.16.8", - "@babel/types": "^7.16.8" + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-wrap-function": "^7.18.6", + "@babel/types": "^7.18.6" } }, "@babel/helper-replace-supers": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.16.7.tgz", - "integrity": "sha512-y9vsWilTNaVnVh6xiJfABzsNpgDPKev9HnAgz6Gb1p6UUwf9NepdlsV7VXGCftJM+jqD5f7JIEubcpLjZj5dBw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.18.6.tgz", + "integrity": "sha512-fTf7zoXnUGl9gF25fXCWE26t7Tvtyn6H4hkLSYhATwJvw2uYxd3aoXplMSe0g9XbwK7bmxNes7+FGO0rB/xC0g==", "dev": true, "requires": { - "@babel/helper-environment-visitor": "^7.16.7", - "@babel/helper-member-expression-to-functions": "^7.16.7", - "@babel/helper-optimise-call-expression": "^7.16.7", - "@babel/traverse": "^7.16.7", - "@babel/types": "^7.16.7" + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-member-expression-to-functions": "^7.18.6", + "@babel/helper-optimise-call-expression": "^7.18.6", + "@babel/traverse": "^7.18.6", + "@babel/types": "^7.18.6" } }, "@babel/helper-simple-access": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.16.7.tgz", - "integrity": "sha512-ZIzHVyoeLMvXMN/vok/a4LWRy8G2v205mNP0XOuf9XRLyX5/u9CnVulUtDgUTama3lT+bf/UqucuZjqiGuTS1g==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz", + "integrity": "sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g==", "dev": true, "requires": { - "@babel/types": "^7.16.7" + "@babel/types": "^7.18.6" } }, "@babel/helper-skip-transparent-expression-wrappers": { - "version": "7.16.0", - "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.16.0.tgz", - "integrity": "sha512-+il1gTy0oHwUsBQZyJvukbB4vPMdcYBrFHa0Uc4AizLxbq6BOYC51Rv4tWocX9BLBDLZ4kc6qUFpQ6HRgL+3zw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.18.6.tgz", + "integrity": "sha512-4KoLhwGS9vGethZpAhYnMejWkX64wsnHPDwvOsKWU6Fg4+AlK2Jz3TyjQLMEPvz+1zemi/WBdkYxCD0bAfIkiw==", "dev": true, "requires": { - "@babel/types": "^7.16.0" + "@babel/types": "^7.18.6" } }, "@babel/helper-split-export-declaration": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.16.7.tgz", - "integrity": "sha512-xbWoy/PFoxSWazIToT9Sif+jJTlrMcndIsaOKvTA6u7QEo7ilkRZpjew18/W3c7nm8fXdUDXh02VXTbZ0pGDNw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", + "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", "dev": true, "requires": { - "@babel/types": "^7.16.7" + "@babel/types": "^7.18.6" } }, "@babel/helper-validator-identifier": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.16.7.tgz", - "integrity": "sha512-hsEnFemeiW4D08A5gUAZxLBTXpZ39P+a+DGDsHw1yxqyQ/jzFEnxf5uTEGp+3bzAbNOxU1paTgYS4ECU/IgfDw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz", + "integrity": "sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g==", "dev": true }, "@babel/helper-validator-option": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.16.7.tgz", - "integrity": "sha512-TRtenOuRUVo9oIQGPC5G9DgK4743cdxvtOw0weQNpZXaS16SCBi5MNjZF8vba3ETURjZpTbVn7Vvcf2eAwFozQ==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz", + "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==", "dev": true }, "@babel/helper-wrap-function": { - "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.16.8.tgz", - "integrity": "sha512-8RpyRVIAW1RcDDGTA+GpPAwV22wXCfKOoM9bet6TLkGIFTkRQSkH1nMQ5Yet4MpoXe1ZwHPVtNasc2w0uZMqnw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.18.6.tgz", + "integrity": "sha512-I5/LZfozwMNbwr/b1vhhuYD+J/mU+gfGAj5td7l5Rv9WYmH6i3Om69WGKNmlIpsVW/mF6O5bvTKbvDQZVgjqOw==", "dev": true, "requires": { - "@babel/helper-function-name": "^7.16.7", - "@babel/template": "^7.16.7", - "@babel/traverse": "^7.16.8", - "@babel/types": "^7.16.8" + "@babel/helper-function-name": "^7.18.6", + "@babel/template": "^7.18.6", + "@babel/traverse": "^7.18.6", + "@babel/types": "^7.18.6" } }, "@babel/helpers": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.16.7.tgz", - "integrity": "sha512-9ZDoqtfY7AuEOt3cxchfii6C7GDyyMBffktR5B2jvWv8u2+efwvpnVKXMWzNehqy68tKgAfSwfdw/lWpthS2bw==", "dev": true, "requires": { "@babel/template": "^7.16.7", @@ -356,12 +8030,12 @@ } }, "@babel/highlight": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.16.7.tgz", - "integrity": "sha512-aKpPMfLvGO3Q97V0qhw/V2SWNWlwfJknuwAunU7wZLSfrM4xTBvg7E5opUVi1kJTBKihE38CPg4nBiqX83PWYw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", + "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", "dev": true, "requires": { - "@babel/helper-validator-identifier": "^7.16.7", + "@babel/helper-validator-identifier": "^7.18.6", "chalk": "^2.0.0", "js-tokens": "^4.0.0" }, @@ -398,13 +8072,13 @@ "color-name": { "version": "1.1.3", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", "dev": true }, "has-flag": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", "dev": true }, "supports-color": { @@ -419,88 +8093,239 @@ } }, "@babel/parser": { - "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.16.8.tgz", - "integrity": "sha512-i7jDUfrVBWc+7OKcBzEe5n7fbv3i2fWtxKzzCvOjnzSxMfWMigAhtfJ7qzZNGFNMsCCd67+uz553dYKWXPvCKw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.18.6.tgz", + "integrity": "sha512-uQVSa9jJUe/G/304lXspfWVpKpK4euFLgGiMQFOCpM/bgcAdeoHwi/OQz23O9GK2osz26ZiXRRV9aV+Yl1O8tw==", "dev": true }, + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz", + "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.18.6.tgz", + "integrity": "sha512-Udgu8ZRgrBrttVz6A0EVL0SJ1z+RLbIeqsu632SA1hf0awEppD6TvdznoH+orIF8wtFFAV/Enmw9Y+9oV8TQcw==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-skip-transparent-expression-wrappers": "^7.18.6", + "@babel/plugin-proposal-optional-chaining": "^7.18.6" + } + }, + "@babel/plugin-proposal-async-generator-functions": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.18.6.tgz", + "integrity": "sha512-WAz4R9bvozx4qwf74M+sfqPMKfSqwM0phxPTR6iJIi8robgzXwkEgmeJG1gEKhm6sDqT/U9aV3lfcqybIpev8w==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-remap-async-to-generator": "^7.18.6", + "@babel/plugin-syntax-async-generators": "^7.8.4" + } + }, "@babel/plugin-proposal-class-properties": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.16.7.tgz", - "integrity": "sha512-IobU0Xme31ewjYOShSIqd/ZGM/r/cuOz2z0MDbNrhF5FW+ZVgi0f2lyeoj9KFPDOAqsYxmLWZte1WOwlvY9aww==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz", + "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==", "dev": true, "requires": { - "@babel/helper-create-class-features-plugin": "^7.16.7", - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-proposal-class-static-block": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.18.6.tgz", + "integrity": "sha512-+I3oIiNxrCpup3Gi8n5IGMwj0gOCAjcJUSQEcotNnCCPMEnixawOQ+KeJPlgfjzx+FKQ1QSyZOWe7wmoJp7vhw==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-class-static-block": "^7.14.5" + } + }, + "@babel/plugin-proposal-dynamic-import": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz", + "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-dynamic-import": "^7.8.3" } }, "@babel/plugin-proposal-export-default-from": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-default-from/-/plugin-proposal-export-default-from-7.16.7.tgz", - "integrity": "sha512-+cENpW1rgIjExn+o5c8Jw/4BuH4eGKKYvkMB8/0ZxFQ9mC0t4z09VsPIwNg6waF69QYC81zxGeAsREGuqQoKeg==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7", "@babel/plugin-syntax-export-default-from": "^7.16.7" } }, + "@babel/plugin-proposal-export-namespace-from": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.6.tgz", + "integrity": "sha512-zr/QcUlUo7GPo6+X1wC98NJADqmy5QTFWWhqeQWiki4XHafJtLl/YMGkmRB2szDD2IYJCCdBTd4ElwhId9T7Xw==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3" + } + }, + "@babel/plugin-proposal-json-strings": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz", + "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-json-strings": "^7.8.3" + } + }, + "@babel/plugin-proposal-logical-assignment-operators": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.18.6.tgz", + "integrity": "sha512-zMo66azZth/0tVd7gmkxOkOjs2rpHyhpcFo565PUP37hSp6hSd9uUKIfTDFMz58BwqgQKhJ9YxtM5XddjXVn+Q==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" + } + }, "@babel/plugin-proposal-nullish-coalescing-operator": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.16.7.tgz", - "integrity": "sha512-aUOrYU3EVtjf62jQrCj63pYZ7k6vns2h/DQvHPWGmsJRYzWXZ6/AsfgpiRy6XiuIDADhJzP2Q9MwSMKauBQ+UQ==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz", + "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7", + "@babel/helper-plugin-utils": "^7.18.6", "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" } }, + "@babel/plugin-proposal-numeric-separator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz", + "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-numeric-separator": "^7.10.4" + } + }, "@babel/plugin-proposal-object-rest-spread": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.16.7.tgz", - "integrity": "sha512-3O0Y4+dw94HA86qSg9IHfyPktgR7q3gpNVAeiKQd+8jBKFaU5NQS1Yatgo4wY+UFNuLjvxcSmzcsHqrhgTyBUA==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.18.6.tgz", + "integrity": "sha512-9yuM6wr4rIsKa1wlUAbZEazkCrgw2sMPEXCr4Rnwetu7cEW1NydkCWytLuYletbf8vFxdJxFhwEZqMpOx2eZyw==", "dev": true, "requires": { - "@babel/compat-data": "^7.16.4", - "@babel/helper-compilation-targets": "^7.16.7", - "@babel/helper-plugin-utils": "^7.16.7", + "@babel/compat-data": "^7.18.6", + "@babel/helper-compilation-targets": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-transform-parameters": "^7.16.7" + "@babel/plugin-transform-parameters": "^7.18.6" } }, "@babel/plugin-proposal-optional-catch-binding": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.16.7.tgz", - "integrity": "sha512-eMOH/L4OvWSZAE1VkHbr1vckLG1WUcHGJSLqqQwl2GaUqG6QjddvrOaTUMNYiv77H5IKPMZ9U9P7EaHwvAShfA==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz", + "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" + } + }, + "@babel/plugin-proposal-optional-chaining": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.18.6.tgz", + "integrity": "sha512-PatI6elL5eMzoypFAiYDpYQyMtXTn+iMhuxxQt5mAXD4fEmKorpSI3PHd+i3JXBJN3xyA6MvJv7at23HffFHwA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-skip-transparent-expression-wrappers": "^7.18.6", + "@babel/plugin-syntax-optional-chaining": "^7.8.3" + } + }, + "@babel/plugin-proposal-private-methods": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz", + "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-proposal-private-property-in-object": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.18.6.tgz", + "integrity": "sha512-9Rysx7FOctvT5ouj5JODjAFAkgGoudQuLPamZb0v1TGLpapdNaftzifU8NTWQm0IRjqoYypdrSmyWgkocDQ8Dw==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5" + } + }, + "@babel/plugin-proposal-unicode-property-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz", + "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==", "dev": true, + "peer": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" } }, - "@babel/plugin-proposal-optional-chaining": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.16.7.tgz", - "integrity": "sha512-eC3xy+ZrUcBtP7x+sq62Q/HYd674pPTb/77XZMb5wbDPGWIdUbSr4Agr052+zaUPSb+gGRnjxXfKFvx5iMJ+DA==", + "@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", "dev": true, + "peer": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7", - "@babel/helper-skip-transparent-expression-wrappers": "^7.16.0", - "@babel/plugin-syntax-optional-chaining": "^7.8.3" + "@babel/helper-plugin-utils": "^7.8.0" } }, "@babel/plugin-syntax-class-properties": { "version": "7.12.13", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", - "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.12.13" } }, + "@babel/plugin-syntax-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", + "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, "@babel/plugin-syntax-dynamic-import": { "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", - "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.8.0" @@ -508,44 +8333,84 @@ }, "@babel/plugin-syntax-export-default-from": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-default-from/-/plugin-syntax-export-default-from-7.16.7.tgz", - "integrity": "sha512-4C3E4NsrLOgftKaTYTULhHsuQrGv3FHrBzOMDiS7UYKIpgGBkAdawg4h+EI8zPeK9M0fiIIh72hIwsI24K7MbA==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7" } }, + "@babel/plugin-syntax-export-namespace-from": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz", + "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, "@babel/plugin-syntax-flow": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-flow/-/plugin-syntax-flow-7.16.7.tgz", - "integrity": "sha512-UDo3YGQO0jH6ytzVwgSLv9i/CzMcUjbKenL67dTrAZPPv6GFAtDhe6jqnvmoKzC/7htNTohhos+onPtDMqJwaQ==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7" } }, + "@babel/plugin-syntax-import-assertions": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.18.6.tgz", + "integrity": "sha512-/DU3RXad9+bZwrgWJQKbr39gYbJpLJHezqEzRzi/BHRlJ9zsQb4CK2CA/5apllXNomwA1qHwzvHl+AdEmC5krQ==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, "@babel/plugin-syntax-jsx": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.16.7.tgz", - "integrity": "sha512-Esxmk7YjA8QysKeT3VhTXvF6y77f/a91SIs4pWb4H2eWGQkCKFgQaG6hdoEVZtGsrAcb2K5BW66XsOErD4WU3Q==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7" } }, + "@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, "@babel/plugin-syntax-nullish-coalescing-operator": { "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", - "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.8.0" } }, + "@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, "@babel/plugin-syntax-object-rest-spread": { "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", - "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.8.0" @@ -553,8 +8418,6 @@ }, "@babel/plugin-syntax-optional-catch-binding": { "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", - "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.8.0" @@ -562,108 +8425,143 @@ }, "@babel/plugin-syntax-optional-chaining": { "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", - "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.8.0" } }, + "@babel/plugin-syntax-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", + "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, "@babel/plugin-syntax-typescript": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.16.7.tgz", - "integrity": "sha512-YhUIJHHGkqPgEcMYkPCKTyGUdoGKWtopIycQyjJH8OjvRgOYsXsaKehLVPScKJWAULPxMa4N1vCe6szREFlZ7A==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7" } }, "@babel/plugin-transform-arrow-functions": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.16.7.tgz", - "integrity": "sha512-9ffkFFMbvzTvv+7dTp/66xvZAWASuPD5Tl9LK3Z9vhOmANo6j94rik+5YMBt4CwHVMWLWpMsriIc2zsa3WW3xQ==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.18.6.tgz", + "integrity": "sha512-9S9X9RUefzrsHZmKMbDXxweEH+YlE8JJEuat9FdvW9Qh1cw7W64jELCtWNkPBPX5En45uy28KGvA/AySqUh8CQ==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-async-to-generator": { - "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.16.8.tgz", - "integrity": "sha512-MtmUmTJQHCnyJVrScNzNlofQJ3dLFuobYn3mwOTKHnSCMtbNsqvF71GQmJfFjdrXSsAA7iysFmYWw4bXZ20hOg==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.18.6.tgz", + "integrity": "sha512-ARE5wZLKnTgPW7/1ftQmSi1CmkqqHo2DNmtztFhvgtOWSDfq0Cq9/9L+KnZNYSNrydBekhW3rwShduf59RoXag==", "dev": true, "requires": { - "@babel/helper-module-imports": "^7.16.7", - "@babel/helper-plugin-utils": "^7.16.7", - "@babel/helper-remap-async-to-generator": "^7.16.8" + "@babel/helper-module-imports": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-remap-async-to-generator": "^7.18.6" } }, "@babel/plugin-transform-block-scoped-functions": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.16.7.tgz", - "integrity": "sha512-JUuzlzmF40Z9cXyytcbZEZKckgrQzChbQJw/5PuEHYeqzCsvebDx0K0jWnIIVcmmDOAVctCgnYs0pMcrYj2zJg==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz", + "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-block-scoping": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.16.7.tgz", - "integrity": "sha512-ObZev2nxVAYA4bhyusELdo9hb3H+A56bxH3FZMbEImZFiEDYVHXQSJ1hQKFlDnlt8G9bBrCZ5ZpURZUrV4G5qQ==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.18.6.tgz", + "integrity": "sha512-pRqwb91C42vs1ahSAWJkxOxU1RHWDn16XAa6ggQ72wjLlWyYeAcLvTtE0aM8ph3KNydy9CQF2nLYcjq1WysgxQ==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-classes": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.16.7.tgz", - "integrity": "sha512-WY7og38SFAGYRe64BrjKf8OrE6ulEHtr5jEYaZMwox9KebgqPi67Zqz8K53EKk1fFEJgm96r32rkKZ3qA2nCWQ==", - "dev": true, - "requires": { - "@babel/helper-annotate-as-pure": "^7.16.7", - "@babel/helper-environment-visitor": "^7.16.7", - "@babel/helper-function-name": "^7.16.7", - "@babel/helper-optimise-call-expression": "^7.16.7", - "@babel/helper-plugin-utils": "^7.16.7", - "@babel/helper-replace-supers": "^7.16.7", - "@babel/helper-split-export-declaration": "^7.16.7", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.18.6.tgz", + "integrity": "sha512-XTg8XW/mKpzAF3actL554Jl/dOYoJtv3l8fxaEczpgz84IeeVf+T1u2CSvPHuZbt0w3JkIx4rdn/MRQI7mo0HQ==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-function-name": "^7.18.6", + "@babel/helper-optimise-call-expression": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-replace-supers": "^7.18.6", + "@babel/helper-split-export-declaration": "^7.18.6", "globals": "^11.1.0" } }, "@babel/plugin-transform-computed-properties": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.16.7.tgz", - "integrity": "sha512-gN72G9bcmenVILj//sv1zLNaPyYcOzUho2lIJBMh/iakJ9ygCo/hEF9cpGb61SCMEDxbbyBoVQxrt+bWKu5KGw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.18.6.tgz", + "integrity": "sha512-9repI4BhNrR0KenoR9vm3/cIc1tSBIo+u1WVjKCAynahj25O8zfbiE6JtAtHPGQSs4yZ+bA8mRasRP+qc+2R5A==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-destructuring": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.16.7.tgz", - "integrity": "sha512-VqAwhTHBnu5xBVDCvrvqJbtLUa++qZaWC0Fgr2mqokBlulZARGyIvZDoqbPlPaKImQ9dKAcCzbv+ul//uqu70A==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.18.6.tgz", + "integrity": "sha512-tgy3u6lRp17ilY8r1kP4i2+HDUwxlVqq3RTc943eAWSzGgpU1qhiKpqZ5CMyHReIYPHdo3Kg8v8edKtDqSVEyQ==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-dotall-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz", + "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-duplicate-keys": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.6.tgz", + "integrity": "sha512-NJU26U/208+sxYszf82nmGYqVF9QN8py2HFTblPT9hbawi8+1C5a9JubODLTGFuT0qlkqVinmkwOD13s0sZktg==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-exponentiation-operator": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.16.7.tgz", - "integrity": "sha512-8UYLSlyLgRixQvlYH3J2ekXFHDFLQutdy7FfFAMm3CPZ6q9wHCwnUyiXpQCe3gVVnQlHc5nsuiEVziteRNTXEA==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz", + "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==", "dev": true, "requires": { - "@babel/helper-builder-binary-assignment-operator-visitor": "^7.16.7", - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-flow-strip-types": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-flow-strip-types/-/plugin-transform-flow-strip-types-7.16.7.tgz", - "integrity": "sha512-mzmCq3cNsDpZZu9FADYYyfZJIOrSONmHcop2XEKPdBNMa4PDC4eEvcOvzZaCNcjKu72v0XQlA5y1g58aLRXdYg==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7", @@ -671,96 +8569,150 @@ } }, "@babel/plugin-transform-for-of": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.16.7.tgz", - "integrity": "sha512-/QZm9W92Ptpw7sjI9Nx1mbcsWz33+l8kuMIQnDwgQBG5s3fAfQvkRjQ7NqXhtNcKOnPkdICmUHyCaWW06HCsqg==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.6.tgz", + "integrity": "sha512-WAjoMf4wIiSsy88KmG7tgj2nFdEK7E46tArVtcgED7Bkj6Fg/tG5SbvNIOKxbFS2VFgNh6+iaPswBeQZm4ox8w==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-function-name": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.16.7.tgz", - "integrity": "sha512-SU/C68YVwTRxqWj5kgsbKINakGag0KTgq9f2iZEXdStoAbOzLHEBRYzImmA6yFo8YZhJVflvXmIHUO7GWHmxxA==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.6.tgz", + "integrity": "sha512-kJha/Gbs5RjzIu0CxZwf5e3aTTSlhZnHMT8zPWnJMjNpLOUgqevg+PN5oMH68nMCXnfiMo4Bhgxqj59KHTlAnA==", "dev": true, "requires": { - "@babel/helper-compilation-targets": "^7.16.7", - "@babel/helper-function-name": "^7.16.7", - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-compilation-targets": "^7.18.6", + "@babel/helper-function-name": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-literals": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.16.7.tgz", - "integrity": "sha512-6tH8RTpTWI0s2sV6uq3e/C9wPo4PTqqZps4uF0kzQ9/xPLFQtipynvmT1g/dOfEJ+0EQsHhkQ/zyRId8J2b8zQ==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.6.tgz", + "integrity": "sha512-x3HEw0cJZVDoENXOp20HlypIHfl0zMIhMVZEBVTfmqbObIpsMxMbmU5nOEO8R7LYT+z5RORKPlTI5Hj4OsO9/Q==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-member-expression-literals": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.16.7.tgz", - "integrity": "sha512-mBruRMbktKQwbxaJof32LT9KLy2f3gH+27a5XSuXo6h7R3vqltl0PgZ80C8ZMKw98Bf8bqt6BEVi3svOh2PzMw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz", + "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-modules-amd": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.18.6.tgz", + "integrity": "sha512-Pra5aXsmTsOnjM3IajS8rTaLCy++nGM4v3YR4esk5PCsyg9z8NA5oQLwxzMUtDBd8F+UmVza3VxoAaWCbzH1rg==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-module-transforms": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "babel-plugin-dynamic-import-node": "^2.3.3" } }, "@babel/plugin-transform-modules-commonjs": { - "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.16.8.tgz", - "integrity": "sha512-oflKPvsLT2+uKQopesJt3ApiaIS2HW+hzHFcwRNtyDGieAeC/dIHZX8buJQ2J2X1rxGPy4eRcUijm3qcSPjYcA==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.18.6.tgz", + "integrity": "sha512-Qfv2ZOWikpvmedXQJDSbxNqy7Xr/j2Y8/KfijM0iJyKkBTmWuvCA1yeH1yDM7NJhBW/2aXxeucLj6i80/LAJ/Q==", "dev": true, "requires": { - "@babel/helper-module-transforms": "^7.16.7", - "@babel/helper-plugin-utils": "^7.16.7", - "@babel/helper-simple-access": "^7.16.7", + "@babel/helper-module-transforms": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-simple-access": "^7.18.6", + "babel-plugin-dynamic-import-node": "^2.3.3" + } + }, + "@babel/plugin-transform-modules-systemjs": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.18.6.tgz", + "integrity": "sha512-UbPYpXxLjTw6w6yXX2BYNxF3p6QY225wcTkfQCy3OMnSlS/C3xGtwUjEzGkldb/sy6PWLiCQ3NbYfjWUTI3t4g==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-hoist-variables": "^7.18.6", + "@babel/helper-module-transforms": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-validator-identifier": "^7.18.6", "babel-plugin-dynamic-import-node": "^2.3.3" } }, + "@babel/plugin-transform-modules-umd": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz", + "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-module-transforms": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.18.6.tgz", + "integrity": "sha512-UmEOGF8XgaIqD74bC8g7iV3RYj8lMf0Bw7NJzvnS9qQhM4mg+1WHKotUIdjxgD2RGrgFLZZPCFPFj3P/kVDYhg==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-new-target": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz", + "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, "@babel/plugin-transform-object-assign": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-assign/-/plugin-transform-object-assign-7.16.7.tgz", - "integrity": "sha512-R8mawvm3x0COTJtveuoqZIjNypn2FjfvXZr4pSQ8VhEFBuQGBz4XhHasZtHXjgXU4XptZ4HtGof3NoYc93ZH9Q==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7" } }, "@babel/plugin-transform-object-super": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.16.7.tgz", - "integrity": "sha512-14J1feiQVWaGvRxj2WjyMuXS2jsBkgB3MdSN5HuC2G5nRspa5RK9COcs82Pwy5BuGcjb+fYaUj94mYcOj7rCvw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz", + "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7", - "@babel/helper-replace-supers": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-replace-supers": "^7.18.6" } }, "@babel/plugin-transform-parameters": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.16.7.tgz", - "integrity": "sha512-AT3MufQ7zZEhU2hwOA11axBnExW0Lszu4RL/tAlUJBuNoRak+wehQW8h6KcXOcgjY42fHtDxswuMhMjFEuv/aw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.18.6.tgz", + "integrity": "sha512-FjdqgMv37yVl/gwvzkcB+wfjRI8HQmc5EgOG9iGNvUY1ok+TjsoaMP7IqCDZBhkFcM5f3OPVMs6Dmp03C5k4/A==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-property-literals": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.16.7.tgz", - "integrity": "sha512-z4FGr9NMGdoIl1RqavCqGG+ZuYjfZ/hkCIeuH6Do7tXmSm0ls11nYVSJqFEUOSJbDab5wC6lRE/w6YjVcr6Hqw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz", + "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-react-display-name": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.16.7.tgz", - "integrity": "sha512-qgIg8BcZgd0G/Cz916D5+9kqX0c7nPZyXaP8R2tLNN5tkyIZdG5fEwBrxwplzSnjC1jvQmyMNVwUCZPcbGY7Pg==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7" @@ -768,8 +8720,6 @@ }, "@babel/plugin-transform-react-jsx": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.16.7.tgz", - "integrity": "sha512-8D16ye66fxiE8m890w0BpPpngG9o9OVBBy0gH2E+2AR7qMR2ZpTYJEqLxAsoroenMId0p/wMW+Blc0meDgu0Ag==", "dev": true, "requires": { "@babel/helper-annotate-as-pure": "^7.16.7", @@ -781,8 +8731,6 @@ }, "@babel/plugin-transform-react-jsx-self": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.16.7.tgz", - "integrity": "sha512-oe5VuWs7J9ilH3BCCApGoYjHoSO48vkjX2CbA5bFVhIuO2HKxA3vyF7rleA4o6/4rTDbk6r8hBW7Ul8E+UZrpA==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7" @@ -790,26 +8738,33 @@ }, "@babel/plugin-transform-react-jsx-source": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.16.7.tgz", - "integrity": "sha512-rONFiQz9vgbsnaMtQlZCjIRwhJvlrPET8TabIUK2hzlXw9B9s2Ieaxte1SCOOXMbWRHodbKixNf3BLcWVOQ8Bw==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7" } }, "@babel/plugin-transform-regenerator": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.16.7.tgz", - "integrity": "sha512-mF7jOgGYCkSJagJ6XCujSQg+6xC1M77/03K2oBmVJWoFGNUtnVJO4WHKJk3dnPC8HCcj4xBQP1Egm8DWh3Pb3Q==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.18.6.tgz", + "integrity": "sha512-poqRI2+qiSdeldcz4wTSTXBRryoq3Gc70ye7m7UD5Ww0nE29IXqMl6r7Nd15WBgRd74vloEMlShtH6CKxVzfmQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "regenerator-transform": "^0.15.0" + } + }, + "@babel/plugin-transform-reserved-words": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz", + "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==", "dev": true, + "peer": true, "requires": { - "regenerator-transform": "^0.14.2" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-runtime": { "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.16.8.tgz", - "integrity": "sha512-6Kg2XHPFnIarNweZxmzbgYnnWsXxkx9WQUVk2sksBRL80lBC1RAQV3wQagWxdCHiYHqPN+oenwNIuttlYgIbQQ==", "dev": true, "requires": { "@babel/helper-module-imports": "^7.16.7", @@ -821,46 +8776,54 @@ } }, "@babel/plugin-transform-shorthand-properties": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.16.7.tgz", - "integrity": "sha512-hah2+FEnoRoATdIb05IOXf+4GzXYTq75TVhIn1PewihbpyrNWUt2JbudKQOETWw6QpLe+AIUpJ5MVLYTQbeeUg==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz", + "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-spread": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.16.7.tgz", - "integrity": "sha512-+pjJpgAngb53L0iaA5gU/1MLXJIfXcYepLgXB3esVRf4fqmj8f2cxM3/FKaHsZms08hFQJkFccEWuIpm429TXg==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.18.6.tgz", + "integrity": "sha512-ayT53rT/ENF8WWexIRg9AiV9h0aIteyWn5ptfZTZQrjk/+f3WdrJGCY4c9wcgl2+MKkKPhzbYp97FTsquZpDCw==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7", - "@babel/helper-skip-transparent-expression-wrappers": "^7.16.0" + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-skip-transparent-expression-wrappers": "^7.18.6" } }, "@babel/plugin-transform-sticky-regex": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.16.7.tgz", - "integrity": "sha512-NJa0Bd/87QV5NZZzTuZG5BPJjLYadeSZ9fO6oOUoL4iQx+9EEuw/eEM92SrsT19Yc2jgB1u1hsjqDtH02c3Drw==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz", + "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-template-literals": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.16.7.tgz", - "integrity": "sha512-VwbkDDUeenlIjmfNeDX/V0aWrQH2QiVyJtwymVQSzItFDTpxfyJh3EVaQiS0rIN/CqbLGr0VcGmuwyTdZtdIsA==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.6.tgz", + "integrity": "sha512-UuqlRrQmT2SWRvahW46cGSany0uTlcj8NYOS5sRGYi8FxPYPoLd5DDmMd32ZXEj2Jq+06uGVQKHxa/hJx2EzKw==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-typeof-symbol": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.6.tgz", + "integrity": "sha512-7m71iS/QhsPk85xSjFPovHPcH3H9qeyzsujhTc+vcdnsXavoWYJ74zx0lP5RhpC5+iDnVLO+PPMHzC11qels1g==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" } }, "@babel/plugin-transform-typescript": { "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.16.8.tgz", - "integrity": "sha512-bHdQ9k7YpBDO2d0NVfkj51DpQcvwIzIusJ7mEUaMlbZq3Kt/U47j24inXZHQ5MDiYpCs+oZiwnXyKedE8+q7AQ==", "dev": true, "requires": { "@babel/helper-create-class-features-plugin": "^7.16.7", @@ -868,20 +8831,112 @@ "@babel/plugin-syntax-typescript": "^7.16.7" } }, - "@babel/plugin-transform-unicode-regex": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.16.7.tgz", - "integrity": "sha512-oC5tYYKw56HO75KZVLQ+R/Nl3Hro9kf8iG0hXoaHP7tjAyCpvqBiSNe6vGrZni1Z6MggmUOC6A7VP7AVmw225Q==", + "@babel/plugin-transform-unicode-escapes": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.6.tgz", + "integrity": "sha512-XNRwQUXYMP7VLuy54cr/KS/WeL3AZeORhrmeZ7iewgu+X2eBqmpaLI/hzqr9ZxCeUoq0ASK4GUzSM0BDhZkLFw==", "dev": true, + "peer": true, "requires": { - "@babel/helper-create-regexp-features-plugin": "^7.16.7", - "@babel/helper-plugin-utils": "^7.16.7" + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-unicode-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz", + "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/preset-env": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.18.6.tgz", + "integrity": "sha512-WrthhuIIYKrEFAwttYzgRNQ5hULGmwTj+D6l7Zdfsv5M7IWV/OZbUfbeL++Qrzx1nVJwWROIFhCHRYQV4xbPNw==", + "dev": true, + "peer": true, + "requires": { + "@babel/compat-data": "^7.18.6", + "@babel/helper-compilation-targets": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-validator-option": "^7.18.6", + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.6", + "@babel/plugin-proposal-async-generator-functions": "^7.18.6", + "@babel/plugin-proposal-class-properties": "^7.18.6", + "@babel/plugin-proposal-class-static-block": "^7.18.6", + "@babel/plugin-proposal-dynamic-import": "^7.18.6", + "@babel/plugin-proposal-export-namespace-from": "^7.18.6", + "@babel/plugin-proposal-json-strings": "^7.18.6", + "@babel/plugin-proposal-logical-assignment-operators": "^7.18.6", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6", + "@babel/plugin-proposal-numeric-separator": "^7.18.6", + "@babel/plugin-proposal-object-rest-spread": "^7.18.6", + "@babel/plugin-proposal-optional-catch-binding": "^7.18.6", + "@babel/plugin-proposal-optional-chaining": "^7.18.6", + "@babel/plugin-proposal-private-methods": "^7.18.6", + "@babel/plugin-proposal-private-property-in-object": "^7.18.6", + "@babel/plugin-proposal-unicode-property-regex": "^7.18.6", + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-class-properties": "^7.12.13", + "@babel/plugin-syntax-class-static-block": "^7.14.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3", + "@babel/plugin-syntax-import-assertions": "^7.18.6", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.10.4", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5", + "@babel/plugin-syntax-top-level-await": "^7.14.5", + "@babel/plugin-transform-arrow-functions": "^7.18.6", + "@babel/plugin-transform-async-to-generator": "^7.18.6", + "@babel/plugin-transform-block-scoped-functions": "^7.18.6", + "@babel/plugin-transform-block-scoping": "^7.18.6", + "@babel/plugin-transform-classes": "^7.18.6", + "@babel/plugin-transform-computed-properties": "^7.18.6", + "@babel/plugin-transform-destructuring": "^7.18.6", + "@babel/plugin-transform-dotall-regex": "^7.18.6", + "@babel/plugin-transform-duplicate-keys": "^7.18.6", + "@babel/plugin-transform-exponentiation-operator": "^7.18.6", + "@babel/plugin-transform-for-of": "^7.18.6", + "@babel/plugin-transform-function-name": "^7.18.6", + "@babel/plugin-transform-literals": "^7.18.6", + "@babel/plugin-transform-member-expression-literals": "^7.18.6", + "@babel/plugin-transform-modules-amd": "^7.18.6", + "@babel/plugin-transform-modules-commonjs": "^7.18.6", + "@babel/plugin-transform-modules-systemjs": "^7.18.6", + "@babel/plugin-transform-modules-umd": "^7.18.6", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.18.6", + "@babel/plugin-transform-new-target": "^7.18.6", + "@babel/plugin-transform-object-super": "^7.18.6", + "@babel/plugin-transform-parameters": "^7.18.6", + "@babel/plugin-transform-property-literals": "^7.18.6", + "@babel/plugin-transform-regenerator": "^7.18.6", + "@babel/plugin-transform-reserved-words": "^7.18.6", + "@babel/plugin-transform-shorthand-properties": "^7.18.6", + "@babel/plugin-transform-spread": "^7.18.6", + "@babel/plugin-transform-sticky-regex": "^7.18.6", + "@babel/plugin-transform-template-literals": "^7.18.6", + "@babel/plugin-transform-typeof-symbol": "^7.18.6", + "@babel/plugin-transform-unicode-escapes": "^7.18.6", + "@babel/plugin-transform-unicode-regex": "^7.18.6", + "@babel/preset-modules": "^0.1.5", + "@babel/types": "^7.18.6", + "babel-plugin-polyfill-corejs2": "^0.3.1", + "babel-plugin-polyfill-corejs3": "^0.5.2", + "babel-plugin-polyfill-regenerator": "^0.3.1", + "core-js-compat": "^3.22.1", + "semver": "^6.3.0" } }, "@babel/preset-flow": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/preset-flow/-/preset-flow-7.16.7.tgz", - "integrity": "sha512-6ceP7IyZdUYQ3wUVqyRSQXztd1YmFHWI4Xv11MIqAlE4WqxBSd/FZ61V9k+TS5Gd4mkHOtQtPp9ymRpxH4y1Ug==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7", @@ -889,10 +8944,22 @@ "@babel/plugin-transform-flow-strip-types": "^7.16.7" } }, + "@babel/preset-modules": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz", + "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==", + "dev": true, + "peer": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-proposal-unicode-property-regex": "^7.4.4", + "@babel/plugin-transform-dotall-regex": "^7.4.4", + "@babel/types": "^7.4.4", + "esutils": "^2.0.2" + } + }, "@babel/preset-typescript": { "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.16.7.tgz", - "integrity": "sha512-WbVEmgXdIyvzB77AQjGBEyYPZx+8tTsO50XtfozQrkW8QB2rLJpH2lgx0TRw5EJrBxOZQ+wCcyPVQvS8tjEHpQ==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.16.7", @@ -902,8 +8969,6 @@ }, "@babel/register": { "version": "7.16.9", - "resolved": "https://registry.npmjs.org/@babel/register/-/register-7.16.9.tgz", - "integrity": "sha512-jJ72wcghdRIlENfvALcyODhNoGE5j75cYHdC+aQMh6cU/P86tiiXTp9XYZct1UxUMo/4+BgQRyNZEGx0KWGS+g==", "dev": true, "requires": { "clone-deep": "^4.0.1", @@ -914,47 +8979,45 @@ } }, "@babel/runtime": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.16.7.tgz", - "integrity": "sha512-9E9FJowqAsytyOY6LG+1KuueckRL+aQW+mKvXRXnuFGyRAyepJPmEo9vgMfXUA6O9u3IeEdv9MAkppFcaQwogQ==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.18.6.tgz", + "integrity": "sha512-t9wi7/AW6XtKahAe20Yw0/mMljKq0B1r2fPdvaAdV/KPDZewFXdaaa6K7lxmZBZ8FBNpCiAT6iHPmd6QO9bKfQ==", "dev": true, "requires": { "regenerator-runtime": "^0.13.4" } }, "@babel/template": { - "version": "7.16.7", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.16.7.tgz", - "integrity": "sha512-I8j/x8kHUrbYRTUxXrrMbfCa7jxkE7tZre39x3kjr9hvI82cK1FfqLygotcWN5kdPGWcLdWMHpSBavse5tWw3w==", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.18.6.tgz", + "integrity": "sha512-JoDWzPe+wgBsTTgdnIma3iHNFC7YVJoPssVBDjiHfNlyt4YcunDtcDOUmfVDfCK5MfdsaIoX9PkijPhjH3nYUw==", "dev": true, "requires": { - "@babel/code-frame": "^7.16.7", - "@babel/parser": "^7.16.7", - "@babel/types": "^7.16.7" + "@babel/code-frame": "^7.18.6", + "@babel/parser": "^7.18.6", + "@babel/types": "^7.18.6" } }, "@babel/traverse": { - "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.16.8.tgz", - "integrity": "sha512-xe+H7JlvKsDQwXRsBhSnq1/+9c+LlQcCK3Tn/l5sbx02HYns/cn7ibp9+RV1sIUqu7hKg91NWsgHurO9dowITQ==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.16.7", - "@babel/generator": "^7.16.8", - "@babel/helper-environment-visitor": "^7.16.7", - "@babel/helper-function-name": "^7.16.7", - "@babel/helper-hoist-variables": "^7.16.7", - "@babel/helper-split-export-declaration": "^7.16.7", - "@babel/parser": "^7.16.8", - "@babel/types": "^7.16.8", + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.18.6.tgz", + "integrity": "sha512-zS/OKyqmD7lslOtFqbscH6gMLFYOfG1YPqCKfAW5KrTeolKqvB8UelR49Fpr6y93kYkW2Ik00mT1LOGiAGvizw==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.18.6", + "@babel/generator": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.6", + "@babel/helper-function-name": "^7.18.6", + "@babel/helper-hoist-variables": "^7.18.6", + "@babel/helper-split-export-declaration": "^7.18.6", + "@babel/parser": "^7.18.6", + "@babel/types": "^7.18.6", "debug": "^4.1.0", "globals": "^11.1.0" }, "dependencies": { "debug": { "version": "4.3.3", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", - "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", "dev": true, "requires": { "ms": "2.1.2" @@ -962,26 +9025,22 @@ }, "ms": { "version": "2.1.2", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", "dev": true } } }, "@babel/types": { - "version": "7.16.8", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.16.8.tgz", - "integrity": "sha512-smN2DQc5s4M7fntyjGtyIPbRJv6wW4rU/94fmYJ7PKQuZkC0qGMHXJbg6sNGt12JmVr4k5YaptI/XtiLJBnmIg==", + "version": "7.18.7", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.18.7.tgz", + "integrity": "sha512-QG3yxTcTIBoAcQmkCs+wAPYZhu7Dk9rXKacINfNbdJDNERTbLQbHGyVG8q/YGMPeCJRIhSY0+fTc5+xuh6WPSQ==", "dev": true, "requires": { - "@babel/helper-validator-identifier": "^7.16.7", + "@babel/helper-validator-identifier": "^7.18.6", "to-fast-properties": "^2.0.0" } }, "@cnakazawa/watch": { "version": "1.0.4", - "resolved": "https://registry.npmjs.org/@cnakazawa/watch/-/watch-1.0.4.tgz", - "integrity": "sha512-v9kIhKwjeZThiWrLmj0y17CWoyddASLj9O2yvbZkbvw/N3rWOYy9zkV66ursAoVr0mV15bL8g0c4QZUE6cdDoQ==", "dev": true, "requires": { "exec-sh": "^0.3.2", @@ -990,14 +9049,10 @@ }, "@hapi/hoek": { "version": "9.2.1", - "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.2.1.tgz", - "integrity": "sha512-gfta+H8aziZsm8pZa0vj04KO6biEiisppNgA1kbJvFrrWu9Vm7eaUEy76DIxsuTaWvti5fkJVhllWc6ZTE+Mdw==", "dev": true }, "@hapi/topo": { "version": "5.1.0", - "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.1.0.tgz", - "integrity": "sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==", "dev": true, "requires": { "@hapi/hoek": "^9.0.0" @@ -1005,8 +9060,6 @@ }, "@jest/create-cache-key-function": { "version": "27.4.2", - "resolved": "https://registry.npmjs.org/@jest/create-cache-key-function/-/create-cache-key-function-27.4.2.tgz", - "integrity": "sha512-aSSCAJwUNX4R1hJQoyimsND5l+2EsFgzlepS8NuOJJHjXij/UdxYFngac44tmv9IYdI+kglAyORg0plt4/aFMQ==", "dev": true, "requires": { "@jest/types": "^27.4.2" @@ -1014,8 +9067,6 @@ }, "@jest/types": { "version": "27.4.2", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.4.2.tgz", - "integrity": "sha512-j35yw0PMTPpZsUoOBiuHzr1zTYoad1cVIE0ajEjcrJONxxrko/IRGKkXx3os0Nsi4Hu3+5VmDbVfq5WhG/pWAg==", "dev": true, "requires": { "@types/istanbul-lib-coverage": "^2.0.0", @@ -1025,10 +9076,47 @@ "chalk": "^4.0.0" } }, + "@jridgewell/gen-mapping": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", + "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", + "dev": true, + "requires": { + "@jridgewell/set-array": "^1.0.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.9" + } + }, + "@jridgewell/resolve-uri": { + "version": "3.0.8", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.0.8.tgz", + "integrity": "sha512-YK5G9LaddzGbcucK4c8h5tWFmMPBvRZ/uyWmN1/SbBdIvqGUdWGkJ5BAaccgs6XbzVLsqbPJrBSFwKv3kT9i7w==", + "dev": true + }, + "@jridgewell/set-array": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", + "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "dev": true + }, + "@jridgewell/sourcemap-codec": { + "version": "1.4.14", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", + "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", + "dev": true + }, + "@jridgewell/trace-mapping": { + "version": "0.3.14", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz", + "integrity": "sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ==", + "dev": true, + "requires": { + "@jridgewell/resolve-uri": "^3.0.3", + "@jridgewell/sourcemap-codec": "^1.4.10" + } + }, "@react-native-community/cli-debugger-ui": { "version": "6.0.0-rc.0", - "resolved": "https://registry.npmjs.org/@react-native-community/cli-debugger-ui/-/cli-debugger-ui-6.0.0-rc.0.tgz", - "integrity": "sha512-achYcPPoWa9D02C5tn6TBzjeY443wQTyx37urptc75JpZ7gR5YHsDyIEEWa3DDYp1va9zx/iGg+uZ/hWw07GAw==", "dev": true, "requires": { "serve-static": "^1.13.1" @@ -1036,8 +9124,6 @@ }, "@react-native-community/cli-hermes": { "version": "6.3.0", - "resolved": "https://registry.npmjs.org/@react-native-community/cli-hermes/-/cli-hermes-6.3.0.tgz", - "integrity": "sha512-Uhbm9bubyZLZ12vFCIfWbE/Qi3SBTbYIN/TC08EudTLhv/KbPomCQnmFsnJ7AXQFuOZJs73mBxoEAYSbRbwyVA==", "dev": true, "requires": { "@react-native-community/cli-platform-android": "^6.3.0", @@ -1049,8 +9135,6 @@ }, "@react-native-community/cli-platform-android": { "version": "6.3.0", - "resolved": "https://registry.npmjs.org/@react-native-community/cli-platform-android/-/cli-platform-android-6.3.0.tgz", - "integrity": "sha512-d5ufyYcvrZoHznYm5bjBXaiHIJv552t5gYtQpnUsxBhHSQ8QlaNmlLUyeSPRDfOw4ND9b0tPHqs4ufwx6vp/fQ==", "dev": true, "requires": { "@react-native-community/cli-tools": "^6.2.0", @@ -1067,8 +9151,6 @@ }, "@react-native-community/cli-platform-ios": { "version": "6.2.0", - "resolved": "https://registry.npmjs.org/@react-native-community/cli-platform-ios/-/cli-platform-ios-6.2.0.tgz", - "integrity": "sha512-k15MhExxLiLDDZOeuPgvTxbp0CsoLQQpk2Du0HjZDePqqWcKJylQqMZru1o8HuQHPcEr+b71HIs5V+lKyFYpfg==", "dev": true, "requires": { "@react-native-community/cli-tools": "^6.2.0", @@ -1083,8 +9165,6 @@ }, "@react-native-community/cli-plugin-metro": { "version": "6.2.0", - "resolved": "https://registry.npmjs.org/@react-native-community/cli-plugin-metro/-/cli-plugin-metro-6.2.0.tgz", - "integrity": "sha512-JfmzuFNzOr+dFTUQJo1rV0t87XAqgHRTMYXNleQVt8otOVCk1FSCgKlgqMdvQc/FCx2ZjoMWEEV/g0LrPI8Etw==", "dev": true, "requires": { "@react-native-community/cli-server-api": "^6.2.0", @@ -1101,8 +9181,6 @@ }, "@react-native-community/cli-server-api": { "version": "6.2.0", - "resolved": "https://registry.npmjs.org/@react-native-community/cli-server-api/-/cli-server-api-6.2.0.tgz", - "integrity": "sha512-OnbnYclhoDpjge33QO5Slhfn0DsmLzzAgyrSCnb24HhSqwq7ObjMHaLpoEhpajzLG71wq5oKh0APEQjiL4Mknw==", "dev": true, "requires": { "@react-native-community/cli-debugger-ui": "^6.0.0-rc.0", @@ -1118,8 +9196,6 @@ "dependencies": { "ws": { "version": "1.1.5", - "resolved": "https://registry.npmjs.org/ws/-/ws-1.1.5.tgz", - "integrity": "sha512-o3KqipXNUdS7wpQzBHSe180lBGO60SoK0yVo3CYJgb2MkobuWuBX6dhkYP5ORCLd55y+SaflMOV5fqAB53ux4w==", "dev": true, "requires": { "options": ">=0.0.5", @@ -1130,8 +9206,6 @@ }, "@react-native-community/cli-tools": { "version": "6.2.0", - "resolved": "https://registry.npmjs.org/@react-native-community/cli-tools/-/cli-tools-6.2.0.tgz", - "integrity": "sha512-08ssz4GMEnRxC/1FgTTN/Ud7mExQi5xMphItPjfHiTxpZPhrFn+IMx6mya0ncFEhhxQ207wYlJMRLPRRdBZ8oA==", "dev": true, "requires": { "appdirsjs": "^1.2.4", @@ -1146,16 +9220,12 @@ "dependencies": { "mime": { "version": "2.6.0", - "resolved": "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz", - "integrity": "sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg==", "dev": true } } }, "@react-native-community/cli-types": { "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@react-native-community/cli-types/-/cli-types-6.0.0.tgz", - "integrity": "sha512-K493Fk2DMJC0ZM8s8gnfseKxGasIhuDaCUDeLZcoCSFlrjKEuEs1BKKEJiev0CARhKEXKOyyp/uqYM9nWhisNw==", "dev": true, "requires": { "ora": "^3.4.0" @@ -1163,26 +9233,18 @@ }, "@react-native/assets": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/@react-native/assets/-/assets-1.0.0.tgz", - "integrity": "sha512-KrwSpS1tKI70wuKl68DwJZYEvXktDHdZMG0k2AXD/rJVSlB23/X2CB2cutVR0HwNMJIal9HOUOBB2rVfa6UGtQ==", "dev": true }, "@react-native/normalize-color": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/@react-native/normalize-color/-/normalize-color-1.0.0.tgz", - "integrity": "sha512-xUNRvNmCl3UGCPbbHvfyFMnpvLPoOjDCcp5bT9m2k+TF/ZBklEQwhPZlkrxRx2NhgFh1X3a5uL7mJ7ZR+8G7Qg==", "dev": true }, "@react-native/polyfills": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@react-native/polyfills/-/polyfills-2.0.0.tgz", - "integrity": "sha512-K0aGNn1TjalKj+65D7ycc1//H9roAQ51GJVk5ZJQFb2teECGmzd86bYDC0aYdbRf7gtovescq4Zt6FR0tgXiHQ==", "dev": true }, "@sideway/address": { "version": "4.1.3", - "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.3.tgz", - "integrity": "sha512-8ncEUtmnTsMmL7z1YPB47kPUq7LpKWJNFPsRzHiIajGC5uXlWGn+AmkYPcHNl8S4tcEGx+cnORnNYaw2wvL+LQ==", "dev": true, "requires": { "@hapi/hoek": "^9.0.0" @@ -1190,20 +9252,14 @@ }, "@sideway/formula": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.0.tgz", - "integrity": "sha512-vHe7wZ4NOXVfkoRb8T5otiENVlT7a3IAiw7H5M2+GO+9CDgcVUUsX1zalAztCmwyOr2RUTGJdgB+ZvSVqmdHmg==", "dev": true }, "@sideway/pinpoint": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz", - "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==", "dev": true }, "@types/graceful-fs": { "version": "4.1.5", - "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.5.tgz", - "integrity": "sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw==", "dev": true, "requires": { "@types/node": "*" @@ -1211,14 +9267,10 @@ }, "@types/istanbul-lib-coverage": { "version": "2.0.4", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", - "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", "dev": true }, "@types/istanbul-lib-report": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", - "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", "dev": true, "requires": { "@types/istanbul-lib-coverage": "*" @@ -1226,8 +9278,6 @@ }, "@types/istanbul-reports": { "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", - "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", "dev": true, "requires": { "@types/istanbul-lib-report": "*" @@ -1235,14 +9285,42 @@ }, "@types/node": { "version": "17.0.8", - "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.8.tgz", - "integrity": "sha512-YofkM6fGv4gDJq78g4j0mMuGMkZVxZDgtU0JRdx6FgiJDG+0fY0GKVolOV8WqVmEhLCXkQRjwDdKyPxJp/uucg==", + "dev": true + }, + "@types/prop-types": { + "version": "15.7.5", + "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.5.tgz", + "integrity": "sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==", + "dev": true + }, + "@types/react": { + "version": "18.0.14", + "resolved": "https://registry.npmjs.org/@types/react/-/react-18.0.14.tgz", + "integrity": "sha512-x4gGuASSiWmo0xjDLpm5mPb52syZHJx02VKbqUKdLmKtAwIh63XClGsiTI1K6DO5q7ox4xAsQrU+Gl3+gGXF9Q==", + "dev": true, + "requires": { + "@types/prop-types": "*", + "@types/scheduler": "*", + "csstype": "^3.0.2" + } + }, + "@types/react-native": { + "version": "0.69.2", + "resolved": "https://registry.npmjs.org/@types/react-native/-/react-native-0.69.2.tgz", + "integrity": "sha512-AVdWv4B8/++T5QQdnpveb2OVqD+0i8SOoT63ZRD+lNtQIYxzDak91V0k6olthy+H261d4t/MRBC1cfX1Rwsb6A==", + "dev": true, + "requires": { + "@types/react": "*" + } + }, + "@types/scheduler": { + "version": "0.16.2", + "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", + "integrity": "sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew==", "dev": true }, "@types/yargs": { "version": "16.0.4", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", - "integrity": "sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw==", "dev": true, "requires": { "@types/yargs-parser": "*" @@ -1250,14 +9328,10 @@ }, "@types/yargs-parser": { "version": "20.2.1", - "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-20.2.1.tgz", - "integrity": "sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw==", "dev": true }, "abort-controller": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", - "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", "dev": true, "requires": { "event-target-shim": "^5.0.0" @@ -1265,14 +9339,10 @@ }, "absolute-path": { "version": "0.0.0", - "resolved": "https://registry.npmjs.org/absolute-path/-/absolute-path-0.0.0.tgz", - "integrity": "sha1-p4di+9rftSl76ZsV01p4Wy8JW/c=", "dev": true }, "accepts": { "version": "1.3.7", - "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", - "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", "dev": true, "requires": { "mime-types": "~2.1.24", @@ -1281,14 +9351,10 @@ }, "anser": { "version": "1.4.10", - "resolved": "https://registry.npmjs.org/anser/-/anser-1.4.10.tgz", - "integrity": "sha512-hCv9AqTQ8ycjpSd3upOJd7vFwW1JaoYQ7tpham03GJ1ca8/65rqn0RpaWpItOAd6ylW9wAw6luXYPJIyPFVOww==", "dev": true }, "ansi-fragments": { "version": "0.2.1", - "resolved": "https://registry.npmjs.org/ansi-fragments/-/ansi-fragments-0.2.1.tgz", - "integrity": "sha512-DykbNHxuXQwUDRv5ibc2b0x7uw7wmwOGLBUd5RmaQ5z8Lhx19vwvKV+FAsM5rEA6dEcHxX+/Ad5s9eF2k2bB+w==", "dev": true, "requires": { "colorette": "^1.0.7", @@ -1298,14 +9364,10 @@ }, "ansi-regex": { "version": "4.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", - "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", "dev": true }, "ansi-styles": { "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", "dev": true, "requires": { "color-convert": "^2.0.1" @@ -1313,8 +9375,6 @@ }, "anymatch": { "version": "3.1.0", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.0.tgz", - "integrity": "sha512-Ozz7l4ixzI7Oxj2+cw+p0tVUt27BpaJ+1+q1TCeANWxHpvyn2+Un+YamBdfKu0uh8xLodGhoa1v7595NhKDAuA==", "dev": true, "requires": { "normalize-path": "^3.0.0", @@ -1323,14 +9383,10 @@ }, "appdirsjs": { "version": "1.2.6", - "resolved": "https://registry.npmjs.org/appdirsjs/-/appdirsjs-1.2.6.tgz", - "integrity": "sha512-D8wJNkqMCeQs3kLasatELsddox/Xqkhp+J07iXGyL54fVN7oc+nmNfYzGuCs1IEP6uBw+TfpuO3JKwc+lECy4w==", "dev": true }, "argparse": { "version": "1.0.10", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", - "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", "dev": true, "requires": { "sprintf-js": "~1.0.2" @@ -1338,85 +9394,53 @@ }, "arr-diff": { "version": "4.0.0", - "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", - "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", "dev": true }, "arr-flatten": { "version": "1.1.0", - "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", - "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", "dev": true }, "arr-union": { "version": "3.1.0", - "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", - "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", "dev": true }, "array-filter": { "version": "0.0.1", - "resolved": "https://registry.npmjs.org/array-filter/-/array-filter-0.0.1.tgz", - "integrity": "sha1-fajPLiZijtcygDWB/SH2fKzS7uw=", "dev": true }, "array-map": { "version": "0.0.0", - "resolved": "https://registry.npmjs.org/array-map/-/array-map-0.0.0.tgz", - "integrity": "sha1-iKK6tz0c97zVwbEYoAP2b2ZfpmI=", "dev": true }, "array-reduce": { "version": "0.0.0", - "resolved": "https://registry.npmjs.org/array-reduce/-/array-reduce-0.0.0.tgz", - "integrity": "sha1-FziZ0//Rx9k4PkR5Ul2+J4yrXys=", "dev": true }, "array-unique": { "version": "0.3.2", - "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", - "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", "dev": true }, "asap": { "version": "2.0.6", - "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", - "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY=", "dev": true }, "assign-symbols": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", - "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", "dev": true }, "ast-types": { "version": "0.14.2", - "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.14.2.tgz", - "integrity": "sha512-O0yuUDnZeQDL+ncNGlJ78BiO4jnYI3bvMsD5prT0/nsgijG/LpNBIr63gTjVTNsiGkgQhiyCShTgxt8oXOrklA==", "dev": true, "requires": { "tslib": "^2.0.1" - }, - "dependencies": { - "tslib": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", - "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", - "dev": true - } } }, "astral-regex": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", - "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", "dev": true }, "async": { "version": "2.6.3", - "resolved": "https://registry.npmjs.org/async/-/async-2.6.3.tgz", - "integrity": "sha512-zflvls11DCy+dQWzTW2dzuilv8Z5X/pjfmZOWba6TNIVDm+2UDaJmXSOXlasHKfNBs8oo3M0aT50fDEWfKZjXg==", "dev": true, "requires": { "lodash": "^4.17.14" @@ -1424,71 +9448,60 @@ }, "async-limiter": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", - "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==", "dev": true }, "atob": { "version": "2.1.2", - "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", - "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", "dev": true }, "babel-core": { "version": "7.0.0-bridge.0", - "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-7.0.0-bridge.0.tgz", - "integrity": "sha512-poPX9mZH/5CSanm50Q+1toVci6pv5KSRv/5TWCwtzQS5XEwn40BcCrgIeMFWP9CKKIniKXNxoIOnOq4VVlGXhg==", - "dev": true + "dev": true, + "requires": {} }, "babel-plugin-dynamic-import-node": { "version": "2.3.3", - "resolved": "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz", - "integrity": "sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ==", "dev": true, "requires": { "object.assign": "^4.1.0" } }, "babel-plugin-polyfill-corejs2": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.0.tgz", - "integrity": "sha512-wMDoBJ6uG4u4PNFh72Ty6t3EgfA91puCuAwKIazbQlci+ENb/UU9A3xG5lutjUIiXCIn1CY5L15r9LimiJyrSA==", + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.1.tgz", + "integrity": "sha512-v7/T6EQcNfVLfcN2X8Lulb7DjprieyLWJK/zOWH5DUYcAgex9sP3h25Q+DLsX9TloXe3y1O8l2q2Jv9q8UVB9w==", "dev": true, "requires": { "@babel/compat-data": "^7.13.11", - "@babel/helper-define-polyfill-provider": "^0.3.0", + "@babel/helper-define-polyfill-provider": "^0.3.1", "semver": "^6.1.1" } }, "babel-plugin-polyfill-corejs3": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.5.0.tgz", - "integrity": "sha512-Hcrgnmkf+4JTj73GbK3bBhlVPiLL47owUAnoJIf69Hakl3q+KfodbDXiZWGMM7iqCZTxCG3Z2VRfPNYES4rXqQ==", + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.5.2.tgz", + "integrity": "sha512-G3uJih0XWiID451fpeFaYGVuxHEjzKTHtc9uGFEjR6hHrvNzeS/PX+LLLcetJcytsB5m4j+K3o/EpXJNb/5IEQ==", "dev": true, "requires": { - "@babel/helper-define-polyfill-provider": "^0.3.0", - "core-js-compat": "^3.20.0" + "@babel/helper-define-polyfill-provider": "^0.3.1", + "core-js-compat": "^3.21.0" } }, "babel-plugin-polyfill-regenerator": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.3.0.tgz", - "integrity": "sha512-dhAPTDLGoMW5/84wkgwiLRwMnio2i1fUe53EuvtKMv0pn2p3S8OCoV1xAzfJPl0KOX7IB89s2ib85vbYiea3jg==", + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.3.1.tgz", + "integrity": "sha512-Y2B06tvgHYt1x0yz17jGkGeeMr5FeKUu+ASJ+N6nB5lQ8Dapfg42i0OVrf8PNGJ3zKL4A23snMi1IRwrqqND7A==", "dev": true, "requires": { - "@babel/helper-define-polyfill-provider": "^0.3.0" + "@babel/helper-define-polyfill-provider": "^0.3.1" } }, "babel-plugin-syntax-trailing-function-commas": { "version": "7.0.0-beta.0", - "resolved": "https://registry.npmjs.org/babel-plugin-syntax-trailing-function-commas/-/babel-plugin-syntax-trailing-function-commas-7.0.0-beta.0.tgz", - "integrity": "sha512-Xj9XuRuz3nTSbaTXWv3itLOcxyF4oPD8douBBmj7U9BBC6nEBYfyOJYQMf/8PJAFotC62UY5dFfIGEPr7WswzQ==", "dev": true }, "babel-preset-fbjs": { "version": "3.4.0", - "resolved": "https://registry.npmjs.org/babel-preset-fbjs/-/babel-preset-fbjs-3.4.0.tgz", - "integrity": "sha512-9ywCsCvo1ojrw0b+XYk7aFvTH6D9064t0RIL1rtMf3nsa02Xw41MS7sZw216Im35xj/UY0PDBQsa1brUDDF1Ow==", "dev": true, "requires": { "@babel/plugin-proposal-class-properties": "^7.0.0", @@ -1522,14 +9535,10 @@ }, "balanced-match": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", "dev": true }, "base": { "version": "0.11.2", - "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", - "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", "dev": true, "requires": { "cache-base": "^1.0.1", @@ -1543,8 +9552,6 @@ "dependencies": { "define-property": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", - "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", "dev": true, "requires": { "is-descriptor": "^1.0.0" @@ -1552,8 +9559,6 @@ }, "is-accessor-descriptor": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", - "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", "dev": true, "requires": { "kind-of": "^6.0.0" @@ -1561,8 +9566,6 @@ }, "is-data-descriptor": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", - "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", "dev": true, "requires": { "kind-of": "^6.0.0" @@ -1570,8 +9573,6 @@ }, "is-descriptor": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", - "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", "dev": true, "requires": { "is-accessor-descriptor": "^1.0.0", @@ -1583,26 +9584,18 @@ }, "base64-js": { "version": "1.5.1", - "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", - "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", "dev": true }, "big-integer": { "version": "1.6.51", - "resolved": "https://registry.npmjs.org/big-integer/-/big-integer-1.6.51.tgz", - "integrity": "sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg==", "dev": true }, "binary-extensions": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.0.0.tgz", - "integrity": "sha512-Phlt0plgpIIBOGTT/ehfFnbNlfsDEiqmzE2KRXoX1bLIlir4X/MR+zSyBEkL05ffWgnRSf/DXv+WrUAVr93/ow==", "dev": true }, "bplist-creator": { "version": "0.1.0", - "resolved": "https://registry.npmjs.org/bplist-creator/-/bplist-creator-0.1.0.tgz", - "integrity": "sha512-sXaHZicyEEmY86WyueLTQesbeoH/mquvarJaQNbjuOQO+7gbFcDEWqKmcWA4cOTLzFlfgvkiVxolk1k5bBIpmg==", "dev": true, "requires": { "stream-buffers": "2.2.x" @@ -1610,8 +9603,6 @@ }, "bplist-parser": { "version": "0.3.0", - "resolved": "https://registry.npmjs.org/bplist-parser/-/bplist-parser-0.3.0.tgz", - "integrity": "sha512-zgmaRvT6AN1JpPPV+S0a1/FAtoxSreYDccZGIqEMSvZl9DMe70mJ7MFzpxa1X+gHVdkToE2haRUHHMiW1OdejA==", "dev": true, "requires": { "big-integer": "1.6.x" @@ -1619,8 +9610,6 @@ }, "brace-expansion": { "version": "1.1.11", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", "dev": true, "requires": { "balanced-match": "^1.0.0", @@ -1629,30 +9618,25 @@ }, "braces": { "version": "3.0.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", - "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", "dev": true, "requires": { "fill-range": "^7.0.1" } }, "browserslist": { - "version": "4.19.1", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.19.1.tgz", - "integrity": "sha512-u2tbbG5PdKRTUoctO3NBD8FQ5HdPh1ZXPHzp1rwaa5jTc+RV9/+RlWiAIKmjRPQF+xbGM9Kklj5bZQFa2s/38A==", + "version": "4.21.1", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.1.tgz", + "integrity": "sha512-Nq8MFCSrnJXSc88yliwlzQe3qNe3VntIjhsArW9IJOEPSHNx23FalwApUVbzAWABLhYJJ7y8AynWI/XM8OdfjQ==", "dev": true, "requires": { - "caniuse-lite": "^1.0.30001286", - "electron-to-chromium": "^1.4.17", - "escalade": "^3.1.1", - "node-releases": "^2.0.1", - "picocolors": "^1.0.0" + "caniuse-lite": "^1.0.30001359", + "electron-to-chromium": "^1.4.172", + "node-releases": "^2.0.5", + "update-browserslist-db": "^1.0.4" } }, "bser": { "version": "2.1.1", - "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", - "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", "dev": true, "requires": { "node-int64": "^0.4.0" @@ -1660,20 +9644,14 @@ }, "buffer-from": { "version": "1.1.2", - "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", "dev": true }, "bytes": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", - "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=", "dev": true }, "cache-base": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", - "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", "dev": true, "requires": { "collection-visit": "^1.0.0", @@ -1689,8 +9667,6 @@ }, "call-bind": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", - "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", "dev": true, "requires": { "function-bind": "^1.1.1", @@ -1699,8 +9675,6 @@ }, "caller-callsite": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/caller-callsite/-/caller-callsite-2.0.0.tgz", - "integrity": "sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ=", "dev": true, "requires": { "callsites": "^2.0.0" @@ -1708,8 +9682,6 @@ }, "caller-path": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-2.0.0.tgz", - "integrity": "sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ=", "dev": true, "requires": { "caller-callsite": "^2.0.0" @@ -1717,26 +9689,20 @@ }, "callsites": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", - "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=", "dev": true }, "camelcase": { "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", "dev": true }, "caniuse-lite": { - "version": "1.0.30001299", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001299.tgz", - "integrity": "sha512-iujN4+x7QzqA2NCSrS5VUy+4gLmRd4xv6vbBBsmfVqTx8bLAD8097euLqQgKxSVLvxjSDcvF1T/i9ocgnUFexw==", + "version": "1.0.30001363", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001363.tgz", + "integrity": "sha512-HpQhpzTGGPVMnCjIomjt+jvyUu8vNFo3TaDiZ/RcoTrlOq/5+tC8zHdsbgFB6MxmaY+jCpsH09aD80Bb4Ow3Sg==", "dev": true }, "capture-exit": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/capture-exit/-/capture-exit-2.0.0.tgz", - "integrity": "sha512-PiT/hQmTonHhl/HFGN+Lx3JJUznrVYJ3+AQsnthneZbvW7x+f08Tk7yLJTLEOUvBTbduLeeBkxEaYXUOUrRq6g==", "dev": true, "requires": { "rsvp": "^4.8.4" @@ -1744,8 +9710,6 @@ }, "chalk": { "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", "dev": true, "requires": { "ansi-styles": "^4.1.0", @@ -1754,8 +9718,6 @@ }, "chokidar": { "version": "3.1.1", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.1.1.tgz", - "integrity": "sha512-df4o16uZmMHzVQwECZRHwfguOt5ixpuQVaZHjYMvYisgKhE+JXwcj/Tcr3+3bu/XeOJQ9ycYmzu7Mv8XrGxJDQ==", "dev": true, "requires": { "anymatch": "^3.1.0", @@ -1770,14 +9732,10 @@ }, "ci-info": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", - "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", "dev": true }, "class-utils": { "version": "0.3.6", - "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", - "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", "dev": true, "requires": { "arr-union": "^3.1.0", @@ -1788,8 +9746,6 @@ "dependencies": { "define-property": { "version": "0.2.5", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", "dev": true, "requires": { "is-descriptor": "^0.1.0" @@ -1799,8 +9755,6 @@ }, "cli-cursor": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", - "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", "dev": true, "requires": { "restore-cursor": "^2.0.0" @@ -1808,14 +9762,10 @@ }, "cli-spinners": { "version": "2.6.1", - "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.6.1.tgz", - "integrity": "sha512-x/5fWmGMnbKQAaNwN+UZlV79qBLM9JFnJuJ03gIi5whrob0xV0ofNVHy9DhwGdsMJQc2OKv0oGmLzvaqvAVv+g==", "dev": true }, "cliui": { "version": "6.0.0", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", - "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", "dev": true, "requires": { "string-width": "^4.2.0", @@ -1825,14 +9775,10 @@ "dependencies": { "ansi-regex": { "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", "dev": true }, "strip-ansi": { "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", "dev": true, "requires": { "ansi-regex": "^5.0.1" @@ -1842,14 +9788,10 @@ }, "clone": { "version": "1.0.4", - "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", - "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", "dev": true }, "clone-deep": { "version": "4.0.1", - "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", - "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", "dev": true, "requires": { "is-plain-object": "^2.0.4", @@ -1859,8 +9801,6 @@ }, "collection-visit": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", - "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", "dev": true, "requires": { "map-visit": "^1.0.0", @@ -1869,8 +9809,6 @@ }, "color-convert": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", "dev": true, "requires": { "color-name": "~1.1.4" @@ -1878,50 +9816,34 @@ }, "color-name": { "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", "dev": true }, "colorette": { "version": "1.4.0", - "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.4.0.tgz", - "integrity": "sha512-Y2oEozpomLn7Q3HFP7dpww7AtMJplbM9lGZP6RDfHqmbeRjiwRg4n6VM6j4KLmRke85uWEI7JqF17f3pqdRA0g==", "dev": true }, "colors": { "version": "1.4.0", - "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz", - "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==", "dev": true }, "command-exists": { "version": "1.2.9", - "resolved": "https://registry.npmjs.org/command-exists/-/command-exists-1.2.9.tgz", - "integrity": "sha512-LTQ/SGc+s0Xc0Fu5WaKnR0YiygZkm9eKFvyS+fRsU7/ZWFF8ykFM6Pc9aCVf1+xasOOZpO3BAVgVrKvsqKHV7w==", "dev": true }, "commander": { "version": "2.20.3", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", - "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", "dev": true }, "commondir": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", - "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", "dev": true }, "component-emitter": { "version": "1.3.0", - "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", - "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==", "dev": true }, "compressible": { "version": "2.0.18", - "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", - "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", "dev": true, "requires": { "mime-db": ">= 1.43.0 < 2" @@ -1929,8 +9851,6 @@ }, "compression": { "version": "1.7.4", - "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz", - "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==", "dev": true, "requires": { "accepts": "~1.3.5", @@ -1944,14 +9864,10 @@ }, "concat-map": { "version": "0.0.1", - "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", "dev": true }, "connect": { "version": "3.7.0", - "resolved": "https://registry.npmjs.org/connect/-/connect-3.7.0.tgz", - "integrity": "sha512-ZqRXc+tZukToSNmh5C2iWMSoV3X1YUcPbqEM4DkEG5tNQXrQUZCNVGGv3IuicnkMtPfGf3Xtp8WCXs295iQ1pQ==", "dev": true, "requires": { "debug": "2.6.9", @@ -1962,8 +9878,6 @@ }, "convert-source-map": { "version": "1.8.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz", - "integrity": "sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==", "dev": true, "requires": { "safe-buffer": "~5.1.1" @@ -1971,17 +9885,15 @@ }, "copy-descriptor": { "version": "0.1.1", - "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", - "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", "dev": true }, "core-js-compat": { - "version": "3.20.2", - "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.20.2.tgz", - "integrity": "sha512-qZEzVQ+5Qh6cROaTPFLNS4lkvQ6mBzE3R6A6EEpssj7Zr2egMHgsy4XapdifqJDGC9CBiNv7s+ejI96rLNQFdg==", + "version": "3.23.3", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.23.3.tgz", + "integrity": "sha512-WSzUs2h2vvmKsacLHNTdpyOC9k43AEhcGoFlVgCY4L7aw98oSBKtPL6vD0/TqZjRWRQYdDSLkzZIni4Crbbiqw==", "dev": true, "requires": { - "browserslist": "^4.19.1", + "browserslist": "^4.21.0", "semver": "7.0.0" }, "dependencies": { @@ -1995,14 +9907,10 @@ }, "core-util-is": { "version": "1.0.3", - "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", - "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", "dev": true }, "cosmiconfig": { "version": "5.2.1", - "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-5.2.1.tgz", - "integrity": "sha512-H65gsXo1SKjf8zmrJ67eJk8aIRKV5ff2D4uKZIBZShbhGSpEmsQOPW/SKMKYhSTrqR7ufy6RP69rPogdaPh/kA==", "dev": true, "requires": { "import-fresh": "^2.0.0", @@ -2013,8 +9921,6 @@ }, "cross-spawn": { "version": "6.0.5", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", - "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", "dev": true, "requires": { "nice-try": "^1.0.4", @@ -2026,22 +9932,22 @@ "dependencies": { "semver": { "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", "dev": true } } }, + "csstype": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.0.tgz", + "integrity": "sha512-uX1KG+x9h5hIJsaKR9xHUeUraxf8IODOwq9JLNPq6BwB04a/xgpq3rcx47l5BZu5zBPlgD342tdke3Hom/nJRA==", + "dev": true + }, "dayjs": { "version": "1.10.7", - "resolved": "https://registry.npmjs.org/dayjs/-/dayjs-1.10.7.tgz", - "integrity": "sha512-P6twpd70BcPK34K26uJ1KT3wlhpuOAPoMwJzpsIWUxHZ7wpmbdZL/hQqBDfz7hGurYSa5PhzdhDHtt319hL3ig==", "dev": true }, "debug": { "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", "dev": true, "requires": { "ms": "2.0.0" @@ -2049,34 +9955,24 @@ "dependencies": { "ms": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", "dev": true } } }, "decamelize": { "version": "1.2.0", - "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", - "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", "dev": true }, "decode-uri-component": { "version": "0.2.0", - "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", - "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", "dev": true }, "deepmerge": { "version": "3.3.0", - "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-3.3.0.tgz", - "integrity": "sha512-GRQOafGHwMHpjPx9iCvTgpu9NojZ49q794EEL94JVEw6VaeA8XTUyBKvAkOOjBX9oJNiV6G3P+T+tihFjo2TqA==", "dev": true }, "defaults": { "version": "1.0.3", - "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.3.tgz", - "integrity": "sha1-xlYFHpgX2f8I7YgUd/P+QBnz730=", "dev": true, "requires": { "clone": "^1.0.2" @@ -2084,8 +9980,6 @@ }, "define-properties": { "version": "1.1.3", - "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", - "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", "dev": true, "requires": { "object-keys": "^1.0.12" @@ -2093,8 +9987,6 @@ }, "define-property": { "version": "2.0.2", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", - "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", "dev": true, "requires": { "is-descriptor": "^1.0.2", @@ -2103,8 +9995,6 @@ "dependencies": { "is-accessor-descriptor": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", - "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", "dev": true, "requires": { "kind-of": "^6.0.0" @@ -2112,8 +10002,6 @@ }, "is-data-descriptor": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", - "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", "dev": true, "requires": { "kind-of": "^6.0.0" @@ -2121,8 +10009,6 @@ }, "is-descriptor": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", - "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", "dev": true, "requires": { "is-accessor-descriptor": "^1.0.0", @@ -2134,50 +10020,36 @@ }, "denodeify": { "version": "1.2.1", - "resolved": "https://registry.npmjs.org/denodeify/-/denodeify-1.2.1.tgz", - "integrity": "sha1-OjYof1A05pnnV3kBBSwubJQlFjE=", "dev": true }, "depd": { "version": "1.1.2", - "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", - "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", "dev": true }, "destroy": { "version": "1.0.4", - "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", - "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=", "dev": true }, "ee-first": { "version": "1.1.1", - "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", - "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=", "dev": true }, "electron-to-chromium": { - "version": "1.4.43", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.43.tgz", - "integrity": "sha512-PO3kEfcxPrti/4STbXvCkNIF4fgWvCKl2508e6UI7KomCDffpIfeBZLXsh5DK/XGsjUw3kwq6WEsi0MJTlGAdg==", + "version": "1.4.179", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.179.tgz", + "integrity": "sha512-1XeTb/U/8Xgh2YgPOqhakLYsvCcU4U7jUjTMbEnhIJoIWd/Qt3yC8y0cbG+fHzn4zUNF99Ey1xiPf20bwgLO3Q==", "dev": true }, "emoji-regex": { "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", "dev": true }, "encodeurl": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", - "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", "dev": true }, "end-of-stream": { "version": "1.4.4", - "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", - "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", "dev": true, "requires": { "once": "^1.4.0" @@ -2185,14 +10057,10 @@ }, "envinfo": { "version": "7.8.1", - "resolved": "https://registry.npmjs.org/envinfo/-/envinfo-7.8.1.tgz", - "integrity": "sha512-/o+BXHmB7ocbHEAs6F2EnG0ogybVVUdkRunTT2glZU9XAaGmhqskrvKwqXuDfNjEO0LZKWdejEEpnq8aM0tOaw==", "dev": true }, "error-ex": { "version": "1.3.2", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", - "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", "dev": true, "requires": { "is-arrayish": "^0.2.1" @@ -2200,8 +10068,6 @@ }, "error-stack-parser": { "version": "2.0.6", - "resolved": "https://registry.npmjs.org/error-stack-parser/-/error-stack-parser-2.0.6.tgz", - "integrity": "sha512-d51brTeqC+BHlwF0BhPtcYgF5nlzf9ZZ0ZIUQNZpc9ZB9qw5IJ2diTrBY9jlCJkTLITYPjmiX6OWCwH+fuyNgQ==", "dev": true, "requires": { "stackframe": "^1.1.1" @@ -2209,8 +10075,6 @@ }, "errorhandler": { "version": "1.5.1", - "resolved": "https://registry.npmjs.org/errorhandler/-/errorhandler-1.5.1.tgz", - "integrity": "sha512-rcOwbfvP1WTViVoUjcfZicVzjhjTuhSMntHh6mW3IrEiyE6mJyXvsToJUJGlGlw/2xU9P5whlWNGlIDVeCiT4A==", "dev": true, "requires": { "accepts": "~1.3.7", @@ -2225,44 +10089,37 @@ }, "escape-html": { "version": "1.0.3", - "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", - "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=", "dev": true }, "escape-string-regexp": { "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", "dev": true }, "esprima": { "version": "4.0.1", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", "dev": true }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "peer": true + }, "etag": { "version": "1.8.1", - "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", - "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", "dev": true }, "event-target-shim": { "version": "5.0.1", - "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", - "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==", "dev": true }, "exec-sh": { "version": "0.3.6", - "resolved": "https://registry.npmjs.org/exec-sh/-/exec-sh-0.3.6.tgz", - "integrity": "sha512-nQn+hI3yp+oD0huYhKwvYI32+JFeq+XkNcD1GAo3Y/MjxsfVGmrrzrnzjWiNY6f+pUCP440fThsFh5gZrRAU/w==", "dev": true }, "execa": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", - "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", "dev": true, "requires": { "cross-spawn": "^6.0.0", @@ -2276,8 +10133,6 @@ }, "expand-brackets": { "version": "2.1.4", - "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", - "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", "dev": true, "requires": { "debug": "^2.3.3", @@ -2291,8 +10146,6 @@ "dependencies": { "define-property": { "version": "0.2.5", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", "dev": true, "requires": { "is-descriptor": "^0.1.0" @@ -2300,8 +10153,6 @@ }, "extend-shallow": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", "dev": true, "requires": { "is-extendable": "^0.1.0" @@ -2311,8 +10162,6 @@ }, "extend-shallow": { "version": "3.0.2", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", - "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", "dev": true, "requires": { "assign-symbols": "^1.0.0", @@ -2321,8 +10170,6 @@ "dependencies": { "is-extendable": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", - "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", "dev": true, "requires": { "is-plain-object": "^2.0.4" @@ -2332,8 +10179,6 @@ }, "extglob": { "version": "2.0.4", - "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", - "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", "dev": true, "requires": { "array-unique": "^0.3.2", @@ -2348,8 +10193,6 @@ "dependencies": { "define-property": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", - "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", "dev": true, "requires": { "is-descriptor": "^1.0.0" @@ -2357,8 +10200,6 @@ }, "extend-shallow": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", "dev": true, "requires": { "is-extendable": "^0.1.0" @@ -2366,8 +10207,6 @@ }, "is-accessor-descriptor": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", - "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", "dev": true, "requires": { "kind-of": "^6.0.0" @@ -2375,8 +10214,6 @@ }, "is-data-descriptor": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", - "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", "dev": true, "requires": { "kind-of": "^6.0.0" @@ -2384,8 +10221,6 @@ }, "is-descriptor": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", - "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", "dev": true, "requires": { "is-accessor-descriptor": "^1.0.0", @@ -2397,8 +10232,6 @@ }, "fb-watchman": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz", - "integrity": "sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg==", "dev": true, "requires": { "bser": "2.1.1" @@ -2406,8 +10239,6 @@ }, "fill-range": { "version": "7.0.1", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", - "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", "dev": true, "requires": { "to-regex-range": "^5.0.1" @@ -2415,8 +10246,6 @@ }, "finalhandler": { "version": "1.1.2", - "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", - "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", "dev": true, "requires": { "debug": "2.6.9", @@ -2430,8 +10259,6 @@ }, "find-cache-dir": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", - "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", "dev": true, "requires": { "commondir": "^1.0.1", @@ -2441,8 +10268,6 @@ }, "find-up": { "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", "dev": true, "requires": { "locate-path": "^5.0.0", @@ -2451,20 +10276,14 @@ }, "flow-parser": { "version": "0.121.0", - "resolved": "https://registry.npmjs.org/flow-parser/-/flow-parser-0.121.0.tgz", - "integrity": "sha512-1gIBiWJNR0tKUNv8gZuk7l9rVX06OuLzY9AoGio7y/JT4V1IZErEMEq2TJS+PFcw/y0RshZ1J/27VfK1UQzYVg==", "dev": true }, "for-in": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", - "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", "dev": true }, "fragment-cache": { "version": "0.2.1", - "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", - "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", "dev": true, "requires": { "map-cache": "^0.2.2" @@ -2472,14 +10291,10 @@ }, "fresh": { "version": "0.5.2", - "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", - "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", "dev": true }, "fs-extra": { "version": "8.1.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", - "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", "dev": true, "requires": { "graceful-fs": "^4.2.0", @@ -2489,39 +10304,27 @@ }, "fs.realpath": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", "dev": true }, "fsevents": { "version": "2.0.7", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.0.7.tgz", - "integrity": "sha512-a7YT0SV3RB+DjYcppwVDLtn13UQnmg0SWZS7ezZD0UjnLwXmy8Zm21GMVGLaFGimIqcvyMQaOJBrop8MyOp1kQ==", "dev": true, "optional": true }, "function-bind": { "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", "dev": true }, "gensync": { "version": "1.0.0-beta.2", - "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", - "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", "dev": true }, "get-caller-file": { "version": "2.0.5", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", - "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", "dev": true }, "get-intrinsic": { "version": "1.1.1", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", - "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", "dev": true, "requires": { "function-bind": "^1.1.1", @@ -2531,8 +10334,6 @@ }, "get-stream": { "version": "4.1.0", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", - "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", "dev": true, "requires": { "pump": "^3.0.0" @@ -2540,14 +10341,10 @@ }, "get-value": { "version": "2.0.6", - "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", - "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", "dev": true }, "glob": { "version": "7.2.0", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", - "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", "dev": true, "requires": { "fs.realpath": "^1.0.0", @@ -2560,8 +10357,6 @@ }, "glob-parent": { "version": "5.1.0", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.0.tgz", - "integrity": "sha512-qjtRgnIVmOfnKUE3NJAQEdk+lKrxfw8t5ke7SXtfMTHcjsBfOfWXCQfdb30zfDoZQ2IRSIiidmjtbHZPZ++Ihw==", "dev": true, "requires": { "is-glob": "^4.0.1" @@ -2569,20 +10364,14 @@ }, "globals": { "version": "11.12.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", - "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", "dev": true }, "graceful-fs": { "version": "4.2.9", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", - "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", "dev": true }, "has": { "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", "dev": true, "requires": { "function-bind": "^1.1.1" @@ -2590,20 +10379,14 @@ }, "has-flag": { "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", "dev": true }, "has-symbols": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", - "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", "dev": true }, "has-value": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", - "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", "dev": true, "requires": { "get-value": "^2.0.6", @@ -2613,8 +10396,6 @@ }, "has-values": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", - "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", "dev": true, "requires": { "is-number": "^3.0.0", @@ -2623,8 +10404,6 @@ "dependencies": { "is-number": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", "dev": true, "requires": { "kind-of": "^3.0.2" @@ -2632,8 +10411,6 @@ "dependencies": { "kind-of": { "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", "dev": true, "requires": { "is-buffer": "^1.1.5" @@ -2643,8 +10420,6 @@ }, "kind-of": { "version": "4.0.0", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", - "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", "dev": true, "requires": { "is-buffer": "^1.1.5" @@ -2654,20 +10429,14 @@ }, "hermes-engine": { "version": "0.9.0", - "resolved": "https://registry.npmjs.org/hermes-engine/-/hermes-engine-0.9.0.tgz", - "integrity": "sha512-r7U+Y4P2Qg/igFVZN+DpT7JFfXUn1MM4dFne8aW+cCrF6RRymof+VqrUHs1kl07j8h8V2CNesU19RKgWbr3qPw==", "dev": true }, "hermes-parser": { "version": "0.4.7", - "resolved": "https://registry.npmjs.org/hermes-parser/-/hermes-parser-0.4.7.tgz", - "integrity": "sha512-jc+zCtXbtwTiXoMAoXOHepxAaGVFIp89wwE9qcdwnMd/uGVEtPoY8FaFSsx0ThPvyKirdR2EsIIDVrpbSXz1Ag==", "dev": true }, "hermes-profile-transformer": { "version": "0.0.6", - "resolved": "https://registry.npmjs.org/hermes-profile-transformer/-/hermes-profile-transformer-0.0.6.tgz", - "integrity": "sha512-cnN7bQUm65UWOy6cbGcCcZ3rpwW8Q/j4OP5aWRhEry4Z2t2aR1cjrbp0BS+KiBN0smvP1caBgAuxutvyvJILzQ==", "dev": true, "requires": { "source-map": "^0.7.3" @@ -2675,8 +10444,6 @@ }, "http-errors": { "version": "1.8.1", - "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", - "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==", "dev": true, "requires": { "depd": "~1.1.2", @@ -2688,14 +10455,10 @@ }, "image-size": { "version": "0.6.3", - "resolved": "https://registry.npmjs.org/image-size/-/image-size-0.6.3.tgz", - "integrity": "sha512-47xSUiQioGaB96nqtp5/q55m0aBQSQdyIloMOc/x+QVTDZLNmXE892IIDrJ0hM1A5vcNUDD5tDffkSP5lCaIIA==", "dev": true }, "import-fresh": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-2.0.0.tgz", - "integrity": "sha1-2BNVwVYS04bGH53dOSLUMEgipUY=", "dev": true, "requires": { "caller-path": "^2.0.0", @@ -2704,14 +10467,10 @@ }, "imurmurhash": { "version": "0.1.4", - "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", - "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", "dev": true }, "inflight": { "version": "1.0.6", - "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", - "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", "dev": true, "requires": { "once": "^1.3.0", @@ -2720,14 +10479,10 @@ }, "inherits": { "version": "2.0.4", - "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", - "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", "dev": true }, "invariant": { "version": "2.2.4", - "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", - "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", "dev": true, "requires": { "loose-envify": "^1.0.0" @@ -2735,14 +10490,10 @@ }, "ip": { "version": "1.1.5", - "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", - "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=", "dev": true }, "is-accessor-descriptor": { "version": "0.1.6", - "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", - "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", "dev": true, "requires": { "kind-of": "^3.0.2" @@ -2750,8 +10501,6 @@ "dependencies": { "kind-of": { "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", "dev": true, "requires": { "is-buffer": "^1.1.5" @@ -2761,14 +10510,10 @@ }, "is-arrayish": { "version": "0.2.1", - "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", - "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", "dev": true }, "is-binary-path": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", - "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", "dev": true, "requires": { "binary-extensions": "^2.0.0" @@ -2776,23 +10521,19 @@ }, "is-buffer": { "version": "1.1.6", - "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", - "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", "dev": true }, "is-ci": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", - "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", "dev": true, "requires": { "ci-info": "^2.0.0" } }, "is-core-module": { - "version": "2.8.1", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", - "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", + "version": "2.9.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz", + "integrity": "sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==", "dev": true, "requires": { "has": "^1.0.3" @@ -2800,8 +10541,6 @@ }, "is-data-descriptor": { "version": "0.1.4", - "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", - "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", "dev": true, "requires": { "kind-of": "^3.0.2" @@ -2809,8 +10548,6 @@ "dependencies": { "kind-of": { "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", "dev": true, "requires": { "is-buffer": "^1.1.5" @@ -2820,8 +10557,6 @@ }, "is-descriptor": { "version": "0.1.6", - "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", - "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", "dev": true, "requires": { "is-accessor-descriptor": "^0.1.6", @@ -2831,40 +10566,28 @@ "dependencies": { "kind-of": { "version": "5.1.0", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", - "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", "dev": true } } }, "is-directory": { "version": "0.3.1", - "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz", - "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=", "dev": true }, "is-extendable": { "version": "0.1.1", - "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", - "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", "dev": true }, "is-extglob": { "version": "2.1.1", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", - "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", "dev": true }, "is-fullwidth-code-point": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", - "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", "dev": true }, "is-glob": { "version": "4.0.1", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", - "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", "dev": true, "requires": { "is-extglob": "^2.1.1" @@ -2872,14 +10595,10 @@ }, "is-number": { "version": "7.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", - "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", "dev": true }, "is-plain-object": { "version": "2.0.4", - "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", - "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", "dev": true, "requires": { "isobject": "^3.0.1" @@ -2887,50 +10606,34 @@ }, "is-stream": { "version": "1.1.0", - "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", - "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", "dev": true }, "is-windows": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", - "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", "dev": true }, "is-wsl": { "version": "1.1.0", - "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-1.1.0.tgz", - "integrity": "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=", "dev": true }, "isarray": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", - "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", "dev": true }, "isexe": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", - "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", "dev": true }, "isobject": { "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", "dev": true }, "jest-get-type": { "version": "26.3.0", - "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-26.3.0.tgz", - "integrity": "sha512-TpfaviN1R2pQWkIihlfEanwOXK0zcxrKEE4MlU6Tn7keoXdN6/3gK/xl0yEh8DOunn5pOVGKf8hB4R9gVh04ig==", "dev": true }, "jest-haste-map": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-26.6.2.tgz", - "integrity": "sha512-easWIJXIw71B2RdR8kgqpjQrbMRWQBgiBwXYEhtGUTaX+doCjBheluShdDMeR8IMfJiTqH4+zfhtg29apJf/8w==", "dev": true, "requires": { "@jest/types": "^26.6.2", @@ -2951,8 +10654,6 @@ "dependencies": { "@jest/types": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.6.2.tgz", - "integrity": "sha512-fC6QCp7Sc5sX6g8Tvbmj4XUTbyrik0akgRy03yjXbQaBWWNWGE7SGtJk98m0N8nzegD/7SggrUlivxo5ax4KWQ==", "dev": true, "requires": { "@types/istanbul-lib-coverage": "^2.0.0", @@ -2964,8 +10665,6 @@ }, "@types/yargs": { "version": "15.0.14", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.14.tgz", - "integrity": "sha512-yEJzHoxf6SyQGhBhIYGXQDSCkJjB6HohDShto7m8vaKg9Yp0Yn8+71J9eakh2bnPg6BfsH9PRMhiRTZnd4eXGQ==", "dev": true, "requires": { "@types/yargs-parser": "*" @@ -2973,8 +10672,6 @@ }, "fsevents": { "version": "2.3.2", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", - "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", "dev": true, "optional": true } @@ -2982,14 +10679,10 @@ }, "jest-regex-util": { "version": "26.0.0", - "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-26.0.0.tgz", - "integrity": "sha512-Gv3ZIs/nA48/Zvjrl34bf+oD76JHiGDUxNOVgUjh3j890sblXryjY4rss71fPtD/njchl6PSE2hIhvyWa1eT0A==", "dev": true }, "jest-serializer": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-26.6.2.tgz", - "integrity": "sha512-S5wqyz0DXnNJPd/xfIzZ5Xnp1HrJWBczg8mMfMpN78OJ5eDxXyf+Ygld9wX1DnUWbIbhM1YDY95NjR4CBXkb2g==", "dev": true, "requires": { "@types/node": "*", @@ -2998,8 +10691,6 @@ }, "jest-util": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-26.6.2.tgz", - "integrity": "sha512-MDW0fKfsn0OI7MS7Euz6h8HNDXVQ0gaM9uW6RjfDmd1DAFcaxX9OqIakHIqhbnmF08Cf2DLDG+ulq8YQQ0Lp0Q==", "dev": true, "requires": { "@jest/types": "^26.6.2", @@ -3012,8 +10703,6 @@ "dependencies": { "@jest/types": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.6.2.tgz", - "integrity": "sha512-fC6QCp7Sc5sX6g8Tvbmj4XUTbyrik0akgRy03yjXbQaBWWNWGE7SGtJk98m0N8nzegD/7SggrUlivxo5ax4KWQ==", "dev": true, "requires": { "@types/istanbul-lib-coverage": "^2.0.0", @@ -3025,8 +10714,6 @@ }, "@types/yargs": { "version": "15.0.14", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.14.tgz", - "integrity": "sha512-yEJzHoxf6SyQGhBhIYGXQDSCkJjB6HohDShto7m8vaKg9Yp0Yn8+71J9eakh2bnPg6BfsH9PRMhiRTZnd4eXGQ==", "dev": true, "requires": { "@types/yargs-parser": "*" @@ -3036,8 +10723,6 @@ }, "jest-validate": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-26.6.2.tgz", - "integrity": "sha512-NEYZ9Aeyj0i5rQqbq+tpIOom0YS1u2MVu6+euBsvpgIme+FOfRmoC4R5p0JiAUpaFvFy24xgrpMknarR/93XjQ==", "dev": true, "requires": { "@jest/types": "^26.6.2", @@ -3050,8 +10735,6 @@ "dependencies": { "@jest/types": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.6.2.tgz", - "integrity": "sha512-fC6QCp7Sc5sX6g8Tvbmj4XUTbyrik0akgRy03yjXbQaBWWNWGE7SGtJk98m0N8nzegD/7SggrUlivxo5ax4KWQ==", "dev": true, "requires": { "@types/istanbul-lib-coverage": "^2.0.0", @@ -3063,8 +10746,6 @@ }, "@types/yargs": { "version": "15.0.14", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.14.tgz", - "integrity": "sha512-yEJzHoxf6SyQGhBhIYGXQDSCkJjB6HohDShto7m8vaKg9Yp0Yn8+71J9eakh2bnPg6BfsH9PRMhiRTZnd4eXGQ==", "dev": true, "requires": { "@types/yargs-parser": "*" @@ -3072,16 +10753,12 @@ }, "camelcase": { "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", "dev": true } } }, "jest-worker": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-26.6.2.tgz", - "integrity": "sha512-KWYVV1c4i+jbMpaBC+U++4Va0cp8OisU185o73T1vo99hqi7w8tSJfUXYswwqqrjzwxa6KpRK54WhPvwf5w6PQ==", "dev": true, "requires": { "@types/node": "*", @@ -3091,14 +10768,10 @@ }, "jetifier": { "version": "1.6.8", - "resolved": "https://registry.npmjs.org/jetifier/-/jetifier-1.6.8.tgz", - "integrity": "sha512-3Zi16h6L5tXDRQJTb221cnRoVG9/9OvreLdLU2/ZjRv/GILL+2Cemt0IKvkowwkDpvouAU1DQPOJ7qaiHeIdrw==", "dev": true }, "joi": { "version": "17.5.0", - "resolved": "https://registry.npmjs.org/joi/-/joi-17.5.0.tgz", - "integrity": "sha512-R7hR50COp7StzLnDi4ywOXHrBrgNXuUUfJWIR5lPY5Bm/pOD3jZaTwpluUXVLRWcoWZxkrHBBJ5hLxgnlehbdw==", "dev": true, "requires": { "@hapi/hoek": "^9.0.0", @@ -3110,14 +10783,10 @@ }, "js-tokens": { "version": "4.0.0", - "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", - "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", "dev": true }, "js-yaml": { "version": "3.14.1", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", - "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", "dev": true, "requires": { "argparse": "^1.0.7", @@ -3126,14 +10795,10 @@ }, "jsc-android": { "version": "250230.2.1", - "resolved": "https://registry.npmjs.org/jsc-android/-/jsc-android-250230.2.1.tgz", - "integrity": "sha512-KmxeBlRjwoqCnBBKGsihFtvsBHyUFlBxJPK4FzeYcIuBfdjv6jFys44JITAgSTbQD+vIdwMEfyZklsuQX0yI1Q==", "dev": true }, "jscodeshift": { "version": "0.11.0", - "resolved": "https://registry.npmjs.org/jscodeshift/-/jscodeshift-0.11.0.tgz", - "integrity": "sha512-SdRK2C7jjs4k/kT2mwtO07KJN9RnjxtKn03d9JVj6c3j9WwaLcFYsICYDnLAzY0hp+wG2nxl+Cm2jWLiNVYb8g==", "dev": true, "requires": { "@babel/core": "^7.1.6", @@ -3159,8 +10824,6 @@ "dependencies": { "braces": { "version": "2.3.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", - "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", "dev": true, "requires": { "arr-flatten": "^1.1.0", @@ -3177,8 +10840,6 @@ "dependencies": { "extend-shallow": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", "dev": true, "requires": { "is-extendable": "^0.1.0" @@ -3188,8 +10849,6 @@ }, "fill-range": { "version": "4.0.0", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", - "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", "dev": true, "requires": { "extend-shallow": "^2.0.1", @@ -3200,8 +10859,6 @@ "dependencies": { "extend-shallow": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", "dev": true, "requires": { "is-extendable": "^0.1.0" @@ -3211,8 +10868,6 @@ }, "is-number": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", "dev": true, "requires": { "kind-of": "^3.0.2" @@ -3220,8 +10875,6 @@ "dependencies": { "kind-of": { "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", "dev": true, "requires": { "is-buffer": "^1.1.5" @@ -3231,8 +10884,6 @@ }, "micromatch": { "version": "3.1.10", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", "dev": true, "requires": { "arr-diff": "^4.0.0", @@ -3252,8 +10903,6 @@ }, "to-regex-range": { "version": "2.1.1", - "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", - "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", "dev": true, "requires": { "is-number": "^3.0.0", @@ -3264,20 +10913,14 @@ }, "jsesc": { "version": "2.5.2", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", - "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", "dev": true }, "json-parse-better-errors": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", - "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", "dev": true }, "json5": { "version": "2.2.0", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.0.tgz", - "integrity": "sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA==", "dev": true, "requires": { "minimist": "^1.2.5" @@ -3285,8 +10928,6 @@ }, "jsonfile": { "version": "4.0.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", - "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", "dev": true, "requires": { "graceful-fs": "^4.1.6" @@ -3294,20 +10935,14 @@ }, "jsonify": { "version": "0.0.0", - "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", - "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", "dev": true }, "kind-of": { "version": "6.0.3", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", - "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", "dev": true }, "klaw": { "version": "1.3.1", - "resolved": "https://registry.npmjs.org/klaw/-/klaw-1.3.1.tgz", - "integrity": "sha1-QIhDO0azsbolnXh4XY6W9zugJDk=", "dev": true, "requires": { "graceful-fs": "^4.1.9" @@ -3315,20 +10950,14 @@ }, "kleur": { "version": "3.0.3", - "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", - "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", "dev": true }, "leven": { "version": "3.1.0", - "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", - "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", "dev": true }, "locate-path": { "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", "dev": true, "requires": { "p-locate": "^4.1.0" @@ -3336,26 +10965,20 @@ }, "lodash": { "version": "4.17.21", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", - "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", "dev": true }, "lodash.debounce": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", - "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=", + "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==", "dev": true }, "lodash.throttle": { "version": "4.1.1", - "resolved": "https://registry.npmjs.org/lodash.throttle/-/lodash.throttle-4.1.1.tgz", - "integrity": "sha1-wj6RtxAkKscMN/HhzaknTMOb8vQ=", "dev": true }, "log-symbols": { "version": "2.2.0", - "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-2.2.0.tgz", - "integrity": "sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg==", "dev": true, "requires": { "chalk": "^2.0.1" @@ -3363,8 +10986,6 @@ "dependencies": { "ansi-styles": { "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", "dev": true, "requires": { "color-convert": "^1.9.0" @@ -3372,8 +10993,6 @@ }, "chalk": { "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", "dev": true, "requires": { "ansi-styles": "^3.2.1", @@ -3383,8 +11002,6 @@ }, "color-convert": { "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", "dev": true, "requires": { "color-name": "1.1.3" @@ -3392,20 +11009,14 @@ }, "color-name": { "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", "dev": true }, "has-flag": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", "dev": true }, "supports-color": { "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", "dev": true, "requires": { "has-flag": "^3.0.0" @@ -3415,8 +11026,6 @@ }, "logkitty": { "version": "0.7.1", - "resolved": "https://registry.npmjs.org/logkitty/-/logkitty-0.7.1.tgz", - "integrity": "sha512-/3ER20CTTbahrCrpYfPn7Xavv9diBROZpoXGVZDWMw4b/X4uuUwAC0ki85tgsdMRONURyIJbcOvS94QsUBYPbQ==", "dev": true, "requires": { "ansi-fragments": "^0.2.1", @@ -3426,8 +11035,6 @@ }, "loose-envify": { "version": "1.4.0", - "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", - "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", "dev": true, "requires": { "js-tokens": "^3.0.0 || ^4.0.0" @@ -3435,8 +11042,6 @@ }, "make-dir": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", - "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", "dev": true, "requires": { "pify": "^4.0.1", @@ -3445,16 +11050,12 @@ "dependencies": { "semver": { "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", "dev": true } } }, "makeerror": { "version": "1.0.12", - "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", - "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", "dev": true, "requires": { "tmpl": "1.0.5" @@ -3462,14 +11063,10 @@ }, "map-cache": { "version": "0.2.2", - "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", - "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", "dev": true }, "map-visit": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", - "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", "dev": true, "requires": { "object-visit": "^1.0.0" @@ -3477,14 +11074,10 @@ }, "merge-stream": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", - "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", "dev": true }, "metro": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro/-/metro-0.66.2.tgz", - "integrity": "sha512-uNsISfcQ3iKKSHoN5Q+LAh0l3jeeg7ZcNZ/4BAHGsk02erA0OP+l2m+b5qYVoPptHz9Oc3KyG5oGJoTu41pWjg==", "dev": true, "requires": { "@babel/code-frame": "^7.0.0", @@ -3543,14 +11136,10 @@ "dependencies": { "ansi-regex": { "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", "dev": true }, "fs-extra": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-1.0.0.tgz", - "integrity": "sha1-zTzl9+fLYUWIP8rjGR6Yd/hYeVA=", "dev": true, "requires": { "graceful-fs": "^4.1.2", @@ -3560,8 +11149,6 @@ }, "jsonfile": { "version": "2.4.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-2.4.0.tgz", - "integrity": "sha1-NzaitCi4e72gzIO1P6PWM6NcKug=", "dev": true, "requires": { "graceful-fs": "^4.1.6" @@ -3569,14 +11156,10 @@ }, "source-map": { "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", "dev": true }, "strip-ansi": { "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", "dev": true, "requires": { "ansi-regex": "^5.0.1" @@ -3584,8 +11167,6 @@ }, "ws": { "version": "1.1.5", - "resolved": "https://registry.npmjs.org/ws/-/ws-1.1.5.tgz", - "integrity": "sha512-o3KqipXNUdS7wpQzBHSe180lBGO60SoK0yVo3CYJgb2MkobuWuBX6dhkYP5ORCLd55y+SaflMOV5fqAB53ux4w==", "dev": true, "requires": { "options": ">=0.0.5", @@ -3596,8 +11177,6 @@ }, "metro-babel-register": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-babel-register/-/metro-babel-register-0.66.2.tgz", - "integrity": "sha512-3F+vsVubUPJYKfVMeol8/7pd8CC287Rw92QYzJD8LEmI980xcgwMUEVBZ0UIAUwlLgiJG/f4Mwhuji2EeBXrPg==", "dev": true, "requires": { "@babel/core": "^7.14.0", @@ -3612,8 +11191,6 @@ }, "metro-babel-transformer": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-babel-transformer/-/metro-babel-transformer-0.66.2.tgz", - "integrity": "sha512-aJ/7fc/Xkofw8Fqa51OTDhBzBz26mmpIWrXAZcPdQ8MSTt883EWncxeCEjasc79NJ89BRi7sOkkaWZo2sXlKvw==", "dev": true, "requires": { "@babel/core": "^7.14.0", @@ -3624,8 +11201,6 @@ }, "metro-cache": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-cache/-/metro-cache-0.66.2.tgz", - "integrity": "sha512-5QCYJtJOHoBSbL3H4/Fpl36oA697C3oYHqsce+Hk/dh2qtODUGpS3gOBhvP1B8iB+H8jJMyR75lZq129LJEsIQ==", "dev": true, "requires": { "metro-core": "0.66.2", @@ -3635,14 +11210,10 @@ }, "metro-cache-key": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-cache-key/-/metro-cache-key-0.66.2.tgz", - "integrity": "sha512-WtkNmRt41qOpHh1MkNA4nLiQ/m7iGL90ysSKD+fcLqlUnOBKJptPQm0ZUv8Kfqk18ddWX2KmsSbq+Sf3I6XohQ==", "dev": true }, "metro-config": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-config/-/metro-config-0.66.2.tgz", - "integrity": "sha512-0C+PrKKIBNNzLZUKN/8ZDJS2U5FLMOTXDWbvBHIdqb6YXz8WplXR2+xlSlaSCCi5b+GR7cWFWUNeKA4GQS1/AQ==", "dev": true, "requires": { "cosmiconfig": "^5.0.5", @@ -3655,8 +11226,6 @@ }, "metro-core": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-core/-/metro-core-0.66.2.tgz", - "integrity": "sha512-JieLZkef/516yxXYvQxWnf3OWw5rcgWRy76K8JV/wr/i8LGVGulPAXlIi445/QZzXVydzRVASKAEVqyxM5F4mA==", "dev": true, "requires": { "jest-haste-map": "^26.5.2", @@ -3666,14 +11235,10 @@ }, "metro-hermes-compiler": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-hermes-compiler/-/metro-hermes-compiler-0.66.2.tgz", - "integrity": "sha512-nCVL1g9uR6vrw5+X1wjwZruRyMkndnzGRMqjqoljf+nGEqBTD607CR7elXw4fMWn/EM+1y0Vdq5altUu9LdgCA==", "dev": true }, "metro-inspector-proxy": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-inspector-proxy/-/metro-inspector-proxy-0.66.2.tgz", - "integrity": "sha512-gnLc9121eznwP0iiA9tCBW8qZjwIsCgwHWMF1g1Qaki9le9tzeJv3dK4/lFNGxyfSaLO7vahQEhsEYsiRnTROg==", "dev": true, "requires": { "connect": "^3.6.5", @@ -3684,8 +11249,6 @@ "dependencies": { "ws": { "version": "1.1.5", - "resolved": "https://registry.npmjs.org/ws/-/ws-1.1.5.tgz", - "integrity": "sha512-o3KqipXNUdS7wpQzBHSe180lBGO60SoK0yVo3CYJgb2MkobuWuBX6dhkYP5ORCLd55y+SaflMOV5fqAB53ux4w==", "dev": true, "requires": { "options": ">=0.0.5", @@ -3696,8 +11259,6 @@ }, "metro-minify-uglify": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-minify-uglify/-/metro-minify-uglify-0.66.2.tgz", - "integrity": "sha512-7TUK+L5CmB5x1PVnFbgmjzHW4CUadq9H5jgp0HfFoWT1skXAyEsx0DHkKDXwnot0khnNhBOEfl62ctQOnE110Q==", "dev": true, "requires": { "uglify-es": "^3.1.9" @@ -3705,8 +11266,6 @@ }, "metro-react-native-babel-preset": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-react-native-babel-preset/-/metro-react-native-babel-preset-0.66.2.tgz", - "integrity": "sha512-H/nLBAz0MgfDloSe1FjyH4EnbokHFdncyERvLPXDACY3ROVRCeUyFNo70ywRGXW2NMbrV4H7KUyU4zkfWhC2HQ==", "dev": true, "requires": { "@babel/core": "^7.14.0", @@ -3753,8 +11312,6 @@ }, "metro-react-native-babel-transformer": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-react-native-babel-transformer/-/metro-react-native-babel-transformer-0.66.2.tgz", - "integrity": "sha512-z1ab7ihIT0pJrwgi9q2IH+LcW/xUWMQ0hH+Mrk7wbKQB0RnJdXFoxphrfoVHBHMUu+TBPetUcEkKawkK1e7Cng==", "dev": true, "requires": { "@babel/core": "^7.14.0", @@ -3768,8 +11325,6 @@ }, "metro-resolver": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-resolver/-/metro-resolver-0.66.2.tgz", - "integrity": "sha512-pXQAJR/xauRf4kWFj2/hN5a77B4jLl0Fom5I3PHp6Arw/KxSBp0cnguXpGLwNQ6zQC0nxKCoYGL9gQpzMnN7Hw==", "dev": true, "requires": { "absolute-path": "^0.0.0" @@ -3777,14 +11332,10 @@ }, "metro-runtime": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-runtime/-/metro-runtime-0.66.2.tgz", - "integrity": "sha512-vFhKBk2ot9FS4b+2v0OTa/guCF/QDAOJubY0CNg7PzCS5+w4y3IvZIcPX4SSS1t8pYEZBLvtdtTDarlDl81xmg==", "dev": true }, "metro-source-map": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-source-map/-/metro-source-map-0.66.2.tgz", - "integrity": "sha512-038tFmB7vSh73VQcDWIbr5O1m+WXWyYafDaOy+1A/2K308YP0oj33gbEgDnZsLZDwcJ+xt1x6KUEBIzlX4YGeQ==", "dev": true, "requires": { "@babel/traverse": "^7.14.0", @@ -3799,16 +11350,12 @@ "dependencies": { "source-map": { "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", "dev": true } } }, "metro-symbolicate": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-symbolicate/-/metro-symbolicate-0.66.2.tgz", - "integrity": "sha512-u+DeQHyAFXVD7mVP+GST/894WHJ3i/U8oEJFnT7U3P52ZuLgX8n4tMNxhqZU12RcLR6etF8143aP0Ktx1gFLEQ==", "dev": true, "requires": { "invariant": "^2.2.4", @@ -3821,16 +11368,12 @@ "dependencies": { "source-map": { "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", "dev": true } } }, "metro-transform-plugins": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-transform-plugins/-/metro-transform-plugins-0.66.2.tgz", - "integrity": "sha512-KTvqplh0ut7oDKovvDG6yzXM02R6X+9b2oVG+qYq8Zd3aCGTi51ASx4ThCNkAHyEvCuJdYg9fxXTL+j+wvhB5w==", "dev": true, "requires": { "@babel/core": "^7.14.0", @@ -3842,8 +11385,6 @@ }, "metro-transform-worker": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/metro-transform-worker/-/metro-transform-worker-0.66.2.tgz", - "integrity": "sha512-dO4PtYOMGB7Vzte8aIzX39xytODhmbJrBYPu+zYzlDjyefJZT7BkZ0LkPIThtyJi96xWcGqi9JBSo0CeRupAHw==", "dev": true, "requires": { "@babel/core": "^7.14.0", @@ -3863,8 +11404,6 @@ }, "micromatch": { "version": "4.0.4", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", - "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", "dev": true, "requires": { "braces": "^3.0.1", @@ -3873,28 +11412,20 @@ "dependencies": { "picomatch": { "version": "2.3.1", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", - "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", "dev": true } } }, "mime": { "version": "1.6.0", - "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", - "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", "dev": true }, "mime-db": { "version": "1.51.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.51.0.tgz", - "integrity": "sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g==", "dev": true }, "mime-types": { "version": "2.1.34", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.34.tgz", - "integrity": "sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A==", "dev": true, "requires": { "mime-db": "1.51.0" @@ -3902,14 +11433,10 @@ }, "mimic-fn": { "version": "1.2.0", - "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", - "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", "dev": true }, "minimatch": { "version": "3.0.4", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", - "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", "dev": true, "requires": { "brace-expansion": "^1.1.7" @@ -3917,14 +11444,10 @@ }, "minimist": { "version": "1.2.5", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", - "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", "dev": true }, "mixin-deep": { "version": "1.3.2", - "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz", - "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==", "dev": true, "requires": { "for-in": "^1.0.2", @@ -3933,8 +11456,6 @@ "dependencies": { "is-extendable": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", - "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", "dev": true, "requires": { "is-plain-object": "^2.0.4" @@ -3944,8 +11465,6 @@ }, "mkdirp": { "version": "0.5.5", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", - "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", "dev": true, "requires": { "minimist": "^1.2.5" @@ -3953,14 +11472,10 @@ }, "ms": { "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", "dev": true }, "nanomatch": { "version": "1.2.13", - "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", - "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", "dev": true, "requires": { "arr-diff": "^4.0.0", @@ -3978,32 +11493,22 @@ }, "negotiator": { "version": "0.6.2", - "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", - "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", "dev": true }, "neo-async": { "version": "2.6.2", - "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz", - "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==", "dev": true }, "nice-try": { "version": "1.0.5", - "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", - "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", "dev": true }, "nocache": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/nocache/-/nocache-2.1.0.tgz", - "integrity": "sha512-0L9FvHG3nfnnmaEQPjT9xhfN4ISk0A8/2j4M37Np4mcDesJjHgEUfgPhdCyZuFI954tjokaIj/A3NdpFNdEh4Q==", "dev": true }, "node-dir": { "version": "0.1.17", - "resolved": "https://registry.npmjs.org/node-dir/-/node-dir-0.1.17.tgz", - "integrity": "sha1-X1Zl2TNRM1yqvvjxxVRRbPXx5OU=", "dev": true, "requires": { "minimatch": "^3.0.2" @@ -4011,8 +11516,6 @@ }, "node-fetch": { "version": "2.6.6", - "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.6.tgz", - "integrity": "sha512-Z8/6vRlTUChSdIgMa51jxQ4lrw/Jy5SOW10ObaA47/RElsAN2c5Pn8bTgFGWn/ibwzXTE8qwr1Yzx28vsecXEA==", "dev": true, "requires": { "whatwg-url": "^5.0.0" @@ -4020,32 +11523,24 @@ }, "node-int64": { "version": "0.4.0", - "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", - "integrity": "sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs=", "dev": true }, "node-releases": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.1.tgz", - "integrity": "sha512-CqyzN6z7Q6aMeF/ktcMVTzhAHCEpf8SOarwpzpf8pNBY2k5/oM34UHldUwp8VKI7uxct2HxSRdJjBaZeESzcxA==", + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.5.tgz", + "integrity": "sha512-U9h1NLROZTq9uE1SNffn6WuPDg8icmi3ns4rEl/oTfIle4iLjTliCzgTsbaIFMq/Xn078/lfY/BL0GWZ+psK4Q==", "dev": true }, "node-stream-zip": { "version": "1.15.0", - "resolved": "https://registry.npmjs.org/node-stream-zip/-/node-stream-zip-1.15.0.tgz", - "integrity": "sha512-LN4fydt9TqhZhThkZIVQnF9cwjU3qmUH9h78Mx/K7d3VvfRqqwthLwJEUOEL0QPZ0XQmNN7be5Ggit5+4dq3Bw==", "dev": true }, "normalize-path": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", - "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", "dev": true }, "npm-run-path": { "version": "2.0.2", - "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", - "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", "dev": true, "requires": { "path-key": "^2.0.0" @@ -4053,26 +11548,18 @@ }, "nullthrows": { "version": "1.1.1", - "resolved": "https://registry.npmjs.org/nullthrows/-/nullthrows-1.1.1.tgz", - "integrity": "sha512-2vPPEi+Z7WqML2jZYddDIfy5Dqb0r2fze2zTxNNknZaFpVHU3mFB3R+DWeJWGVx0ecvttSGlJTI+WG+8Z4cDWw==", "dev": true }, "ob1": { "version": "0.66.2", - "resolved": "https://registry.npmjs.org/ob1/-/ob1-0.66.2.tgz", - "integrity": "sha512-RFewnL/RjE0qQBOuM+2bbY96zmJPIge/aDtsiDbLSb+MOiK8CReAhBHDgL+zrA3F1hQk00lMWpUwYcep750plA==", "dev": true }, "object-assign": { "version": "4.1.1", - "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", - "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", "dev": true }, "object-copy": { "version": "0.1.0", - "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", - "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", "dev": true, "requires": { "copy-descriptor": "^0.1.0", @@ -4082,8 +11569,6 @@ "dependencies": { "define-property": { "version": "0.2.5", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", "dev": true, "requires": { "is-descriptor": "^0.1.0" @@ -4091,8 +11576,6 @@ }, "kind-of": { "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", "dev": true, "requires": { "is-buffer": "^1.1.5" @@ -4102,14 +11585,10 @@ }, "object-keys": { "version": "1.1.1", - "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", - "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", "dev": true }, "object-visit": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", - "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", "dev": true, "requires": { "isobject": "^3.0.0" @@ -4117,8 +11596,6 @@ }, "object.assign": { "version": "4.1.2", - "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", - "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", "dev": true, "requires": { "call-bind": "^1.0.0", @@ -4129,8 +11606,6 @@ }, "object.pick": { "version": "1.3.0", - "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", - "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", "dev": true, "requires": { "isobject": "^3.0.1" @@ -4138,8 +11613,6 @@ }, "on-finished": { "version": "2.3.0", - "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", - "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", "dev": true, "requires": { "ee-first": "1.1.1" @@ -4147,14 +11620,10 @@ }, "on-headers": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", - "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", "dev": true }, "once": { "version": "1.4.0", - "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", - "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", "dev": true, "requires": { "wrappy": "1" @@ -4162,8 +11631,6 @@ }, "onetime": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", - "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", "dev": true, "requires": { "mimic-fn": "^1.0.0" @@ -4171,8 +11638,6 @@ }, "open": { "version": "6.4.0", - "resolved": "https://registry.npmjs.org/open/-/open-6.4.0.tgz", - "integrity": "sha512-IFenVPgF70fSm1keSd2iDBIDIBZkroLeuffXq+wKTzTJlBpesFWojV9lb8mzOfaAzM1sr7HQHuO0vtV0zYekGg==", "dev": true, "requires": { "is-wsl": "^1.1.0" @@ -4180,14 +11645,10 @@ }, "options": { "version": "0.0.6", - "resolved": "https://registry.npmjs.org/options/-/options-0.0.6.tgz", - "integrity": "sha1-7CLTEoBrtT5zF3Pnza788cZDEo8=", "dev": true }, "ora": { "version": "3.4.0", - "resolved": "https://registry.npmjs.org/ora/-/ora-3.4.0.tgz", - "integrity": "sha512-eNwHudNbO1folBP3JsZ19v9azXWtQZjICdr3Q0TDPIaeBQ3mXLrh54wM+er0+hSp+dWKf+Z8KM58CYzEyIYxYg==", "dev": true, "requires": { "chalk": "^2.4.2", @@ -4200,8 +11661,6 @@ "dependencies": { "ansi-styles": { "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", "dev": true, "requires": { "color-convert": "^1.9.0" @@ -4209,8 +11668,6 @@ }, "chalk": { "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", "dev": true, "requires": { "ansi-styles": "^3.2.1", @@ -4220,8 +11677,6 @@ }, "color-convert": { "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", "dev": true, "requires": { "color-name": "1.1.3" @@ -4229,20 +11684,14 @@ }, "color-name": { "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", "dev": true }, "has-flag": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", "dev": true }, "supports-color": { "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", "dev": true, "requires": { "has-flag": "^3.0.0" @@ -4252,20 +11701,14 @@ }, "os-tmpdir": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", - "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", "dev": true }, "p-finally": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", - "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", "dev": true }, "p-limit": { "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", "dev": true, "requires": { "p-try": "^2.0.0" @@ -4273,8 +11716,6 @@ }, "p-locate": { "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", "dev": true, "requires": { "p-limit": "^2.2.0" @@ -4282,14 +11723,10 @@ }, "p-try": { "version": "2.2.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", - "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", "dev": true }, "parse-json": { "version": "4.0.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", - "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", "dev": true, "requires": { "error-ex": "^1.3.1", @@ -4298,32 +11735,22 @@ }, "parseurl": { "version": "1.3.3", - "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", - "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", "dev": true }, "pascalcase": { "version": "0.1.1", - "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", - "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", "dev": true }, "path-exists": { "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", - "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", "dev": true }, "path-is-absolute": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", "dev": true }, "path-key": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", - "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", "dev": true }, "path-parse": { @@ -4340,26 +11767,18 @@ }, "picomatch": { "version": "2.0.7", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.0.7.tgz", - "integrity": "sha512-oLHIdio3tZ0qH76NybpeneBhYVj0QFTfXEFTc/B3zKQspYfYYkWYgFsmzo+4kvId/bQRcNkVeguI3y+CD22BtA==", "dev": true }, "pify": { "version": "4.0.1", - "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", - "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", "dev": true }, "pirates": { "version": "4.0.4", - "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.4.tgz", - "integrity": "sha512-ZIrVPH+A52Dw84R0L3/VS9Op04PuQ2SEoJL6bkshmiTic/HldyW9Tf7oH5mhJZBK7NmDx27vSMrYEXPXclpDKw==", "dev": true }, "pkg-dir": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", - "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", "dev": true, "requires": { "find-up": "^3.0.0" @@ -4367,8 +11786,6 @@ "dependencies": { "find-up": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", - "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", "dev": true, "requires": { "locate-path": "^3.0.0" @@ -4376,8 +11793,6 @@ }, "locate-path": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", - "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", "dev": true, "requires": { "p-locate": "^3.0.0", @@ -4386,8 +11801,6 @@ }, "p-locate": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", - "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", "dev": true, "requires": { "p-limit": "^2.0.0" @@ -4395,16 +11808,12 @@ }, "path-exists": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", - "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", "dev": true } } }, "plist": { "version": "3.0.4", - "resolved": "https://registry.npmjs.org/plist/-/plist-3.0.4.tgz", - "integrity": "sha512-ksrr8y9+nXOxQB2osVNqrgvX/XQPOXaU4BQMKjYq8PvaY1U18mo+fKgBSwzK+luSyinOuPae956lSVcBwxlAMg==", "dev": true, "requires": { "base64-js": "^1.5.1", @@ -4413,14 +11822,10 @@ }, "posix-character-classes": { "version": "0.1.1", - "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", - "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", "dev": true }, "pretty-format": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-26.6.2.tgz", - "integrity": "sha512-7AeGuCYNGmycyQbCqd/3PWH4eOoX/OiCa0uphp57NVTeAGdJGaAliecxwBDHYQCIvrW7aDBZCYeNTP/WX69mkg==", "dev": true, "requires": { "@jest/types": "^26.6.2", @@ -4431,8 +11836,6 @@ "dependencies": { "@jest/types": { "version": "26.6.2", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.6.2.tgz", - "integrity": "sha512-fC6QCp7Sc5sX6g8Tvbmj4XUTbyrik0akgRy03yjXbQaBWWNWGE7SGtJk98m0N8nzegD/7SggrUlivxo5ax4KWQ==", "dev": true, "requires": { "@types/istanbul-lib-coverage": "^2.0.0", @@ -4444,8 +11847,6 @@ }, "@types/yargs": { "version": "15.0.14", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.14.tgz", - "integrity": "sha512-yEJzHoxf6SyQGhBhIYGXQDSCkJjB6HohDShto7m8vaKg9Yp0Yn8+71J9eakh2bnPg6BfsH9PRMhiRTZnd4eXGQ==", "dev": true, "requires": { "@types/yargs-parser": "*" @@ -4453,22 +11854,16 @@ }, "ansi-regex": { "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", "dev": true } } }, "process-nextick-args": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", - "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", "dev": true }, "promise": { "version": "8.1.0", - "resolved": "https://registry.npmjs.org/promise/-/promise-8.1.0.tgz", - "integrity": "sha512-W04AqnILOL/sPRXziNicCjSNRruLAuIHEOVBazepu0545DDNGYHz7ar9ZgZ1fMU8/MA4mVxp5rkBWRi6OXIy3Q==", "dev": true, "requires": { "asap": "~2.0.6" @@ -4476,8 +11871,6 @@ }, "prompts": { "version": "2.4.2", - "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", - "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", "dev": true, "requires": { "kleur": "^3.0.3", @@ -4486,8 +11879,6 @@ }, "prop-types": { "version": "15.8.1", - "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", - "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", "dev": true, "requires": { "loose-envify": "^1.4.0", @@ -4497,16 +11888,12 @@ "dependencies": { "react-is": { "version": "16.13.1", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", - "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", "dev": true } } }, "pump": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", - "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", "dev": true, "requires": { "end-of-stream": "^1.1.0", @@ -4515,14 +11902,10 @@ }, "range-parser": { "version": "1.2.1", - "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", - "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", "dev": true }, "react": { "version": "17.0.2", - "resolved": "https://registry.npmjs.org/react/-/react-17.0.2.tgz", - "integrity": "sha512-gnhPt75i/dq/z3/6q/0asP78D0u592D5L1pd7M8P+dck6Fu/jJeL6iVVK23fptSUZj8Vjf++7wXA8UNclGQcbA==", "dev": true, "requires": { "loose-envify": "^1.1.0", @@ -4531,8 +11914,6 @@ }, "react-devtools-core": { "version": "4.22.1", - "resolved": "https://registry.npmjs.org/react-devtools-core/-/react-devtools-core-4.22.1.tgz", - "integrity": "sha512-pvpNDHE7p0FtcCmIWGazoY8LLVfBI9sw0Kf10kdHhPI9Tzt3OG/qEt16GrAbE0keuna5WzX3r1qPKVjqOqsuUg==", "dev": true, "requires": { "shell-quote": "^1.6.1", @@ -4541,22 +11922,17 @@ "dependencies": { "ws": { "version": "7.5.6", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.6.tgz", - "integrity": "sha512-6GLgCqo2cy2A2rjCNFlxQS6ZljG/coZfZXclldI8FB/1G3CCI36Zd8xy2HrFVACi8tfk5XrgLQEk+P0Tnz9UcA==", - "dev": true + "dev": true, + "requires": {} } } }, "react-is": { "version": "17.0.2", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", - "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", "dev": true }, "react-native": { "version": "0.66.4", - "resolved": "https://registry.npmjs.org/react-native/-/react-native-0.66.4.tgz", - "integrity": "sha512-9vx5dlSfQlKbbDtr8+xMon6qsmSu7jvjdXWZpEKh3XVKpUidbbODv7048gwVKX8YAel1egeR7hN8vzSeI6ssTw==", "dev": true, "requires": { "@jest/create-cache-key-function": "^27.0.1", @@ -4594,8 +11970,6 @@ "dependencies": { "@react-native-community/cli": { "version": "6.3.1", - "resolved": "https://registry.npmjs.org/@react-native-community/cli/-/cli-6.3.1.tgz", - "integrity": "sha512-UQ77AkGvPzdwJt6qhYXUyDMP1v2rdCcIlrhU48FOcAhGX+N/LCL9Cp/Ic6CkiiSHJdktbgiEEJ2srprXH8nzVg==", "dev": true, "requires": { "@react-native-community/cli-debugger-ui": "^6.0.0-rc.0", @@ -4635,8 +12009,6 @@ }, "react-native-codegen": { "version": "0.0.7", - "resolved": "https://registry.npmjs.org/react-native-codegen/-/react-native-codegen-0.0.7.tgz", - "integrity": "sha512-dwNgR8zJ3ALr480QnAmpTiqvFo+rDtq6V5oCggKhYFlRjzOmVSFn3YD41u8ltvKS5G2nQ8gCs2vReFFnRGLYng==", "dev": true, "requires": { "flow-parser": "^0.121.0", @@ -4646,14 +12018,10 @@ }, "react-refresh": { "version": "0.4.3", - "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.4.3.tgz", - "integrity": "sha512-Hwln1VNuGl/6bVwnd0Xdn1e84gT/8T9aYNL+HAKDArLCS7LWjwr7StE30IEYbIkx0Vi3vs+coQxe+SQDbGbbpA==", "dev": true }, "readable-stream": { "version": "2.3.7", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", - "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", "dev": true, "requires": { "core-util-is": "~1.0.0", @@ -4667,8 +12035,6 @@ }, "readdirp": { "version": "3.1.2", - "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.1.2.tgz", - "integrity": "sha512-8rhl0xs2cxfVsqzreYCvs8EwBfn/DhVdqtoLmw19uI3SC5avYX9teCurlErfpPXGmYtMHReGaP2RsLnFvz/lnw==", "dev": true, "requires": { "picomatch": "^2.0.4" @@ -4676,14 +12042,10 @@ }, "readline": { "version": "1.3.0", - "resolved": "https://registry.npmjs.org/readline/-/readline-1.3.0.tgz", - "integrity": "sha1-xYDXfvLPyHUrEySYBg3JeTp6wBw=", "dev": true }, "recast": { "version": "0.20.5", - "resolved": "https://registry.npmjs.org/recast/-/recast-0.20.5.tgz", - "integrity": "sha512-E5qICoPoNL4yU0H0NoBDntNB0Q5oMSNh9usFctYniLBluTthi3RsQVBXIJNbApOlvSwW/RGxIuokPcAc59J5fQ==", "dev": true, "requires": { "ast-types": "0.14.2", @@ -4694,14 +12056,6 @@ "dependencies": { "source-map": { "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true - }, - "tslib": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", - "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", "dev": true } } @@ -4713,9 +12067,9 @@ "dev": true }, "regenerate-unicode-properties": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-9.0.0.tgz", - "integrity": "sha512-3E12UeNSPfjrgwjkR81m5J7Aw/T55Tu7nUyZVQYCKEOs+2dkxEY+DpPtZzO4YruuiPb7NkYLVcyJC4+zCbk5pA==", + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.0.1.tgz", + "integrity": "sha512-vn5DU6yg6h8hP/2OkQo3K7uVILvY4iu0oI4t3HFa81UPkhGJwkRwM10JEc3upjdhHjs/k8GJY1sRBhk5sr69Bw==", "dev": true, "requires": { "regenerate": "^1.4.2" @@ -4723,14 +12077,12 @@ }, "regenerator-runtime": { "version": "0.13.9", - "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz", - "integrity": "sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA==", "dev": true }, "regenerator-transform": { - "version": "0.14.5", - "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.14.5.tgz", - "integrity": "sha512-eOf6vka5IO151Jfsw2NO9WpGX58W6wWmefK3I1zEGr0lOD0u8rwPaNqQL1aRxUaxLeKO3ArNh3VYg1KbaD+FFw==", + "version": "0.15.0", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.0.tgz", + "integrity": "sha512-LsrGtPmbYg19bcPHwdtmXwbW+TqNvtY4riE3P83foeHRroMbH6/2ddFBfab3t7kbzc7v7p4wbkIecHImqt0QNg==", "dev": true, "requires": { "@babel/runtime": "^7.8.4" @@ -4738,8 +12090,6 @@ }, "regex-not": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", - "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", "dev": true, "requires": { "extend-shallow": "^3.0.2", @@ -4747,29 +12097,29 @@ } }, "regexpu-core": { - "version": "4.8.0", - "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-4.8.0.tgz", - "integrity": "sha512-1F6bYsoYiz6is+oz70NWur2Vlh9KWtswuRuzJOfeYUrfPX2o8n74AnUVaOGDbUqVGO9fNHu48/pjJO4sNVwsOg==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.1.0.tgz", + "integrity": "sha512-bb6hk+xWd2PEOkj5It46A16zFMs2mv86Iwpdu94la4S3sJ7C973h2dHpYKwIBGaWSO7cIRJ+UX0IeMaWcO4qwA==", "dev": true, "requires": { "regenerate": "^1.4.2", - "regenerate-unicode-properties": "^9.0.0", - "regjsgen": "^0.5.2", - "regjsparser": "^0.7.0", + "regenerate-unicode-properties": "^10.0.1", + "regjsgen": "^0.6.0", + "regjsparser": "^0.8.2", "unicode-match-property-ecmascript": "^2.0.0", "unicode-match-property-value-ecmascript": "^2.0.0" } }, "regjsgen": { - "version": "0.5.2", - "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.5.2.tgz", - "integrity": "sha512-OFFT3MfrH90xIW8OOSyUrk6QHD5E9JOTeGodiJeBS3J6IwlgzJMNE/1bZklWz5oTg+9dCMyEetclvCVXOPoN3A==", + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.6.0.tgz", + "integrity": "sha512-ozE883Uigtqj3bx7OhL1KNbCzGyW2NQZPl6Hs09WTvCuZD5sTI4JY58bkbQWa/Y9hxIsvJ3M8Nbf7j54IqeZbA==", "dev": true }, "regjsparser": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.7.0.tgz", - "integrity": "sha512-A4pcaORqmNMDVwUjWoTzuhwMGpP+NykpfqAsEgI1FSH/EzC7lrN5TMd+kN8YCovX+jMpu8eaqXgXPCa0g8FQNQ==", + "version": "0.8.4", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.8.4.tgz", + "integrity": "sha512-J3LABycON/VNEu3abOviqGHuB/LOtOQj8SKmfP9anY5GfAVw/SPjwzSjxGjbZXIxbGfqTHtJw58C2Li/WkStmA==", "dev": true, "requires": { "jsesc": "~0.5.0" @@ -4778,68 +12128,52 @@ "jsesc": { "version": "0.5.0", "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", - "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", + "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==", "dev": true } } }, "remove-trailing-separator": { "version": "1.1.0", - "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", - "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", "dev": true }, "repeat-element": { "version": "1.1.4", - "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.4.tgz", - "integrity": "sha512-LFiNfRcSu7KK3evMyYOuCzv3L10TW7yC1G2/+StMjK8Y6Vqd2MG7r/Qjw4ghtuCOjFvlnms/iMmLqpvW/ES/WQ==", "dev": true }, "repeat-string": { "version": "1.6.1", - "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", - "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", "dev": true }, "require-directory": { "version": "2.1.1", - "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", - "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", "dev": true }, "require-main-filename": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", - "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", "dev": true }, "resolve": { - "version": "1.21.0", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.21.0.tgz", - "integrity": "sha512-3wCbTpk5WJlyE4mSOtDLhqQmGFi0/TD9VPwmiolnk8U0wRgMEktqCXd3vy5buTO3tljvalNvKrjHEfrd2WpEKA==", + "version": "1.22.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", + "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", "dev": true, "requires": { - "is-core-module": "^2.8.0", + "is-core-module": "^2.9.0", "path-parse": "^1.0.7", "supports-preserve-symlinks-flag": "^1.0.0" } }, "resolve-from": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", - "integrity": "sha1-six699nWiBvItuZTM17rywoYh0g=", "dev": true }, "resolve-url": { "version": "0.2.1", - "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", - "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", "dev": true }, "restore-cursor": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", - "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", "dev": true, "requires": { "onetime": "^2.0.0", @@ -4848,14 +12182,10 @@ }, "ret": { "version": "0.1.15", - "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", - "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", "dev": true }, "rimraf": { "version": "2.7.1", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", - "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", "dev": true, "requires": { "glob": "^7.1.3" @@ -4863,28 +12193,21 @@ }, "rsvp": { "version": "4.8.5", - "resolved": "https://registry.npmjs.org/rsvp/-/rsvp-4.8.5.tgz", - "integrity": "sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==", "dev": true }, "rxjs": { - "version": "6.5.3", - "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.3.tgz", - "integrity": "sha512-wuYsAYYFdWTAnAaPoKGNhfpWwKZbJW+HgAJ+mImp+Epl7BG8oNWBCTyRM8gba9k4lk8BgWdoYm21Mo/RYhhbgA==", + "version": "7.5.5", + "peer": true, "requires": { - "tslib": "^1.9.0" + "tslib": "^2.1.0" } }, "safe-buffer": { "version": "5.1.2", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", "dev": true }, "safe-regex": { "version": "1.1.0", - "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", - "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", "dev": true, "requires": { "ret": "~0.1.10" @@ -4892,8 +12215,6 @@ }, "sane": { "version": "4.1.0", - "resolved": "https://registry.npmjs.org/sane/-/sane-4.1.0.tgz", - "integrity": "sha512-hhbzAgTIX8O7SHfp2c8/kREfEn4qO/9q8C9beyY6+tvZ87EpoZ3i1RIEvp27YBswnNbY9mWd6paKVmKbAgLfZA==", "dev": true, "requires": { "@cnakazawa/watch": "^1.0.3", @@ -4909,8 +12230,6 @@ "dependencies": { "anymatch": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", - "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", "dev": true, "requires": { "micromatch": "^3.1.4", @@ -4919,8 +12238,6 @@ }, "braces": { "version": "2.3.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", - "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", "dev": true, "requires": { "arr-flatten": "^1.1.0", @@ -4937,8 +12254,6 @@ "dependencies": { "extend-shallow": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", "dev": true, "requires": { "is-extendable": "^0.1.0" @@ -4948,8 +12263,6 @@ }, "fill-range": { "version": "4.0.0", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", - "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", "dev": true, "requires": { "extend-shallow": "^2.0.1", @@ -4960,8 +12273,6 @@ "dependencies": { "extend-shallow": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", "dev": true, "requires": { "is-extendable": "^0.1.0" @@ -4971,8 +12282,6 @@ }, "is-number": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", "dev": true, "requires": { "kind-of": "^3.0.2" @@ -4980,8 +12289,6 @@ "dependencies": { "kind-of": { "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", "dev": true, "requires": { "is-buffer": "^1.1.5" @@ -4991,8 +12298,6 @@ }, "micromatch": { "version": "3.1.10", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", "dev": true, "requires": { "arr-diff": "^4.0.0", @@ -5012,8 +12317,6 @@ }, "normalize-path": { "version": "2.1.1", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", - "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", "dev": true, "requires": { "remove-trailing-separator": "^1.0.1" @@ -5021,8 +12324,6 @@ }, "to-regex-range": { "version": "2.1.1", - "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", - "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", "dev": true, "requires": { "is-number": "^3.0.0", @@ -5033,14 +12334,10 @@ }, "sax": { "version": "1.2.4", - "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", - "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", "dev": true }, "scheduler": { "version": "0.20.2", - "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.20.2.tgz", - "integrity": "sha512-2eWfGgAqqWFGqtdMmcL5zCMK1U8KlXv8SQFGglL3CEtd0aDVDWgeF/YoCmvln55m5zSk3J/20hTaSBeSObsQDQ==", "dev": true, "requires": { "loose-envify": "^1.1.0", @@ -5049,14 +12346,10 @@ }, "semver": { "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", "dev": true }, "send": { "version": "0.17.2", - "resolved": "https://registry.npmjs.org/send/-/send-0.17.2.tgz", - "integrity": "sha512-UJYB6wFSJE3G00nEivR5rgWp8c2xXvJ3OPWPhmuteU0IKj8nKbG3DrjiOmLwpnHGYWAVwA69zmTm++YG0Hmwww==", "dev": true, "requires": { "debug": "2.6.9", @@ -5076,14 +12369,10 @@ }, "serialize-error": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/serialize-error/-/serialize-error-2.1.0.tgz", - "integrity": "sha1-ULZ51WNc34Rme9yOWa9OW4HV9go=", "dev": true }, "serve-static": { "version": "1.14.2", - "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.2.tgz", - "integrity": "sha512-+TMNA9AFxUEGuC0z2mevogSnn9MXKb4fa7ngeRMJaaGv8vTwnIEkKi+QGvPt33HSnf8pRS+WGM0EbMtCJLKMBQ==", "dev": true, "requires": { "encodeurl": "~1.0.2", @@ -5094,14 +12383,10 @@ }, "set-blocking": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", - "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", "dev": true }, "set-value": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz", - "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==", "dev": true, "requires": { "extend-shallow": "^2.0.1", @@ -5112,8 +12397,6 @@ "dependencies": { "extend-shallow": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", "dev": true, "requires": { "is-extendable": "^0.1.0" @@ -5123,14 +12406,10 @@ }, "setprototypeof": { "version": "1.2.0", - "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", - "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", "dev": true }, "shallow-clone": { "version": "3.0.1", - "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", - "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", "dev": true, "requires": { "kind-of": "^6.0.2" @@ -5138,8 +12417,6 @@ }, "shebang-command": { "version": "1.2.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", - "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", "dev": true, "requires": { "shebang-regex": "^1.0.0" @@ -5147,14 +12424,10 @@ }, "shebang-regex": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", - "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", "dev": true }, "shell-quote": { "version": "1.6.1", - "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.6.1.tgz", - "integrity": "sha1-9HgZSczkAmlxJ0MOo7PFR29IF2c=", "dev": true, "requires": { "array-filter": "~0.0.0", @@ -5165,14 +12438,10 @@ }, "signal-exit": { "version": "3.0.6", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.6.tgz", - "integrity": "sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ==", "dev": true }, "simple-plist": { "version": "1.3.0", - "resolved": "https://registry.npmjs.org/simple-plist/-/simple-plist-1.3.0.tgz", - "integrity": "sha512-uYWpeGFtZtVt2NhG4AHgpwx323zxD85x42heMJBan1qAiqqozIlaGrwrEt6kRjXWRWIXsuV1VLCvVmZan2B5dg==", "dev": true, "requires": { "bplist-creator": "0.1.0", @@ -5182,20 +12451,14 @@ }, "sisteransi": { "version": "1.0.5", - "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", - "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", "dev": true }, "slash": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", - "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", "dev": true }, "slice-ansi": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", - "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", "dev": true, "requires": { "ansi-styles": "^3.2.0", @@ -5205,8 +12468,6 @@ "dependencies": { "ansi-styles": { "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", "dev": true, "requires": { "color-convert": "^1.9.0" @@ -5214,8 +12475,6 @@ }, "color-convert": { "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", "dev": true, "requires": { "color-name": "1.1.3" @@ -5223,16 +12482,12 @@ }, "color-name": { "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", "dev": true } } }, "snapdragon": { "version": "0.8.2", - "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", - "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", "dev": true, "requires": { "base": "^0.11.1", @@ -5247,8 +12502,6 @@ "dependencies": { "define-property": { "version": "0.2.5", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", "dev": true, "requires": { "is-descriptor": "^0.1.0" @@ -5256,8 +12509,6 @@ }, "extend-shallow": { "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", "dev": true, "requires": { "is-extendable": "^0.1.0" @@ -5265,16 +12516,12 @@ }, "source-map": { "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", "dev": true } } }, "snapdragon-node": { "version": "2.1.1", - "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", - "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", "dev": true, "requires": { "define-property": "^1.0.0", @@ -5284,8 +12531,6 @@ "dependencies": { "define-property": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", - "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", "dev": true, "requires": { "is-descriptor": "^1.0.0" @@ -5293,8 +12538,6 @@ }, "is-accessor-descriptor": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", - "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", "dev": true, "requires": { "kind-of": "^6.0.0" @@ -5302,8 +12545,6 @@ }, "is-data-descriptor": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", - "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", "dev": true, "requires": { "kind-of": "^6.0.0" @@ -5311,8 +12552,6 @@ }, "is-descriptor": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", - "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", "dev": true, "requires": { "is-accessor-descriptor": "^1.0.0", @@ -5324,8 +12563,6 @@ }, "snapdragon-util": { "version": "3.0.1", - "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", - "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", "dev": true, "requires": { "kind-of": "^3.2.0" @@ -5333,8 +12570,6 @@ "dependencies": { "kind-of": { "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", "dev": true, "requires": { "is-buffer": "^1.1.5" @@ -5344,14 +12579,10 @@ }, "source-map": { "version": "0.7.3", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", - "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", "dev": true }, "source-map-resolve": { "version": "0.5.3", - "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.3.tgz", - "integrity": "sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw==", "dev": true, "requires": { "atob": "^2.1.2", @@ -5363,8 +12594,6 @@ }, "source-map-support": { "version": "0.5.21", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", - "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", "dev": true, "requires": { "buffer-from": "^1.0.0", @@ -5373,22 +12602,16 @@ "dependencies": { "source-map": { "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", "dev": true } } }, "source-map-url": { "version": "0.4.1", - "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.1.tgz", - "integrity": "sha512-cPiFOTLUKvJFIg4SKVScy4ilPPW6rFgMgfuZJPNoDuMs3nC1HbMUycBoJw77xFIp6z1UJQJOfx6C9GMH80DiTw==", "dev": true }, "split-string": { "version": "3.1.0", - "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", - "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", "dev": true, "requires": { "extend-shallow": "^3.0.0" @@ -5396,20 +12619,14 @@ }, "sprintf-js": { "version": "1.0.3", - "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", - "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", "dev": true }, "stackframe": { "version": "1.2.0", - "resolved": "https://registry.npmjs.org/stackframe/-/stackframe-1.2.0.tgz", - "integrity": "sha512-GrdeshiRmS1YLMYgzF16olf2jJ/IzxXY9lhKOskuVziubpTYcYqyOwYeJKzQkwy7uN0fYSsbsC4RQaXf9LCrYA==", "dev": true }, "stacktrace-parser": { "version": "0.1.10", - "resolved": "https://registry.npmjs.org/stacktrace-parser/-/stacktrace-parser-0.1.10.tgz", - "integrity": "sha512-KJP1OCML99+8fhOHxwwzyWrlUuVX5GQ0ZpJTd1DFXhdkrvg1szxfHhawXUZ3g9TkXORQd4/WG68jMlQZ2p8wlg==", "dev": true, "requires": { "type-fest": "^0.7.1" @@ -5417,8 +12634,6 @@ }, "static-extend": { "version": "0.1.2", - "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", - "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", "dev": true, "requires": { "define-property": "^0.2.5", @@ -5427,8 +12642,6 @@ "dependencies": { "define-property": { "version": "0.2.5", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", "dev": true, "requires": { "is-descriptor": "^0.1.0" @@ -5438,20 +12651,21 @@ }, "statuses": { "version": "1.5.0", - "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", - "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", "dev": true }, "stream-buffers": { "version": "2.2.0", - "resolved": "https://registry.npmjs.org/stream-buffers/-/stream-buffers-2.2.0.tgz", - "integrity": "sha1-kdX1Ew0c75bc+n9yaUUYh0HQnuQ=", "dev": true }, + "string_decoder": { + "version": "1.1.1", + "dev": true, + "requires": { + "safe-buffer": "~5.1.0" + } + }, "string-width": { "version": "4.2.3", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", - "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", "dev": true, "requires": { "emoji-regex": "^8.0.0", @@ -5461,20 +12675,14 @@ "dependencies": { "ansi-regex": { "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", "dev": true }, "is-fullwidth-code-point": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", - "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", "dev": true }, "strip-ansi": { "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", "dev": true, "requires": { "ansi-regex": "^5.0.1" @@ -5482,19 +12690,8 @@ } } }, - "string_decoder": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", - "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", - "dev": true, - "requires": { - "safe-buffer": "~5.1.0" - } - }, "strip-ansi": { "version": "5.2.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", - "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", "dev": true, "requires": { "ansi-regex": "^4.1.0" @@ -5502,20 +12699,14 @@ }, "strip-eof": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", - "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", "dev": true }, "sudo-prompt": { "version": "9.2.1", - "resolved": "https://registry.npmjs.org/sudo-prompt/-/sudo-prompt-9.2.1.tgz", - "integrity": "sha512-Mu7R0g4ig9TUuGSxJavny5Rv0egCEtpZRNMrZaYS1vxkiIxGiGUwoezU3LazIQ+KE04hTrTfNPgxU5gzi7F5Pw==", "dev": true }, "supports-color": { "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", "dev": true, "requires": { "has-flag": "^4.0.0" @@ -5529,8 +12720,6 @@ }, "temp": { "version": "0.8.3", - "resolved": "https://registry.npmjs.org/temp/-/temp-0.8.3.tgz", - "integrity": "sha1-4Ma8TSa5AxJEEOT+2BEDAU38H1k=", "dev": true, "requires": { "os-tmpdir": "^1.0.0", @@ -5539,22 +12728,16 @@ "dependencies": { "rimraf": { "version": "2.2.8", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.2.8.tgz", - "integrity": "sha1-5Dm+Kq7jJzIZUnMPmaiSnk/FBYI=", "dev": true } } }, "throat": { "version": "5.0.0", - "resolved": "https://registry.npmjs.org/throat/-/throat-5.0.0.tgz", - "integrity": "sha512-fcwX4mndzpLQKBS1DVYhGAcYaYt7vsHNIvQV+WXMvnow5cgjPphq5CaayLaGsjRdSCKZFNGt7/GYAuXaNOiYCA==", "dev": true }, "through2": { "version": "2.0.5", - "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", - "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", "dev": true, "requires": { "readable-stream": "~2.3.6", @@ -5563,20 +12746,14 @@ }, "tmpl": { "version": "1.0.5", - "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", - "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", "dev": true }, "to-fast-properties": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", - "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", "dev": true }, "to-object-path": { "version": "0.3.0", - "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", - "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", "dev": true, "requires": { "kind-of": "^3.0.2" @@ -5584,8 +12761,6 @@ "dependencies": { "kind-of": { "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", "dev": true, "requires": { "is-buffer": "^1.1.5" @@ -5595,8 +12770,6 @@ }, "to-regex": { "version": "3.0.2", - "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", - "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", "dev": true, "requires": { "define-property": "^2.0.2", @@ -5607,8 +12780,6 @@ }, "to-regex-range": { "version": "5.0.1", - "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", - "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", "dev": true, "requires": { "is-number": "^7.0.0" @@ -5616,31 +12787,25 @@ }, "toidentifier": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", - "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", "dev": true }, "tr46": { "version": "0.0.3", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", - "integrity": "sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o=", "dev": true }, "tslib": { - "version": "1.10.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", - "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" + "version": "2.3.1" }, "type-fest": { "version": "0.7.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.7.1.tgz", - "integrity": "sha512-Ne2YiiGN8bmrmJJEuTWTLJR32nh/JdL1+PSicowtNb0WFpn59GK8/lfD61bVtzguz7b3PBt74nxpv/Pw5po5Rg==", + "dev": true + }, + "typescript": { + "version": "4.6.2", "dev": true }, "uglify-es": { "version": "3.3.9", - "resolved": "https://registry.npmjs.org/uglify-es/-/uglify-es-3.3.9.tgz", - "integrity": "sha512-r+MU0rfv4L/0eeW3xZrd16t4NZfK8Ld4SWVglYBb7ez5uXFWHuVRs6xCTrf1yirs9a4j4Y27nn7SRfO6v67XsQ==", "dev": true, "requires": { "commander": "~2.13.0", @@ -5649,22 +12814,16 @@ "dependencies": { "commander": { "version": "2.13.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.13.0.tgz", - "integrity": "sha512-MVuS359B+YzaWqjCL/c+22gfryv+mCBPHAv3zyVI2GN8EY6IRP8VwtasXn8jyyhvvq84R4ImN1OKRtcbIasjYA==", "dev": true }, "source-map": { "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", "dev": true } } }, "ultron": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.0.2.tgz", - "integrity": "sha1-rOEWq1V80Zc4ak6I9GhTeMiy5Po=", "dev": true }, "unicode-canonical-property-names-ecmascript": { @@ -5697,8 +12856,6 @@ }, "union-value": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz", - "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==", "dev": true, "requires": { "arr-union": "^3.1.0", @@ -5709,20 +12866,14 @@ }, "universalify": { "version": "0.1.2", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", - "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", "dev": true }, "unpipe": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", - "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", "dev": true }, "unset-value": { "version": "1.0.0", - "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", - "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", "dev": true, "requires": { "has-value": "^0.3.1", @@ -5731,8 +12882,6 @@ "dependencies": { "has-value": { "version": "0.3.1", - "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", - "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", "dev": true, "requires": { "get-value": "^2.0.3", @@ -5742,8 +12891,6 @@ "dependencies": { "isobject": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", - "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", "dev": true, "requires": { "isarray": "1.0.0" @@ -5753,28 +12900,30 @@ }, "has-values": { "version": "0.1.4", - "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", - "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", "dev": true } } }, + "update-browserslist-db": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.4.tgz", + "integrity": "sha512-jnmO2BEGUjsMOe/Fg9u0oczOe/ppIDZPebzccl1yDWGLFP16Pa1/RM5wEoKYPG2zstNcDuAStejyxsOuKINdGA==", + "dev": true, + "requires": { + "escalade": "^3.1.1", + "picocolors": "^1.0.0" + } + }, "urix": { "version": "0.1.0", - "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", - "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", "dev": true }, "use": { "version": "3.1.1", - "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", - "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", "dev": true }, "use-subscription": { "version": "1.5.1", - "resolved": "https://registry.npmjs.org/use-subscription/-/use-subscription-1.5.1.tgz", - "integrity": "sha512-Xv2a1P/yReAjAbhylMfFplFKj9GssgTwN7RlcTxBujFQcloStWNDQdc4g4NRWH9xS4i/FDk04vQBptAXoF3VcA==", "dev": true, "requires": { "object-assign": "^4.1.1" @@ -5782,38 +12931,26 @@ }, "util-deprecate": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", - "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", "dev": true }, "utils-merge": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", - "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", "dev": true }, "uuid": { "version": "3.4.0", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", - "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", "dev": true }, "vary": { "version": "1.1.2", - "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", - "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", "dev": true }, "vlq": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/vlq/-/vlq-1.0.1.tgz", - "integrity": "sha512-gQpnTgkubC6hQgdIcRdYGDSDc+SaujOdyesZQMv6JlfQee/9Mp0Qhnys6WxDWvQnL5WZdT7o2Ul187aSt0Rq+w==", "dev": true }, "walker": { "version": "1.0.8", - "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", - "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", "dev": true, "requires": { "makeerror": "1.0.12" @@ -5821,8 +12958,6 @@ }, "wcwidth": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz", - "integrity": "sha1-8LDc+RW8X/FSivrbLA4XtTLaL+g=", "dev": true, "requires": { "defaults": "^1.0.3" @@ -5830,20 +12965,14 @@ }, "webidl-conversions": { "version": "3.0.1", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", - "integrity": "sha1-JFNCdeKnvGvnvIZhHMFq4KVlSHE=", "dev": true }, "whatwg-fetch": { "version": "3.6.2", - "resolved": "https://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-3.6.2.tgz", - "integrity": "sha512-bJlen0FcuU/0EMLrdbJ7zOnW6ITZLrZMIarMUVmdKtsGvZna8vxKYaexICWPfZ8qwf9fzNq+UEIZrnSaApt6RA==", "dev": true }, "whatwg-url": { "version": "5.0.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", - "integrity": "sha1-lmRU6HZUYuN2RNNib2dCzotwll0=", "dev": true, "requires": { "tr46": "~0.0.3", @@ -5852,8 +12981,6 @@ }, "which": { "version": "1.3.1", - "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", - "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", "dev": true, "requires": { "isexe": "^2.0.0" @@ -5861,14 +12988,10 @@ }, "which-module": { "version": "2.0.0", - "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", - "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", "dev": true }, "wrap-ansi": { "version": "6.2.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", - "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", "dev": true, "requires": { "ansi-styles": "^4.0.0", @@ -5878,14 +13001,10 @@ "dependencies": { "ansi-regex": { "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", "dev": true }, "strip-ansi": { "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", "dev": true, "requires": { "ansi-regex": "^5.0.1" @@ -5895,14 +13014,10 @@ }, "wrappy": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", "dev": true }, "write-file-atomic": { "version": "2.4.3", - "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.3.tgz", - "integrity": "sha512-GaETH5wwsX+GcnzhPgKcKjJ6M2Cq3/iZp1WyY/X1CSqrW+jVNM9Y7D8EC2sM4ZG/V8wZlSniJnCKWPmBYAucRQ==", "dev": true, "requires": { "graceful-fs": "^4.1.11", @@ -5912,8 +13027,6 @@ }, "ws": { "version": "6.2.2", - "resolved": "https://registry.npmjs.org/ws/-/ws-6.2.2.tgz", - "integrity": "sha512-zmhltoSR8u1cnDsD43TX59mzoMZsLKqUweyYBAIvTngR3shc0W6aOZylZmq/7hqyVxPdi+5Ud2QInblgyE72fw==", "dev": true, "requires": { "async-limiter": "~1.0.0" @@ -5921,8 +13034,6 @@ }, "xcode": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/xcode/-/xcode-2.1.0.tgz", - "integrity": "sha512-uCrmPITrqTEzhn0TtT57fJaNaw8YJs1aCzs+P/QqxsDbvPZSv7XMPPwXrKvHtD6pLjBM/NaVwraWJm8q83Y4iQ==", "dev": true, "requires": { "simple-plist": "^1.0.0", @@ -5931,14 +13042,10 @@ }, "xmlbuilder": { "version": "9.0.7", - "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-9.0.7.tgz", - "integrity": "sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0=", "dev": true }, "xmldoc": { "version": "1.1.2", - "resolved": "https://registry.npmjs.org/xmldoc/-/xmldoc-1.1.2.tgz", - "integrity": "sha512-ruPC/fyPNck2BD1dpz0AZZyrEwMOrWTO5lDdIXS91rs3wtm4j+T8Rp2o+zoOYkkAxJTZRPOSnOGei1egoRmKMQ==", "dev": true, "requires": { "sax": "^1.2.1" @@ -5946,20 +13053,14 @@ }, "xtend": { "version": "4.0.2", - "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", - "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", "dev": true }, "y18n": { "version": "4.0.3", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", - "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", "dev": true }, "yargs": { "version": "15.4.1", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.4.1.tgz", - "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==", "dev": true, "requires": { "cliui": "^6.0.0", @@ -5977,8 +13078,6 @@ }, "yargs-parser": { "version": "18.1.3", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", - "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", "dev": true, "requires": { "camelcase": "^5.0.0", diff --git a/package.json b/package.json index f28690a0..8b3e108e 100644 --- a/package.json +++ b/package.json @@ -3,9 +3,11 @@ "title": "React Native DJI Mobile", "version": "0.3.17", "description": "A React Native wrapper for DJI's Mobile SDK.", - "main": "index.js", + "main": "index.ts", + "typings": "dist/index", "scripts": { - "dev": "node ./scripts/make.js" + "dev": "node ./scripts/make.js", + "prepare": "tsc" }, "keywords": [ "react-native", @@ -19,17 +21,17 @@ "license": "MIT", "licenseFilename": "LICENSE", "readmeFilename": "README.md", - "dependencies": { - "rxjs": "^6.5.3" - }, "peerDependencies": { "react": "^17.0.2", - "react-native": "^0.66.4" + "react-native": "^0.66.4", + "rxjs": ">=7.0.0" }, "devDependencies": { + "@types/react-native": "^0.69.1", "chokidar": "^3.1.1", "react": "^17.0.2", - "react-native": "^0.66.4" + "react-native": "^0.66.4", + "typescript": "^4.6.2" }, "directories": { "doc": "docs", diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 00000000..b2fad382 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,30 @@ +{ + // Change this to match your project + "include": ["lib/**/*", "index.ts"], + "compilerOptions": { + "experimentalDecorators": true, + "target": "esnext" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017','ES2018' or 'ESNEXT'. */, + "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */, + "lib": [ + "es2019" + ] /* Specify library files to be included in the compilation. */, + "strict": false /* Enable all strict type-checking options. */, + "moduleResolution": "node" /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */, + "allowSyntheticDefaultImports": true /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */, + "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, + + // Tells TypeScript to read JS files, as normally they are ignored as source files + "allowJs": true, + // Generate d.ts files + "declaration": true, + // This compiler run should only output d.ts files + "emitDeclarationOnly": true, + // Types should go into this directory. Removing this would place the .d.ts files next to the .js files + "outDir": "dist", + // go to js file when using IDE functions like "Go to Definition" in VSCode + "declarationMap": true, + "skipLibCheck": false /* Skip type checking of declaration files. */, + "types": ["react-native"] + }, + "exclude": ["node_modules"] +} diff --git a/types/index.ts b/types/index.ts new file mode 100644 index 00000000..c1d121c3 --- /dev/null +++ b/types/index.ts @@ -0,0 +1,271 @@ +export interface DJIEvent { + type: string; + value: any; +} + +export interface HomeLocationCoordinate3D { + latitude?: number; + longitude?: number; + altitude?: number; +} + +export interface LocationCoordinate3D { + latitude: number; + longitude: number; + altitude: number; +} + +export interface LocationCoordinate2D { + latitude: number; + longitude: number; +} + +export interface VelocityVector { + x: number; + y: number; + z: number; +} + +export interface Attitude { + roll: number; + pitch: number; + yaw: number; +} + +export type WaypointMissionV1State = + | 'DISCONNECTED' + | 'RECOVERING' + | 'NOT_SUPPORTED' + | 'READY_TO_UPLOAD' + | 'UPLOADING' + | 'READY_TO_EXECUTE' + | 'EXECUTING' + | 'EXECUTION_PAUSED' + | 'UNKNOWN'; + +export type WaypointMissionV2State = + | 'DISCONNECTED' + | 'RECOVERING' + | 'NOT_SUPPORTED' + | 'READY_TO_UPLOAD' + | 'UPLOADING' + | 'READY_TO_EXECUTE' + | 'EXECUTING' // For V2, this includes the progress states 'GO_HOME' & 'LANDING' + | 'EXECUTION_PAUSED' // This has been merged with V1 on the Native side + | 'UNKNOWN'; + +// TODO (Nick A): should we merge these on the wrapper side and expose a cleaner API? +export type WaypointMissionState = + | WaypointMissionV1State + | WaypointMissionV2State; + +export type WaypointMissionV1ExecuteState = + | 'INITIALIZING' + | 'MOVING' + | 'CURVE_MODE_MOVING' + | 'CURVE_MODE_TURNING' + | 'BEGIN_ACTION' + | 'DOING_ACTION' + | 'FINISHED_ACTION' + | 'RETURN_TO_FIRST_WAYPOINT' + | 'PAUSED' + | 'UNKNOWN'; // this will never be returned by DJI, but is used as the initial value + +export type WaypointMissionV2ExecuteState = + | 'INITIALIZING' + | 'GO_TO_FIRST_WAYPOINT' + | 'MOVING' + | 'PAUSED' + | 'INTERRUPTED' + | 'FINISHED' + | 'GO_HOME' + | 'LANDING' + | 'RETURN_TO_FIRST_WAYPOINT' + | 'UNKNOWN'; + +export type WaypointMissionExecuteState = + | WaypointMissionV1ExecuteState + | WaypointMissionV2ExecuteState; + +export interface WaypointMissionExecutionProgressEvent { + targetWaypointIndex: number; + isWaypointReached: boolean; + executeState: WaypointMissionExecuteState; + totalWaypointCount?: number; // Waypoint Mission V2 doesn't return this out-the-box +} + +export interface WaypointMissionUploadEvent { + uploadedWaypointIndex: number; + totalWaypointCount: number; + isSummaryUploaded: boolean; +} + +export const FlightLogListenerEventNames = Object.freeze({ + create: 'create', + modify: 'modify', +}); + +export interface FlightLogListenerEvent { + value: { + eventName: typeof FlightLogListenerEventNames; + fileName: string; + }; + type: string; +} + +export interface MediaFileData { + fileName: string; + fileSizeInBytes: number; + dateCreated: string; +} + +export interface DJIDiagnostic { + type: string; + reason: string; + solution: string; + error: string; +} + +export type SensorState = + | 'UNKNOWN' + | 'DISCONNECTED' + | 'CALIBRATING' + | 'CALIBRATION_FAILED' + | 'DATA_EXCEPTION' + | 'WARMING_UP' + | 'IN_MOTION' + | 'NORMAL_BIAS' + | 'MEDIUM_BIAS' + | 'LARGE_BIAS'; + +export interface IMUState { + accelerometerState: SensorState; + gyroscopeState: SensorState; +} + +export type WhiteBalancePresets = + | 'AUTO' + | 'SUNNY' + | 'CLOUDY' + | 'WATER_SURFACE' + | 'INDOOR_INCANDESCENT' + | 'INDOOR_FLUORESCENT' + | 'CUSTOM' + | 'PRESET_NEUTRAL' + | 'UNKNOWN'; + +export type CameraExposureSettings = { + aperture?: number; + iso?: number; + shutterSpeed?: number; + exposureValue?: number; +}; + +export type RemoteControllerFlightMode = + | 'F' + | 'A' + | 'P' + | 'S' + | 'G' + | 'M' + | 'T' + | 'UNKNOWN'; + +export type AircraftFlightMode = + | 'MANUAL' + | 'ATTI' + | 'ATTI_COURSE_LOCK' + | 'ATTI_HOVER' + | 'HOVER' + | 'GPS_BLAKE' + | 'GPS_ATTI' + | 'GPS_COURSE_LOCK' + | 'GPS_HOME_LOCK' + | 'GPS_HOT_POINT' + | 'ASSISTED_TAKEOFF' + | 'AUTO_TAKEOFF' + | 'AUTO_LANDING' + | 'ATTI_LANDING' + | 'GPS_WAYPOINT' + | 'GO_HOME' + | 'CLICK_GO' + | 'JOYSTICK' + | 'GPS_ATTI_WRISTBAND' + | 'CINEMATIC' + | 'ATTI_LIMITED' + | 'DRAW' + | 'GPS_FOLLOW_ME' + | 'ACTIVE_TRACK' + | 'TAP_FLY' + | 'PANO' + | 'FARMING' + | 'FPV' + | 'GPS_SPORT' + | 'GPS_NOVICE' + | 'CONFIRM_LANDING' + | 'TERRAIN_FOLLOW' + | 'PALM_CONTROL' + | 'QUICK_SHOT' + | 'TRIPOD' + | 'TRACK_SPOTLIGHT' + | 'MOTORS_JUST_STARTED' + | 'DETOUR' + | 'TIME_LAPSE' + | 'POI2' + | 'OMNI_MOVING' + | 'ADSB_AVOIDING' + | 'SMART_TRACK' + | 'MOTOR_STOP_LANDING' + | 'UNKNOWN'; + +export type ModelName = + | 'INSPIRE_1' + | 'INSPIRE_1_PRO' + | 'INSPIRE_1_RAW' + | 'INSPIRE_2' + | 'MATRICE_100' + | 'PHANTOM_3_ADVANCED' + | 'PHANTOM_3_PROFESSIONAL' + | 'PHANTOM_3_STANDARD' + | 'Phantom_3_4K' + | 'Phantom_3_SE' + | 'PHANTOM_4' + | 'PHANTOM_4_PRO' + | 'PHANTOM_4_ADVANCED' + | 'PHANTOM_4_PRO_V2' + | 'PHANTOM_4_RTK' + | 'P_4_MULTISPECTRAL' + | 'OSMO' + | 'OSMO_MOBILE' + | 'OSMO_MOBILE_2' + | 'OSMO_PRO' + | 'OSMO_RAW' + | 'OSMO_PLUS' + | 'MATRICE_600' + | 'MATRICE_200' + | 'MATRICE_210' + | 'MATRICE_210_RTK' + | 'MATRICE_200_V2' + | 'MATRICE_210_V2' + | 'MATRICE_210_RTK_V2' + | 'MATRICE_300_RTK' + | 'MATRICE_600_PRO' + | 'A3' + | 'N3' + | 'UNKNOWN_AIRCRAFT' + | 'UNKNOWN_HANDHELD' + | 'MAVIC_PRO' + | 'Spark' + | 'MAVIC_AIR' + | 'MAVIC_2_ZOOM' + | 'MAVIC_2_PRO' + | 'MAVIC_2' + | 'MAVIC_2_ENTERPRISE' + | 'MAVIC_2_ENTERPRISE_DUAL' + | 'MAVIC_MINI' + | 'DJI_MINI_2' + | 'DJI_MINI_SE' + | 'MAVIC_AIR_2' + | 'DJI_AIR_2S' + | 'MAVIC_2_ENTERPRISE_ADVANCED' + | 'DISCONNECT';