react-native-mmkv 4.0.0-beta.1 → 4.0.0-beta.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/NitroMmkv.podspec +44 -0
- package/README.md +1 -3
- package/android/CMakeLists.txt +31 -30
- package/android/build.gradle +66 -21
- package/android/fix-prefab.gradle +51 -0
- package/android/gradle.properties +5 -5
- package/android/src/main/cpp/cpp-adapter.cpp +6 -0
- package/android/src/main/java/com/margelo/nitro/mmkv/HybridMMKVPlatformContext.kt +19 -0
- package/android/src/main/java/com/margelo/nitro/mmkv/NitroMmkvPackage.java +33 -0
- package/cpp/HybridMMKV.cpp +184 -0
- package/cpp/HybridMMKV.hpp +47 -0
- package/cpp/HybridMMKVFactory.cpp +33 -0
- package/cpp/HybridMMKVFactory.hpp +24 -0
- package/cpp/{MmkvTypes.h → MMKVTypes.hpp} +1 -1
- package/cpp/MMKVValueChangedListenerRegistry.cpp +58 -0
- package/cpp/MMKVValueChangedListenerRegistry.hpp +43 -0
- package/cpp/{ManagedMMBuffer.h → ManagedMMBuffer.hpp} +13 -5
- package/ios/HybridMMKVPlatformContext.swift +43 -0
- package/lib/__tests__/hooks.test.d.ts +1 -0
- package/lib/__tests__/hooks.test.js +69 -0
- package/lib/addMemoryWarningListener/addMemoryWarningListener.d.ts +2 -0
- package/lib/addMemoryWarningListener/addMemoryWarningListener.js +25 -0
- package/lib/addMemoryWarningListener/addMemoryWarningListener.mock.d.ts +2 -0
- package/lib/addMemoryWarningListener/addMemoryWarningListener.mock.js +3 -0
- package/lib/addMemoryWarningListener/addMemoryWarningListener.web.d.ts +2 -0
- package/lib/addMemoryWarningListener/addMemoryWarningListener.web.js +3 -0
- package/lib/createMMKV/createMMKV.d.ts +3 -0
- package/lib/createMMKV/createMMKV.js +40 -0
- package/lib/createMMKV/createMMKV.web.d.ts +3 -0
- package/lib/createMMKV/createMMKV.web.js +117 -0
- package/lib/createMMKV/createMockMMKV.d.ts +5 -0
- package/lib/createMMKV/createMockMMKV.js +74 -0
- package/lib/createMMKV/getDefaultMMKVInstance.d.ts +2 -0
- package/lib/createMMKV/getDefaultMMKVInstance.js +8 -0
- package/lib/hooks/createMMKVHook.d.ts +2 -0
- package/lib/hooks/createMMKVHook.js +49 -0
- package/lib/hooks/useMMKV.d.ts +11 -0
- package/lib/hooks/useMMKV.js +23 -0
- package/lib/hooks/useMMKVBoolean.d.ts +11 -0
- package/lib/hooks/useMMKVBoolean.js +12 -0
- package/lib/hooks/useMMKVBuffer.d.ts +11 -0
- package/lib/hooks/useMMKVBuffer.js +12 -0
- package/lib/hooks/useMMKVKeys.d.ts +12 -0
- package/lib/hooks/useMMKVKeys.js +33 -0
- package/lib/hooks/useMMKVListener.d.ts +15 -0
- package/lib/hooks/useMMKVListener.js +26 -0
- package/lib/hooks/useMMKVNumber.d.ts +11 -0
- package/lib/hooks/useMMKVNumber.js +12 -0
- package/lib/hooks/useMMKVObject.d.ts +17 -0
- package/lib/hooks/useMMKVObject.js +38 -0
- package/lib/hooks/useMMKVString.d.ts +11 -0
- package/lib/hooks/useMMKVString.js +12 -0
- package/lib/index.d.ts +11 -0
- package/lib/index.js +11 -0
- package/lib/isTest.d.ts +1 -0
- package/lib/isTest.js +7 -0
- package/lib/specs/MMKV.nitro.d.ts +94 -0
- package/lib/specs/MMKV.nitro.js +1 -0
- package/lib/{typescript/src/NativeMmkv.d.ts → specs/MMKVFactory.nitro.d.ts} +26 -33
- package/lib/specs/MMKVFactory.nitro.js +1 -0
- package/lib/specs/MMKVPlatformContext.nitro.d.ts +18 -0
- package/lib/specs/MMKVPlatformContext.nitro.js +1 -0
- package/lib/{typescript/src → web}/createTextEncoder.d.ts +0 -1
- package/lib/web/createTextEncoder.js +17 -0
- package/nitro.json +28 -0
- package/nitrogen/generated/.gitattributes +1 -0
- package/nitrogen/generated/android/NitroMmkv+autolinking.cmake +80 -0
- package/nitrogen/generated/android/NitroMmkv+autolinking.gradle +27 -0
- package/nitrogen/generated/android/NitroMmkvOnLoad.cpp +54 -0
- package/nitrogen/generated/android/NitroMmkvOnLoad.hpp +25 -0
- package/nitrogen/generated/android/c++/JHybridMMKVPlatformContextSpec.cpp +52 -0
- package/nitrogen/generated/android/c++/JHybridMMKVPlatformContextSpec.hpp +65 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/mmkv/HybridMMKVPlatformContextSpec.kt +56 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/mmkv/NitroMmkvOnLoad.kt +35 -0
- package/nitrogen/generated/ios/NitroMmkv+autolinking.rb +60 -0
- package/nitrogen/generated/ios/NitroMmkv-Swift-Cxx-Bridge.cpp +32 -0
- package/nitrogen/generated/ios/NitroMmkv-Swift-Cxx-Bridge.hpp +77 -0
- package/nitrogen/generated/ios/NitroMmkv-Swift-Cxx-Umbrella.hpp +45 -0
- package/nitrogen/generated/ios/NitroMmkvAutolinking.mm +43 -0
- package/nitrogen/generated/ios/NitroMmkvAutolinking.swift +25 -0
- package/nitrogen/generated/ios/c++/HybridMMKVPlatformContextSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridMMKVPlatformContextSpecSwift.hpp +82 -0
- package/nitrogen/generated/ios/swift/HybridMMKVPlatformContextSpec.swift +50 -0
- package/nitrogen/generated/ios/swift/HybridMMKVPlatformContextSpec_cxx.swift +141 -0
- package/nitrogen/generated/shared/c++/Configuration.hpp +86 -0
- package/nitrogen/generated/shared/c++/HybridMMKVFactorySpec.cpp +23 -0
- package/nitrogen/generated/shared/c++/HybridMMKVFactorySpec.hpp +69 -0
- package/nitrogen/generated/shared/c++/HybridMMKVPlatformContextSpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridMMKVPlatformContextSpec.hpp +64 -0
- package/nitrogen/generated/shared/c++/HybridMMKVSpec.cpp +34 -0
- package/nitrogen/generated/shared/c++/HybridMMKVSpec.hpp +83 -0
- package/nitrogen/generated/shared/c++/Listener.hpp +67 -0
- package/nitrogen/generated/shared/c++/Mode.hpp +76 -0
- package/package.json +74 -122
- package/react-native.config.js +2 -15
- package/src/__tests__/hooks.test.tsx +39 -34
- package/src/addMemoryWarningListener/addMemoryWarningListener.mock.ts +5 -0
- package/src/{MemoryWarningListener.ts → addMemoryWarningListener/addMemoryWarningListener.ts} +12 -12
- package/src/addMemoryWarningListener/addMemoryWarningListener.web.ts +5 -0
- package/src/createMMKV/createMMKV.ts +51 -0
- package/src/{createMMKV.web.ts → createMMKV/createMMKV.web.ts} +58 -46
- package/src/createMMKV/createMockMMKV.ts +78 -0
- package/src/createMMKV/getDefaultMMKVInstance.ts +10 -0
- package/src/hooks/createMMKVHook.ts +66 -0
- package/src/hooks/useMMKV.ts +45 -0
- package/src/hooks/useMMKVBoolean.ts +15 -0
- package/src/hooks/useMMKVBuffer.ts +15 -0
- package/src/hooks/useMMKVKeys.ts +36 -0
- package/src/hooks/useMMKVListener.ts +33 -0
- package/src/hooks/useMMKVNumber.ts +15 -0
- package/src/hooks/useMMKVObject.ts +53 -0
- package/src/hooks/useMMKVString.ts +15 -0
- package/src/index.ts +15 -3
- package/src/{PlatformChecker.ts → isTest.ts} +2 -2
- package/src/specs/MMKV.nitro.ts +93 -0
- package/src/specs/MMKVFactory.nitro.ts +87 -0
- package/src/specs/MMKVPlatformContext.nitro.ts +17 -0
- package/src/{createTextEncoder.ts → web/createTextEncoder.ts} +7 -7
- package/android/src/main/cpp/AndroidLogger.cpp +0 -16
- package/android/src/main/java/com/mrousavy/mmkv/MmkvPackage.java +0 -44
- package/android/src/main/java/com/mrousavy/mmkv/MmkvPlatformContextModule.java +0 -26
- package/cpp/MmkvHostObject.cpp +0 -360
- package/cpp/MmkvHostObject.h +0 -31
- package/cpp/MmkvLogger.h +0 -35
- package/cpp/NativeMmkvModule.cpp +0 -43
- package/cpp/NativeMmkvModule.h +0 -31
- package/ios/AppleLogger.mm +0 -16
- package/ios/MmkvOnLoad.mm +0 -25
- package/ios/MmkvPlatformContext.h +0 -19
- package/ios/MmkvPlatformContextModule.mm +0 -55
- package/lib/commonjs/MMKV.js +0 -124
- package/lib/commonjs/MMKV.js.map +0 -1
- package/lib/commonjs/MemoryWarningListener.js +0 -31
- package/lib/commonjs/MemoryWarningListener.js.map +0 -1
- package/lib/commonjs/MemoryWarningListener.web.js +0 -11
- package/lib/commonjs/MemoryWarningListener.web.js.map +0 -1
- package/lib/commonjs/ModuleNotFoundError.js +0 -75
- package/lib/commonjs/ModuleNotFoundError.js.map +0 -1
- package/lib/commonjs/NativeMmkv.js +0 -47
- package/lib/commonjs/NativeMmkv.js.map +0 -1
- package/lib/commonjs/NativeMmkvPlatformContext.js +0 -22
- package/lib/commonjs/NativeMmkvPlatformContext.js.map +0 -1
- package/lib/commonjs/PlatformChecker.js +0 -14
- package/lib/commonjs/PlatformChecker.js.map +0 -1
- package/lib/commonjs/Types.js +0 -26
- package/lib/commonjs/Types.js.map +0 -1
- package/lib/commonjs/createMMKV.js +0 -43
- package/lib/commonjs/createMMKV.js.map +0 -1
- package/lib/commonjs/createMMKV.mock.js +0 -43
- package/lib/commonjs/createMMKV.mock.js.map +0 -1
- package/lib/commonjs/createMMKV.web.js +0 -110
- package/lib/commonjs/createMMKV.web.js.map +0 -1
- package/lib/commonjs/createTextEncoder.js +0 -23
- package/lib/commonjs/createTextEncoder.js.map +0 -1
- package/lib/commonjs/hooks.js +0 -198
- package/lib/commonjs/hooks.js.map +0 -1
- package/lib/commonjs/index.js +0 -40
- package/lib/commonjs/index.js.map +0 -1
- package/lib/commonjs/package.json +0 -1
- package/lib/module/MMKV.js +0 -119
- package/lib/module/MMKV.js.map +0 -1
- package/lib/module/MemoryWarningListener.js +0 -27
- package/lib/module/MemoryWarningListener.js.map +0 -1
- package/lib/module/MemoryWarningListener.web.js +0 -6
- package/lib/module/MemoryWarningListener.web.js.map +0 -1
- package/lib/module/ModuleNotFoundError.js +0 -70
- package/lib/module/ModuleNotFoundError.js.map +0 -1
- package/lib/module/NativeMmkv.js +0 -45
- package/lib/module/NativeMmkv.js.map +0 -1
- package/lib/module/NativeMmkvPlatformContext.js +0 -18
- package/lib/module/NativeMmkvPlatformContext.js.map +0 -1
- package/lib/module/PlatformChecker.js +0 -10
- package/lib/module/PlatformChecker.js.map +0 -1
- package/lib/module/Types.js +0 -25
- package/lib/module/Types.js.map +0 -1
- package/lib/module/createMMKV.js +0 -38
- package/lib/module/createMMKV.js.map +0 -1
- package/lib/module/createMMKV.mock.js +0 -38
- package/lib/module/createMMKV.mock.js.map +0 -1
- package/lib/module/createMMKV.web.js +0 -105
- package/lib/module/createMMKV.web.js.map +0 -1
- package/lib/module/createTextEncoder.js +0 -19
- package/lib/module/createTextEncoder.js.map +0 -1
- package/lib/module/hooks.js +0 -189
- package/lib/module/hooks.js.map +0 -1
- package/lib/module/index.js +0 -6
- package/lib/module/index.js.map +0 -1
- package/lib/module/package.json +0 -1
- package/lib/typescript/src/MMKV.d.ts +0 -34
- package/lib/typescript/src/MMKV.d.ts.map +0 -1
- package/lib/typescript/src/MemoryWarningListener.d.ts +0 -3
- package/lib/typescript/src/MemoryWarningListener.d.ts.map +0 -1
- package/lib/typescript/src/MemoryWarningListener.web.d.ts +0 -3
- package/lib/typescript/src/MemoryWarningListener.web.d.ts.map +0 -1
- package/lib/typescript/src/ModuleNotFoundError.d.ts +0 -7
- package/lib/typescript/src/ModuleNotFoundError.d.ts.map +0 -1
- package/lib/typescript/src/NativeMmkv.d.ts.map +0 -1
- package/lib/typescript/src/NativeMmkvPlatformContext.d.ts +0 -20
- package/lib/typescript/src/NativeMmkvPlatformContext.d.ts.map +0 -1
- package/lib/typescript/src/PlatformChecker.d.ts +0 -2
- package/lib/typescript/src/PlatformChecker.d.ts.map +0 -1
- package/lib/typescript/src/Types.d.ts +0 -172
- package/lib/typescript/src/Types.d.ts.map +0 -1
- package/lib/typescript/src/__tests__/hooks.test.d.ts +0 -2
- package/lib/typescript/src/__tests__/hooks.test.d.ts.map +0 -1
- package/lib/typescript/src/createMMKV.d.ts +0 -3
- package/lib/typescript/src/createMMKV.d.ts.map +0 -1
- package/lib/typescript/src/createMMKV.mock.d.ts +0 -3
- package/lib/typescript/src/createMMKV.mock.d.ts.map +0 -1
- package/lib/typescript/src/createMMKV.web.d.ts +0 -3
- package/lib/typescript/src/createMMKV.web.d.ts.map +0 -1
- package/lib/typescript/src/createTextEncoder.d.ts.map +0 -1
- package/lib/typescript/src/hooks.d.ts +0 -86
- package/lib/typescript/src/hooks.d.ts.map +0 -1
- package/lib/typescript/src/index.d.ts +0 -4
- package/lib/typescript/src/index.d.ts.map +0 -1
- package/react-native-mmkv.podspec +0 -32
- package/src/MMKV.ts +0 -142
- package/src/MemoryWarningListener.web.ts +0 -5
- package/src/ModuleNotFoundError.ts +0 -95
- package/src/NativeMmkv.ts +0 -118
- package/src/NativeMmkvPlatformContext.ts +0 -38
- package/src/Types.ts +0 -178
- package/src/createMMKV.mock.ts +0 -38
- package/src/createMMKV.ts +0 -42
- package/src/hooks.ts +0 -247
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["AppState","addMemoryWarningListener","mmkv","global","WeakRef","FinalizationRegistry","weakMmkv","listener","addEventListener","deref","trim","finalization","l","remove","register"],"sourceRoot":"../../src","sources":["MemoryWarningListener.ts"],"mappings":";;AAAA,SAASA,QAAQ,QAAQ,cAAc;AAIvC,OAAO,SAASC,wBAAwBA,CAACC,IAAmB,EAAQ;EAClE,IAAIC,MAAM,CAACC,OAAO,IAAI,IAAI,IAAID,MAAM,CAACE,oBAAoB,IAAI,IAAI,EAAE;IACjE;IACA,MAAMC,QAAQ,GAAG,IAAIF,OAAO,CAACF,IAAI,CAAC;IAClC,MAAMK,QAAQ,GAAGP,QAAQ,CAACQ,gBAAgB,CAAC,eAAe,EAAE,MAAM;MAChE;MACAF,QAAQ,CAACG,KAAK,CAAC,CAAC,EAAEC,IAAI,CAAC,CAAC;IAC1B,CAAC,CAAC;IACF;IACA,MAAMC,YAAY,GAAG,IAAIN,oBAAoB,CAC1CO,CAA0B,IAAK;MAC9B;MACAA,CAAC,CAACC,MAAM,CAAC,CAAC;IACZ,CACF,CAAC;IACD;IACAF,YAAY,CAACG,QAAQ,CAACZ,IAAI,EAAEK,QAAQ,CAAC;EACvC,CAAC,MAAM;IACL;IACA;IACAP,QAAQ,CAACQ,gBAAgB,CAAC,eAAe,EAAE,MAAM;MAC/CN,IAAI,CAACQ,IAAI,CAAC,CAAC;IACb,CAAC,CAAC;EACJ;AACF","ignoreList":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["addMemoryWarningListener","_mmkv"],"sourceRoot":"../../src","sources":["MemoryWarningListener.web.ts"],"mappings":";;AAEA,OAAO,MAAMA,wBAAwB,GAAIC,KAAoB,IAAW;EACtE;AAAA,CACD","ignoreList":[]}
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
import { NativeModules, Platform } from 'react-native';
|
|
4
|
-
const BULLET_POINT = '\n* ';
|
|
5
|
-
function messageWithSuggestions(message, suggestions) {
|
|
6
|
-
return message + BULLET_POINT + suggestions.join(BULLET_POINT);
|
|
7
|
-
}
|
|
8
|
-
function getFrameworkType() {
|
|
9
|
-
// check if Expo
|
|
10
|
-
const ExpoConstants = NativeModules.NativeUnimoduleProxy?.modulesConstants?.ExponentConstants;
|
|
11
|
-
if (ExpoConstants != null) {
|
|
12
|
-
if (ExpoConstants.appOwnership === 'expo') {
|
|
13
|
-
// We're running Expo Go
|
|
14
|
-
return 'expo-go';
|
|
15
|
-
} else {
|
|
16
|
-
// We're running Expo bare / standalone
|
|
17
|
-
return 'expo';
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
return 'react-native';
|
|
21
|
-
}
|
|
22
|
-
export class ModuleNotFoundError extends Error {
|
|
23
|
-
constructor(cause) {
|
|
24
|
-
// TurboModule not found, something went wrong!
|
|
25
|
-
if (global.__turboModuleProxy == null) {
|
|
26
|
-
// TurboModules are not available/new arch is not enabled.
|
|
27
|
-
// react-native-mmkv 3.x.x requires new arch (react-native >0.74)
|
|
28
|
-
// react-native-mmkv 2.x.x works on old arch (react-native <0.74)
|
|
29
|
-
const message = 'Failed to create a new MMKV instance: react-native-mmkv 3.x.x requires TurboModules, but the new architecture is not enabled!';
|
|
30
|
-
const suggestions = [];
|
|
31
|
-
suggestions.push('Downgrade to react-native-mmkv 2.x.x if you want to stay on the old architecture.');
|
|
32
|
-
suggestions.push('Enable the new architecture in your app to use react-native-mmkv 3.x.x. (See https://github.com/reactwg/react-native-new-architecture/blob/main/docs/enable-apps.md)');
|
|
33
|
-
const error = messageWithSuggestions(message, suggestions);
|
|
34
|
-
super(error, {
|
|
35
|
-
cause: cause
|
|
36
|
-
});
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
const framework = getFrameworkType();
|
|
40
|
-
if (framework === 'expo-go') {
|
|
41
|
-
super('react-native-mmkv is not supported in Expo Go! Use EAS (`expo prebuild`) or eject to a bare workflow instead.');
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
const message = 'Failed to create a new MMKV instance: The native MMKV Module could not be found.';
|
|
45
|
-
const suggestions = [];
|
|
46
|
-
suggestions.push('Make sure react-native-mmkv is correctly autolinked (run `npx react-native config` to verify)');
|
|
47
|
-
suggestions.push('Make sure you enabled the new architecture (TurboModules) and CodeGen properly generated the react-native-mmkv specs. See https://github.com/reactwg/react-native-new-architecture/blob/main/docs/enable-apps.md');
|
|
48
|
-
suggestions.push('Make sure you are using react-native 0.74.0 or higher, because react-native-mmkv is a C++ TurboModule.');
|
|
49
|
-
suggestions.push('Make sure you rebuilt the app.');
|
|
50
|
-
if (framework === 'expo') {
|
|
51
|
-
suggestions.push('Make sure you ran `expo prebuild`.');
|
|
52
|
-
}
|
|
53
|
-
switch (Platform.OS) {
|
|
54
|
-
case 'ios':
|
|
55
|
-
case 'macos':
|
|
56
|
-
suggestions.push('Make sure you ran `pod install` in the ios/ directory.');
|
|
57
|
-
break;
|
|
58
|
-
case 'android':
|
|
59
|
-
suggestions.push('Make sure gradle is synced.');
|
|
60
|
-
break;
|
|
61
|
-
default:
|
|
62
|
-
throw new Error(`MMKV is not supported on ${Platform.OS}!`);
|
|
63
|
-
}
|
|
64
|
-
const error = messageWithSuggestions(message, suggestions);
|
|
65
|
-
super(error, {
|
|
66
|
-
cause: cause
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
//# sourceMappingURL=ModuleNotFoundError.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["NativeModules","Platform","BULLET_POINT","messageWithSuggestions","message","suggestions","join","getFrameworkType","ExpoConstants","NativeUnimoduleProxy","modulesConstants","ExponentConstants","appOwnership","ModuleNotFoundError","Error","constructor","cause","global","__turboModuleProxy","push","error","framework","OS"],"sourceRoot":"../../src","sources":["ModuleNotFoundError.ts"],"mappings":";;AAAA,SAASA,aAAa,EAAEC,QAAQ,QAAQ,cAAc;AAOtD,MAAMC,YAAY,GAAG,MAAM;AAE3B,SAASC,sBAAsBA,CAC7BC,OAAe,EACfC,WAAqB,EACb;EACR,OAAOD,OAAO,GAAGF,YAAY,GAAGG,WAAW,CAACC,IAAI,CAACJ,YAAY,CAAC;AAChE;AAEA,SAASK,gBAAgBA,CAAA,EAAwC;EAC/D;EACA,MAAMC,aAAa,GACjBR,aAAa,CAACS,oBAAoB,EAAEC,gBAAgB,EAAEC,iBAAiB;EACzE,IAAIH,aAAa,IAAI,IAAI,EAAE;IACzB,IAAIA,aAAa,CAACI,YAAY,KAAK,MAAM,EAAE;MACzC;MACA,OAAO,SAAS;IAClB,CAAC,MAAM;MACL;MACA,OAAO,MAAM;IACf;EACF;EACA,OAAO,cAAc;AACvB;AAEA,OAAO,MAAMC,mBAAmB,SAASC,KAAK,CAAC;EAC7CC,WAAWA,CAACC,KAAe,EAAE;IAC3B;IACA,IAAIC,MAAM,CAACC,kBAAkB,IAAI,IAAI,EAAE;MACrC;MACA;MACA;MACA,MAAMd,OAAO,GACX,+HAA+H;MACjI,MAAMC,WAAqB,GAAG,EAAE;MAChCA,WAAW,CAACc,IAAI,CACd,mFACF,CAAC;MACDd,WAAW,CAACc,IAAI,CACd,sKACF,CAAC;MACD,MAAMC,KAAK,GAAGjB,sBAAsB,CAACC,OAAO,EAAEC,WAAW,CAAC;MAC1D,KAAK,CAACe,KAAK,EAAE;QAAEJ,KAAK,EAAEA;MAAM,CAAC,CAAC;MAC9B;IACF;IAEA,MAAMK,SAAS,GAAGd,gBAAgB,CAAC,CAAC;IACpC,IAAIc,SAAS,KAAK,SAAS,EAAE;MAC3B,KAAK,CACH,+GACF,CAAC;MACD;IACF;IAEA,MAAMjB,OAAO,GACX,kFAAkF;IACpF,MAAMC,WAAqB,GAAG,EAAE;IAChCA,WAAW,CAACc,IAAI,CACd,+FACF,CAAC;IACDd,WAAW,CAACc,IAAI,CACd,kNACF,CAAC;IACDd,WAAW,CAACc,IAAI,CACd,wGACF,CAAC;IACDd,WAAW,CAACc,IAAI,CAAC,gCAAgC,CAAC;IAClD,IAAIE,SAAS,KAAK,MAAM,EAAE;MACxBhB,WAAW,CAACc,IAAI,CAAC,oCAAoC,CAAC;IACxD;IACA,QAAQlB,QAAQ,CAACqB,EAAE;MACjB,KAAK,KAAK;MACV,KAAK,OAAO;QACVjB,WAAW,CAACc,IAAI,CACd,wDACF,CAAC;QACD;MACF,KAAK,SAAS;QACZd,WAAW,CAACc,IAAI,CAAC,6BAA6B,CAAC;QAC/C;MACF;QACE,MAAM,IAAIL,KAAK,CAAC,4BAA4Bb,QAAQ,CAACqB,EAAE,GAAG,CAAC;IAC/D;IAEA,MAAMF,KAAK,GAAGjB,sBAAsB,CAACC,OAAO,EAAEC,WAAW,CAAC;IAC1D,KAAK,CAACe,KAAK,EAAE;MAAEJ,KAAK,EAAEA;IAAM,CAAC,CAAC;EAChC;AACF","ignoreList":[]}
|
package/lib/module/NativeMmkv.js
DELETED
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
import { TurboModuleRegistry } from 'react-native';
|
|
4
|
-
import { ModuleNotFoundError } from './ModuleNotFoundError';
|
|
5
|
-
import { getMMKVPlatformContextTurboModule } from './NativeMmkvPlatformContext';
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* IMPORTANT: These types are also in the Types.ts file.
|
|
9
|
-
* Due to how react-native-codegen works these are required here as the spec types can not be separated from spec.
|
|
10
|
-
* We also need the types separate to allow bypassing importing turbo module registry in web
|
|
11
|
-
*/
|
|
12
|
-
/**
|
|
13
|
-
* Configures the mode of the MMKV instance.
|
|
14
|
-
*/
|
|
15
|
-
export let Mode = /*#__PURE__*/function (Mode) {
|
|
16
|
-
Mode[Mode["SINGLE_PROCESS"] = 0] = "SINGLE_PROCESS";
|
|
17
|
-
Mode[Mode["MULTI_PROCESS"] = 1] = "MULTI_PROCESS";
|
|
18
|
-
return Mode;
|
|
19
|
-
}({});
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Used for configuration of a single MMKV instance.
|
|
23
|
-
*/
|
|
24
|
-
|
|
25
|
-
let mmkvModule;
|
|
26
|
-
export function getMMKVTurboModule() {
|
|
27
|
-
try {
|
|
28
|
-
if (mmkvModule == null) {
|
|
29
|
-
// 1. Load MMKV TurboModule
|
|
30
|
-
mmkvModule = TurboModuleRegistry.getEnforcing('MmkvCxx');
|
|
31
|
-
|
|
32
|
-
// 2. Get the PlatformContext TurboModule as well
|
|
33
|
-
const platformContext = getMMKVPlatformContextTurboModule();
|
|
34
|
-
|
|
35
|
-
// 3. Initialize it with the documents directory from platform-specific context
|
|
36
|
-
const basePath = platformContext.getBaseDirectory();
|
|
37
|
-
mmkvModule.initialize(basePath);
|
|
38
|
-
}
|
|
39
|
-
return mmkvModule;
|
|
40
|
-
} catch (cause) {
|
|
41
|
-
// TurboModule could not be found!
|
|
42
|
-
throw new ModuleNotFoundError(cause);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
//# sourceMappingURL=NativeMmkv.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["TurboModuleRegistry","ModuleNotFoundError","getMMKVPlatformContextTurboModule","Mode","mmkvModule","getMMKVTurboModule","getEnforcing","platformContext","basePath","getBaseDirectory","initialize","cause"],"sourceRoot":"../../src","sources":["NativeMmkv.ts"],"mappings":";;AACA,SAASA,mBAAmB,QAAQ,cAAc;AAElD,SAASC,mBAAmB,QAAQ,uBAAuB;AAC3D,SAASC,iCAAiC,QAAQ,6BAA6B;;AAE/E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAYC,IAAI,0BAAJA,IAAI;EAAJA,IAAI,CAAJA,IAAI;EAAJA,IAAI,CAAJA,IAAI;EAAA,OAAJA,IAAI;AAAA;;AAWhB;AACA;AACA;;AAqEA,IAAIC,UAAuB;AAE3B,OAAO,SAASC,kBAAkBA,CAAA,EAAS;EACzC,IAAI;IACF,IAAID,UAAU,IAAI,IAAI,EAAE;MACtB;MACAA,UAAU,GAAGJ,mBAAmB,CAACM,YAAY,CAAO,SAAS,CAAC;;MAE9D;MACA,MAAMC,eAAe,GAAGL,iCAAiC,CAAC,CAAC;;MAE3D;MACA,MAAMM,QAAQ,GAAGD,eAAe,CAACE,gBAAgB,CAAC,CAAC;MACnDL,UAAU,CAACM,UAAU,CAACF,QAAQ,CAAC;IACjC;IAEA,OAAOJ,UAAU;EACnB,CAAC,CAAC,OAAOO,KAAK,EAAE;IACd;IACA,MAAM,IAAIV,mBAAmB,CAACU,KAAK,CAAC;EACtC;AACF","ignoreList":[]}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
import { TurboModuleRegistry } from 'react-native';
|
|
4
|
-
import { ModuleNotFoundError } from './ModuleNotFoundError';
|
|
5
|
-
let mmkvPlatformModule;
|
|
6
|
-
export function getMMKVPlatformContextTurboModule() {
|
|
7
|
-
try {
|
|
8
|
-
if (mmkvPlatformModule == null) {
|
|
9
|
-
// 1. Get the TurboModule
|
|
10
|
-
mmkvPlatformModule = TurboModuleRegistry.getEnforcing('MmkvPlatformContext');
|
|
11
|
-
}
|
|
12
|
-
return mmkvPlatformModule;
|
|
13
|
-
} catch (e) {
|
|
14
|
-
// TurboModule could not be found!
|
|
15
|
-
throw new ModuleNotFoundError(e);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
//# sourceMappingURL=NativeMmkvPlatformContext.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["TurboModuleRegistry","ModuleNotFoundError","mmkvPlatformModule","getMMKVPlatformContextTurboModule","getEnforcing","e"],"sourceRoot":"../../src","sources":["NativeMmkvPlatformContext.ts"],"mappings":";;AACA,SAASA,mBAAmB,QAAQ,cAAc;AAClD,SAASC,mBAAmB,QAAQ,uBAAuB;AAoB3D,IAAIC,kBAA+B;AAEnC,OAAO,SAASC,iCAAiCA,CAAA,EAAS;EACxD,IAAI;IACF,IAAID,kBAAkB,IAAI,IAAI,EAAE;MAC9B;MACAA,kBAAkB,GAAGF,mBAAmB,CAACI,YAAY,CACnD,qBACF,CAAC;IACH;IACA,OAAOF,kBAAkB;EAC3B,CAAC,CAAC,OAAOG,CAAC,EAAE;IACV;IACA,MAAM,IAAIJ,mBAAmB,CAACI,CAAC,CAAC;EAClC;AACF","ignoreList":[]}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
export function isTest() {
|
|
4
|
-
if (global.process == null) {
|
|
5
|
-
// In a WebBrowser/Electron the `process` variable does not exist
|
|
6
|
-
return false;
|
|
7
|
-
}
|
|
8
|
-
return process.env.JEST_WORKER_ID != null || process.env.VITEST_WORKER_ID != null;
|
|
9
|
-
}
|
|
10
|
-
//# sourceMappingURL=PlatformChecker.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["isTest","global","process","env","JEST_WORKER_ID","VITEST_WORKER_ID"],"sourceRoot":"../../src","sources":["PlatformChecker.ts"],"mappings":";;AAAA,OAAO,SAASA,MAAMA,CAAA,EAAY;EAChC,IAAIC,MAAM,CAACC,OAAO,IAAI,IAAI,EAAE;IAC1B;IACA,OAAO,KAAK;EACd;EACA,OACEA,OAAO,CAACC,GAAG,CAACC,cAAc,IAAI,IAAI,IAAIF,OAAO,CAACC,GAAG,CAACE,gBAAgB,IAAI,IAAI;AAE9E","ignoreList":[]}
|
package/lib/module/Types.js
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* IMPORTANT: Some of these types are also in the NativeMmkv.ts file.
|
|
5
|
-
* Due to how react-native-codegen works these are required here as the spec types can not be separated from spec.
|
|
6
|
-
* We also need the types separate to allow bypassing importing turbo module registry in web
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Configures the mode of the MMKV instance.
|
|
11
|
-
*/
|
|
12
|
-
export let Mode = /*#__PURE__*/function (Mode) {
|
|
13
|
-
Mode[Mode["SINGLE_PROCESS"] = 0] = "SINGLE_PROCESS";
|
|
14
|
-
Mode[Mode["MULTI_PROCESS"] = 1] = "MULTI_PROCESS";
|
|
15
|
-
return Mode;
|
|
16
|
-
}({});
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* Used for configuration of a single MMKV instance.
|
|
20
|
-
*/
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* Represents a single MMKV instance.
|
|
24
|
-
*/
|
|
25
|
-
//# sourceMappingURL=Types.js.map
|
package/lib/module/Types.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["Mode"],"sourceRoot":"../../src","sources":["Types.ts"],"mappings":";;AAAA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAYA,IAAI,0BAAJA,IAAI;EAAJA,IAAI,CAAJA,IAAI;EAAJA,IAAI,CAAJA,IAAI;EAAA,OAAJA,IAAI;AAAA;;AAWhB;AACA;AACA;;AA0DA;AACA;AACA","ignoreList":[]}
|
package/lib/module/createMMKV.js
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
import { Platform } from 'react-native';
|
|
4
|
-
import { getMMKVTurboModule } from './NativeMmkv';
|
|
5
|
-
import { Mode } from './Types';
|
|
6
|
-
import { getMMKVPlatformContextTurboModule } from './NativeMmkvPlatformContext';
|
|
7
|
-
export const createMMKV = config => {
|
|
8
|
-
const module = getMMKVTurboModule();
|
|
9
|
-
if (Platform.OS === 'ios') {
|
|
10
|
-
if (config.path == null) {
|
|
11
|
-
try {
|
|
12
|
-
// If no `path` was supplied, we check if an `AppGroup` was set in Info.plist
|
|
13
|
-
const appGroupDirectory = getMMKVPlatformContextTurboModule().getAppGroupDirectory();
|
|
14
|
-
if (appGroupDirectory != null) {
|
|
15
|
-
// If we have an `AppGroup` in Info.plist, use that as a path.
|
|
16
|
-
config.path = appGroupDirectory;
|
|
17
|
-
}
|
|
18
|
-
} catch (e) {
|
|
19
|
-
// We cannot throw errors here because it is a sync C++ TurboModule func. idk why.
|
|
20
|
-
console.error(e);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
if (typeof config.mode === 'number') {
|
|
25
|
-
// Code-gen expects enums to be strings. In TS, they might be numbers tho.
|
|
26
|
-
// This sucks, so we need a workaround.
|
|
27
|
-
// @ts-expect-error the native side actually expects a string.
|
|
28
|
-
config.mode = Mode[config.mode];
|
|
29
|
-
}
|
|
30
|
-
const instance = module.createMMKV(config);
|
|
31
|
-
if (__DEV__) {
|
|
32
|
-
if (typeof instance !== 'object' || instance == null) {
|
|
33
|
-
throw new Error('Failed to create MMKV instance - an unknown object was returned by createMMKV(..)!');
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
return instance;
|
|
37
|
-
};
|
|
38
|
-
//# sourceMappingURL=createMMKV.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["Platform","getMMKVTurboModule","Mode","getMMKVPlatformContextTurboModule","createMMKV","config","module","OS","path","appGroupDirectory","getAppGroupDirectory","e","console","error","mode","instance","__DEV__","Error"],"sourceRoot":"../../src","sources":["createMMKV.ts"],"mappings":";;AAAA,SAASA,QAAQ,QAAQ,cAAc;AACvC,SAASC,kBAAkB,QAAQ,cAAc;AACjD,SAA6BC,IAAI,QAAyB,SAAS;AACnE,SAASC,iCAAiC,QAAQ,6BAA6B;AAE/E,OAAO,MAAMC,UAAU,GAAIC,MAAqB,IAAiB;EAC/D,MAAMC,MAAM,GAAGL,kBAAkB,CAAC,CAAC;EAEnC,IAAID,QAAQ,CAACO,EAAE,KAAK,KAAK,EAAE;IACzB,IAAIF,MAAM,CAACG,IAAI,IAAI,IAAI,EAAE;MACvB,IAAI;QACF;QACA,MAAMC,iBAAiB,GACrBN,iCAAiC,CAAC,CAAC,CAACO,oBAAoB,CAAC,CAAC;QAC5D,IAAID,iBAAiB,IAAI,IAAI,EAAE;UAC7B;UACAJ,MAAM,CAACG,IAAI,GAAGC,iBAAiB;QACjC;MACF,CAAC,CAAC,OAAOE,CAAC,EAAE;QACV;QACAC,OAAO,CAACC,KAAK,CAACF,CAAC,CAAC;MAClB;IACF;EACF;EAEA,IAAI,OAAON,MAAM,CAACS,IAAI,KAAK,QAAQ,EAAE;IACnC;IACA;IACA;IACAT,MAAM,CAACS,IAAI,GAAGZ,IAAI,CAACG,MAAM,CAACS,IAAI,CAAC;EACjC;EAEA,MAAMC,QAAQ,GAAGT,MAAM,CAACF,UAAU,CAACC,MAAM,CAAC;EAC1C,IAAIW,OAAO,EAAE;IACX,IAAI,OAAOD,QAAQ,KAAK,QAAQ,IAAIA,QAAQ,IAAI,IAAI,EAAE;MACpD,MAAM,IAAIE,KAAK,CACb,oFACF,CAAC;IACH;EACF;EACA,OAAOF,QAAQ;AACjB,CAAC","ignoreList":[]}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
/* Mock MMKV instance for use in tests */
|
|
4
|
-
export const createMockMMKV = () => {
|
|
5
|
-
const storage = new Map();
|
|
6
|
-
return {
|
|
7
|
-
clearAll: () => storage.clear(),
|
|
8
|
-
delete: key => storage.delete(key),
|
|
9
|
-
set: (key, value) => storage.set(key, value),
|
|
10
|
-
getString: key => {
|
|
11
|
-
const result = storage.get(key);
|
|
12
|
-
return typeof result === 'string' ? result : undefined;
|
|
13
|
-
},
|
|
14
|
-
getNumber: key => {
|
|
15
|
-
const result = storage.get(key);
|
|
16
|
-
return typeof result === 'number' ? result : undefined;
|
|
17
|
-
},
|
|
18
|
-
getBoolean: key => {
|
|
19
|
-
const result = storage.get(key);
|
|
20
|
-
return typeof result === 'boolean' ? result : undefined;
|
|
21
|
-
},
|
|
22
|
-
getBuffer: key => {
|
|
23
|
-
const result = storage.get(key);
|
|
24
|
-
return result instanceof ArrayBuffer ? result : undefined;
|
|
25
|
-
},
|
|
26
|
-
getAllKeys: () => Array.from(storage.keys()),
|
|
27
|
-
contains: key => storage.has(key),
|
|
28
|
-
recrypt: () => {
|
|
29
|
-
console.warn('Encryption is not supported in mocked MMKV instances!');
|
|
30
|
-
},
|
|
31
|
-
size: 0,
|
|
32
|
-
isReadOnly: false,
|
|
33
|
-
trim: () => {
|
|
34
|
-
// no-op
|
|
35
|
-
}
|
|
36
|
-
};
|
|
37
|
-
};
|
|
38
|
-
//# sourceMappingURL=createMMKV.mock.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["createMockMMKV","storage","Map","clearAll","clear","delete","key","set","value","getString","result","get","undefined","getNumber","getBoolean","getBuffer","ArrayBuffer","getAllKeys","Array","from","keys","contains","has","recrypt","console","warn","size","isReadOnly","trim"],"sourceRoot":"../../src","sources":["createMMKV.mock.ts"],"mappings":";;AAEA;AACA,OAAO,MAAMA,cAAc,GAAGA,CAAA,KAAkB;EAC9C,MAAMC,OAAO,GAAG,IAAIC,GAAG,CAAkD,CAAC;EAE1E,OAAO;IACLC,QAAQ,EAAEA,CAAA,KAAMF,OAAO,CAACG,KAAK,CAAC,CAAC;IAC/BC,MAAM,EAAGC,GAAG,IAAKL,OAAO,CAACI,MAAM,CAACC,GAAG,CAAC;IACpCC,GAAG,EAAEA,CAACD,GAAG,EAAEE,KAAK,KAAKP,OAAO,CAACM,GAAG,CAACD,GAAG,EAAEE,KAAK,CAAC;IAC5CC,SAAS,EAAGH,GAAG,IAAK;MAClB,MAAMI,MAAM,GAAGT,OAAO,CAACU,GAAG,CAACL,GAAG,CAAC;MAC/B,OAAO,OAAOI,MAAM,KAAK,QAAQ,GAAGA,MAAM,GAAGE,SAAS;IACxD,CAAC;IACDC,SAAS,EAAGP,GAAG,IAAK;MAClB,MAAMI,MAAM,GAAGT,OAAO,CAACU,GAAG,CAACL,GAAG,CAAC;MAC/B,OAAO,OAAOI,MAAM,KAAK,QAAQ,GAAGA,MAAM,GAAGE,SAAS;IACxD,CAAC;IACDE,UAAU,EAAGR,GAAG,IAAK;MACnB,MAAMI,MAAM,GAAGT,OAAO,CAACU,GAAG,CAACL,GAAG,CAAC;MAC/B,OAAO,OAAOI,MAAM,KAAK,SAAS,GAAGA,MAAM,GAAGE,SAAS;IACzD,CAAC;IACDG,SAAS,EAAGT,GAAG,IAAK;MAClB,MAAMI,MAAM,GAAGT,OAAO,CAACU,GAAG,CAACL,GAAG,CAAC;MAC/B,OAAOI,MAAM,YAAYM,WAAW,GAAGN,MAAM,GAAGE,SAAS;IAC3D,CAAC;IACDK,UAAU,EAAEA,CAAA,KAAMC,KAAK,CAACC,IAAI,CAAClB,OAAO,CAACmB,IAAI,CAAC,CAAC,CAAC;IAC5CC,QAAQ,EAAGf,GAAG,IAAKL,OAAO,CAACqB,GAAG,CAAChB,GAAG,CAAC;IACnCiB,OAAO,EAAEA,CAAA,KAAM;MACbC,OAAO,CAACC,IAAI,CAAC,uDAAuD,CAAC;IACvE,CAAC;IACDC,IAAI,EAAE,CAAC;IACPC,UAAU,EAAE,KAAK;IACjBC,IAAI,EAAEA,CAAA,KAAM;MACV;IAAA;EAEJ,CAAC;AACH,CAAC","ignoreList":[]}
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
/* global localStorage */
|
|
4
|
-
|
|
5
|
-
import { createTextEncoder } from './createTextEncoder';
|
|
6
|
-
const canUseDOM = typeof window !== 'undefined' && window.document?.createElement != null;
|
|
7
|
-
const hasAccessToLocalStorage = () => {
|
|
8
|
-
try {
|
|
9
|
-
// throws ACCESS_DENIED error
|
|
10
|
-
window.localStorage;
|
|
11
|
-
return true;
|
|
12
|
-
} catch {
|
|
13
|
-
return false;
|
|
14
|
-
}
|
|
15
|
-
};
|
|
16
|
-
const KEY_WILDCARD = '\\';
|
|
17
|
-
const inMemoryStorage = new Map();
|
|
18
|
-
export const createMMKV = config => {
|
|
19
|
-
if (config.encryptionKey != null) {
|
|
20
|
-
throw new Error("MMKV: 'encryptionKey' is not supported on Web!");
|
|
21
|
-
}
|
|
22
|
-
if (config.path != null) {
|
|
23
|
-
throw new Error("MMKV: 'path' is not supported on Web!");
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
// canUseDOM check prevents spam in Node server environments, such as Next.js server side props.
|
|
27
|
-
if (!hasAccessToLocalStorage() && canUseDOM) {
|
|
28
|
-
console.warn('MMKV: LocalStorage has been disabled. Your experience will be limited to in-memory storage!');
|
|
29
|
-
}
|
|
30
|
-
const storage = () => {
|
|
31
|
-
if (!canUseDOM) {
|
|
32
|
-
throw new Error('Tried to access storage on the server. Did you forget to call this in useEffect?');
|
|
33
|
-
}
|
|
34
|
-
if (!hasAccessToLocalStorage()) {
|
|
35
|
-
return {
|
|
36
|
-
getItem: key => inMemoryStorage.get(key) ?? null,
|
|
37
|
-
setItem: (key, value) => inMemoryStorage.set(key, value),
|
|
38
|
-
removeItem: key => inMemoryStorage.delete(key),
|
|
39
|
-
clear: () => inMemoryStorage.clear(),
|
|
40
|
-
length: inMemoryStorage.size,
|
|
41
|
-
key: index => Object.keys(inMemoryStorage).at(index) ?? null
|
|
42
|
-
};
|
|
43
|
-
}
|
|
44
|
-
const domStorage = global?.localStorage ?? window?.localStorage ?? localStorage;
|
|
45
|
-
if (domStorage == null) {
|
|
46
|
-
throw new Error(`Could not find 'localStorage' instance!`);
|
|
47
|
-
}
|
|
48
|
-
return domStorage;
|
|
49
|
-
};
|
|
50
|
-
const textEncoder = createTextEncoder();
|
|
51
|
-
if (config.id.includes(KEY_WILDCARD)) {
|
|
52
|
-
throw new Error('MMKV: `id` cannot contain the backslash character (`\\`)!');
|
|
53
|
-
}
|
|
54
|
-
const keyPrefix = `${config.id}${KEY_WILDCARD}`; // mmkv.default\\
|
|
55
|
-
const prefixedKey = key => {
|
|
56
|
-
if (key.includes('\\')) {
|
|
57
|
-
throw new Error('MMKV: `key` cannot contain the backslash character (`\\`)!');
|
|
58
|
-
}
|
|
59
|
-
return `${keyPrefix}${key}`;
|
|
60
|
-
};
|
|
61
|
-
return {
|
|
62
|
-
clearAll: () => {
|
|
63
|
-
const keys = Object.keys(storage());
|
|
64
|
-
for (const key of keys) {
|
|
65
|
-
if (key.startsWith(keyPrefix)) {
|
|
66
|
-
storage().removeItem(key);
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
},
|
|
70
|
-
delete: key => storage().removeItem(prefixedKey(key)),
|
|
71
|
-
set: (key, value) => {
|
|
72
|
-
storage().setItem(prefixedKey(key), value.toString());
|
|
73
|
-
},
|
|
74
|
-
getString: key => storage().getItem(prefixedKey(key)) ?? undefined,
|
|
75
|
-
getNumber: key => {
|
|
76
|
-
const value = storage().getItem(prefixedKey(key));
|
|
77
|
-
if (value == null) return undefined;
|
|
78
|
-
return Number(value);
|
|
79
|
-
},
|
|
80
|
-
getBoolean: key => {
|
|
81
|
-
const value = storage().getItem(prefixedKey(key));
|
|
82
|
-
if (value == null) return undefined;
|
|
83
|
-
return value === 'true';
|
|
84
|
-
},
|
|
85
|
-
getBuffer: key => {
|
|
86
|
-
const value = storage().getItem(prefixedKey(key));
|
|
87
|
-
if (value == null) return undefined;
|
|
88
|
-
return textEncoder.encode(value).buffer;
|
|
89
|
-
},
|
|
90
|
-
getAllKeys: () => {
|
|
91
|
-
const keys = Object.keys(storage());
|
|
92
|
-
return keys.filter(key => key.startsWith(keyPrefix)).map(key => key.slice(keyPrefix.length));
|
|
93
|
-
},
|
|
94
|
-
contains: key => storage().getItem(prefixedKey(key)) != null,
|
|
95
|
-
recrypt: () => {
|
|
96
|
-
throw new Error('`recrypt(..)` is not supported on Web!');
|
|
97
|
-
},
|
|
98
|
-
size: 0,
|
|
99
|
-
isReadOnly: false,
|
|
100
|
-
trim: () => {
|
|
101
|
-
// no-op
|
|
102
|
-
}
|
|
103
|
-
};
|
|
104
|
-
};
|
|
105
|
-
//# sourceMappingURL=createMMKV.web.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["createTextEncoder","canUseDOM","window","document","createElement","hasAccessToLocalStorage","localStorage","KEY_WILDCARD","inMemoryStorage","Map","createMMKV","config","encryptionKey","Error","path","console","warn","storage","getItem","key","get","setItem","value","set","removeItem","delete","clear","length","size","index","Object","keys","at","domStorage","global","textEncoder","id","includes","keyPrefix","prefixedKey","clearAll","startsWith","toString","getString","undefined","getNumber","Number","getBoolean","getBuffer","encode","buffer","getAllKeys","filter","map","slice","contains","recrypt","isReadOnly","trim"],"sourceRoot":"../../src","sources":["createMMKV.web.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
/* global TextEncoder */
|
|
4
|
-
export function createTextEncoder() {
|
|
5
|
-
if (global.TextEncoder != null) {
|
|
6
|
-
return new global.TextEncoder();
|
|
7
|
-
} else {
|
|
8
|
-
return {
|
|
9
|
-
encode: () => {
|
|
10
|
-
throw new Error('TextEncoder is not supported in this environment!');
|
|
11
|
-
},
|
|
12
|
-
encodeInto: () => {
|
|
13
|
-
throw new Error('TextEncoder is not supported in this environment!');
|
|
14
|
-
},
|
|
15
|
-
encoding: 'utf-8'
|
|
16
|
-
};
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=createTextEncoder.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["createTextEncoder","global","TextEncoder","encode","Error","encodeInto","encoding"],"sourceRoot":"../../src","sources":["createTextEncoder.ts"],"mappings":";;AAAA;AACA,OAAO,SAASA,iBAAiBA,CAAA,EAAgB;EAC/C,IAAIC,MAAM,CAACC,WAAW,IAAI,IAAI,EAAE;IAC9B,OAAO,IAAID,MAAM,CAACC,WAAW,CAAC,CAAC;EACjC,CAAC,MAAM;IACL,OAAO;MACLC,MAAM,EAAEA,CAAA,KAAM;QACZ,MAAM,IAAIC,KAAK,CAAC,mDAAmD,CAAC;MACtE,CAAC;MACDC,UAAU,EAAEA,CAAA,KAAM;QAChB,MAAM,IAAID,KAAK,CAAC,mDAAmD,CAAC;MACtE,CAAC;MACDE,QAAQ,EAAE;IACZ,CAAC;EACH;AACF","ignoreList":[]}
|
package/lib/module/hooks.js
DELETED
|
@@ -1,189 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
import { useRef, useState, useMemo, useCallback, useEffect } from 'react';
|
|
4
|
-
import { MMKV } from './MMKV';
|
|
5
|
-
function isConfigurationEqual(left, right) {
|
|
6
|
-
if (left == null || right == null) return left == null && right == null;
|
|
7
|
-
return left.encryptionKey === right.encryptionKey && left.id === right.id && left.path === right.path && left.mode === right.mode;
|
|
8
|
-
}
|
|
9
|
-
let defaultInstance = null;
|
|
10
|
-
function getDefaultInstance() {
|
|
11
|
-
if (defaultInstance == null) {
|
|
12
|
-
defaultInstance = new MMKV();
|
|
13
|
-
}
|
|
14
|
-
return defaultInstance;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Use the default, shared MMKV instance.
|
|
19
|
-
*/
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Use a custom MMKV instance with the given configuration.
|
|
23
|
-
* @param configuration The configuration to initialize the MMKV instance with. Does not have to be memoized.
|
|
24
|
-
*/
|
|
25
|
-
|
|
26
|
-
export function useMMKV(configuration) {
|
|
27
|
-
const instance = useRef(undefined);
|
|
28
|
-
const lastConfiguration = useRef(undefined);
|
|
29
|
-
if (configuration == null) return getDefaultInstance();
|
|
30
|
-
if (instance.current == null || !isConfigurationEqual(lastConfiguration.current, configuration)) {
|
|
31
|
-
lastConfiguration.current = configuration;
|
|
32
|
-
instance.current = new MMKV(configuration);
|
|
33
|
-
}
|
|
34
|
-
return instance.current;
|
|
35
|
-
}
|
|
36
|
-
function createMMKVHook(getter) {
|
|
37
|
-
return (key, instance) => {
|
|
38
|
-
const mmkv = instance ?? getDefaultInstance();
|
|
39
|
-
const [bump, setBump] = useState(0);
|
|
40
|
-
const value = useMemo(() => {
|
|
41
|
-
// bump is here as an additional outside dependency, so this useMemo
|
|
42
|
-
// re-computes the value each time bump changes, effectively acting as a hint
|
|
43
|
-
// that the outside value (storage) has changed. setting bump refreshes this value.
|
|
44
|
-
bump;
|
|
45
|
-
return getter(mmkv, key);
|
|
46
|
-
}, [mmkv, key, bump]);
|
|
47
|
-
|
|
48
|
-
// update value by user set
|
|
49
|
-
const set = useCallback(v => {
|
|
50
|
-
const newValue = typeof v === 'function' ? v(getter(mmkv, key)) : v;
|
|
51
|
-
switch (typeof newValue) {
|
|
52
|
-
case 'number':
|
|
53
|
-
case 'string':
|
|
54
|
-
case 'boolean':
|
|
55
|
-
mmkv.set(key, newValue);
|
|
56
|
-
break;
|
|
57
|
-
case 'undefined':
|
|
58
|
-
mmkv.delete(key);
|
|
59
|
-
break;
|
|
60
|
-
case 'object':
|
|
61
|
-
if (newValue instanceof ArrayBuffer) {
|
|
62
|
-
mmkv.set(key, newValue);
|
|
63
|
-
break;
|
|
64
|
-
} else {
|
|
65
|
-
throw new Error(`MMKV: Type object (${newValue}) is not supported!`);
|
|
66
|
-
}
|
|
67
|
-
default:
|
|
68
|
-
throw new Error(`MMKV: Type ${typeof newValue} is not supported!`);
|
|
69
|
-
}
|
|
70
|
-
}, [key, mmkv]);
|
|
71
|
-
|
|
72
|
-
// update value if it changes somewhere else (second hook, same key)
|
|
73
|
-
useEffect(() => {
|
|
74
|
-
const listener = mmkv.addOnValueChangedListener(changedKey => {
|
|
75
|
-
if (changedKey === key) {
|
|
76
|
-
setBump(b => b + 1);
|
|
77
|
-
}
|
|
78
|
-
});
|
|
79
|
-
return () => listener.remove();
|
|
80
|
-
}, [key, mmkv]);
|
|
81
|
-
return [value, set];
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
/**
|
|
86
|
-
* Use the string value of the given `key` from the given MMKV storage instance.
|
|
87
|
-
*
|
|
88
|
-
* If no instance is provided, a shared default instance will be used.
|
|
89
|
-
*
|
|
90
|
-
* @example
|
|
91
|
-
* ```ts
|
|
92
|
-
* const [username, setUsername] = useMMKVString("user.name")
|
|
93
|
-
* ```
|
|
94
|
-
*/
|
|
95
|
-
export const useMMKVString = createMMKVHook((instance, key) => instance.getString(key));
|
|
96
|
-
|
|
97
|
-
/**
|
|
98
|
-
* Use the number value of the given `key` from the given MMKV storage instance.
|
|
99
|
-
*
|
|
100
|
-
* If no instance is provided, a shared default instance will be used.
|
|
101
|
-
*
|
|
102
|
-
* @example
|
|
103
|
-
* ```ts
|
|
104
|
-
* const [age, setAge] = useMMKVNumber("user.age")
|
|
105
|
-
* ```
|
|
106
|
-
*/
|
|
107
|
-
export const useMMKVNumber = createMMKVHook((instance, key) => instance.getNumber(key));
|
|
108
|
-
/**
|
|
109
|
-
* Use the boolean value of the given `key` from the given MMKV storage instance.
|
|
110
|
-
*
|
|
111
|
-
* If no instance is provided, a shared default instance will be used.
|
|
112
|
-
*
|
|
113
|
-
* @example
|
|
114
|
-
* ```ts
|
|
115
|
-
* const [isPremiumAccount, setIsPremiumAccount] = useMMKVBoolean("user.isPremium")
|
|
116
|
-
* ```
|
|
117
|
-
*/
|
|
118
|
-
export const useMMKVBoolean = createMMKVHook((instance, key) => instance.getBoolean(key));
|
|
119
|
-
/**
|
|
120
|
-
* Use the buffer value (unsigned 8-bit (0-255)) of the given `key` from the given MMKV storage instance.
|
|
121
|
-
*
|
|
122
|
-
* If no instance is provided, a shared default instance will be used.
|
|
123
|
-
*
|
|
124
|
-
* @example
|
|
125
|
-
* ```ts
|
|
126
|
-
* const [privateKey, setPrivateKey] = useMMKVBuffer("user.privateKey")
|
|
127
|
-
* ```
|
|
128
|
-
*/
|
|
129
|
-
export const useMMKVBuffer = createMMKVHook((instance, key) => instance.getBuffer(key));
|
|
130
|
-
/**
|
|
131
|
-
* Use an object value of the given `key` from the given MMKV storage instance.
|
|
132
|
-
*
|
|
133
|
-
* If no instance is provided, a shared default instance will be used.
|
|
134
|
-
*
|
|
135
|
-
* The object will be serialized using `JSON`.
|
|
136
|
-
*
|
|
137
|
-
* @example
|
|
138
|
-
* ```ts
|
|
139
|
-
* const [user, setUser] = useMMKVObject<User>("user")
|
|
140
|
-
* ```
|
|
141
|
-
*/
|
|
142
|
-
export function useMMKVObject(key, instance) {
|
|
143
|
-
const [json, setJson] = useMMKVString(key, instance);
|
|
144
|
-
const value = useMemo(() => {
|
|
145
|
-
if (json == null) return undefined;
|
|
146
|
-
return JSON.parse(json);
|
|
147
|
-
}, [json]);
|
|
148
|
-
const setValue = useCallback(v => {
|
|
149
|
-
if (v instanceof Function) {
|
|
150
|
-
setJson(currentJson => {
|
|
151
|
-
const currentValue = currentJson != null ? JSON.parse(currentJson) : undefined;
|
|
152
|
-
const newValue = v(currentValue);
|
|
153
|
-
// Store the Object as a serialized Value or clear the value
|
|
154
|
-
return newValue != null ? JSON.stringify(newValue) : undefined;
|
|
155
|
-
});
|
|
156
|
-
} else {
|
|
157
|
-
// Store the Object as a serialized Value or clear the value
|
|
158
|
-
const newValue = v != null ? JSON.stringify(v) : undefined;
|
|
159
|
-
setJson(newValue);
|
|
160
|
-
}
|
|
161
|
-
}, [setJson]);
|
|
162
|
-
return [value, setValue];
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
/**
|
|
166
|
-
* Listen for changes in the given MMKV storage instance.
|
|
167
|
-
* If no instance is passed, the default instance will be used.
|
|
168
|
-
* @param valueChangedListener The function to call whenever a value inside the storage instance changes
|
|
169
|
-
* @param instance The instance to listen to changes to (or the default instance)
|
|
170
|
-
*
|
|
171
|
-
* @example
|
|
172
|
-
* ```ts
|
|
173
|
-
* useMMKVListener((key) => {
|
|
174
|
-
* console.log(`Value for "${key}" changed!`)
|
|
175
|
-
* })
|
|
176
|
-
* ```
|
|
177
|
-
*/
|
|
178
|
-
export function useMMKVListener(valueChangedListener, instance) {
|
|
179
|
-
const ref = useRef(valueChangedListener);
|
|
180
|
-
ref.current = valueChangedListener;
|
|
181
|
-
const mmkv = instance ?? getDefaultInstance();
|
|
182
|
-
useEffect(() => {
|
|
183
|
-
const listener = mmkv.addOnValueChangedListener(changedKey => {
|
|
184
|
-
ref.current(changedKey);
|
|
185
|
-
});
|
|
186
|
-
return () => listener.remove();
|
|
187
|
-
}, [mmkv]);
|
|
188
|
-
}
|
|
189
|
-
//# sourceMappingURL=hooks.js.map
|
package/lib/module/hooks.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["useRef","useState","useMemo","useCallback","useEffect","MMKV","isConfigurationEqual","left","right","encryptionKey","id","path","mode","defaultInstance","getDefaultInstance","useMMKV","configuration","instance","undefined","lastConfiguration","current","createMMKVHook","getter","key","mmkv","bump","setBump","value","set","v","newValue","delete","ArrayBuffer","Error","listener","addOnValueChangedListener","changedKey","b","remove","useMMKVString","getString","useMMKVNumber","getNumber","useMMKVBoolean","getBoolean","useMMKVBuffer","getBuffer","useMMKVObject","json","setJson","JSON","parse","setValue","Function","currentJson","currentValue","stringify","useMMKVListener","valueChangedListener","ref"],"sourceRoot":"../../src","sources":["hooks.ts"],"mappings":";;AAAA,SAASA,MAAM,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,WAAW,EAAEC,SAAS,QAAQ,OAAO;AACzE,SAASC,IAAI,QAAQ,QAAQ;AAG7B,SAASC,oBAAoBA,CAC3BC,IAAoB,EACpBC,KAAqB,EACZ;EACT,IAAID,IAAI,IAAI,IAAI,IAAIC,KAAK,IAAI,IAAI,EAAE,OAAOD,IAAI,IAAI,IAAI,IAAIC,KAAK,IAAI,IAAI;EAEvE,OACED,IAAI,CAACE,aAAa,KAAKD,KAAK,CAACC,aAAa,IAC1CF,IAAI,CAACG,EAAE,KAAKF,KAAK,CAACE,EAAE,IACpBH,IAAI,CAACI,IAAI,KAAKH,KAAK,CAACG,IAAI,IACxBJ,IAAI,CAACK,IAAI,KAAKJ,KAAK,CAACI,IAAI;AAE5B;AAEA,IAAIC,eAA4B,GAAG,IAAI;AACvC,SAASC,kBAAkBA,CAAA,EAAS;EAClC,IAAID,eAAe,IAAI,IAAI,EAAE;IAC3BA,eAAe,GAAG,IAAIR,IAAI,CAAC,CAAC;EAC9B;EACA,OAAOQ,eAAe;AACxB;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,OAAO,SAASE,OAAOA,CAACC,aAA6B,EAAQ;EAC3D,MAAMC,QAAQ,GAAGjB,MAAM,CAAOkB,SAAS,CAAC;EACxC,MAAMC,iBAAiB,GAAGnB,MAAM,CAAgBkB,SAAS,CAAC;EAE1D,IAAIF,aAAa,IAAI,IAAI,EAAE,OAAOF,kBAAkB,CAAC,CAAC;EAEtD,IACEG,QAAQ,CAACG,OAAO,IAAI,IAAI,IACxB,CAACd,oBAAoB,CAACa,iBAAiB,CAACC,OAAO,EAAEJ,aAAa,CAAC,EAC/D;IACAG,iBAAiB,CAACC,OAAO,GAAGJ,aAAa;IACzCC,QAAQ,CAACG,OAAO,GAAG,IAAIf,IAAI,CAACW,aAAa,CAAC;EAC5C;EAEA,OAAOC,QAAQ,CAACG,OAAO;AACzB;AAEA,SAASC,cAAcA,CAIrBC,MAA0C,EAAE;EAC5C,OAAO,CACLC,GAAW,EACXN,QAAe,KACuC;IACtD,MAAMO,IAAI,GAAGP,QAAQ,IAAIH,kBAAkB,CAAC,CAAC;IAE7C,MAAM,CAACW,IAAI,EAAEC,OAAO,CAAC,GAAGzB,QAAQ,CAAC,CAAC,CAAC;IACnC,MAAM0B,KAAK,GAAGzB,OAAO,CAAC,MAAM;MAC1B;MACA;MACA;MACAuB,IAAI;MACJ,OAAOH,MAAM,CAACE,IAAI,EAAED,GAAG,CAAC;IAC1B,CAAC,EAAE,CAACC,IAAI,EAAED,GAAG,EAAEE,IAAI,CAAC,CAAC;;IAErB;IACA,MAAMG,GAAG,GAAGzB,WAAW,CACpB0B,CAAa,IAAK;MACjB,MAAMC,QAAQ,GAAG,OAAOD,CAAC,KAAK,UAAU,GAAGA,CAAC,CAACP,MAAM,CAACE,IAAI,EAAED,GAAG,CAAC,CAAC,GAAGM,CAAC;MACnE,QAAQ,OAAOC,QAAQ;QACrB,KAAK,QAAQ;QACb,KAAK,QAAQ;QACb,KAAK,SAAS;UACZN,IAAI,CAACI,GAAG,CAACL,GAAG,EAAEO,QAAQ,CAAC;UACvB;QACF,KAAK,WAAW;UACdN,IAAI,CAACO,MAAM,CAACR,GAAG,CAAC;UAChB;QACF,KAAK,QAAQ;UACX,IAAIO,QAAQ,YAAYE,WAAW,EAAE;YACnCR,IAAI,CAACI,GAAG,CAACL,GAAG,EAAEO,QAAQ,CAAC;YACvB;UACF,CAAC,MAAM;YACL,MAAM,IAAIG,KAAK,CACb,sBAAsBH,QAAQ,qBAChC,CAAC;UACH;QACF;UACE,MAAM,IAAIG,KAAK,CAAC,cAAc,OAAOH,QAAQ,oBAAoB,CAAC;MACtE;IACF,CAAC,EACD,CAACP,GAAG,EAAEC,IAAI,CACZ,CAAC;;IAED;IACApB,SAAS,CAAC,MAAM;MACd,MAAM8B,QAAQ,GAAGV,IAAI,CAACW,yBAAyB,CAAEC,UAAU,IAAK;QAC9D,IAAIA,UAAU,KAAKb,GAAG,EAAE;UACtBG,OAAO,CAAEW,CAAC,IAAKA,CAAC,GAAG,CAAC,CAAC;QACvB;MACF,CAAC,CAAC;MACF,OAAO,MAAMH,QAAQ,CAACI,MAAM,CAAC,CAAC;IAChC,CAAC,EAAE,CAACf,GAAG,EAAEC,IAAI,CAAC,CAAC;IAEf,OAAO,CAACG,KAAK,EAAEC,GAAG,CAAC;EACrB,CAAC;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMW,aAAa,GAAGlB,cAAc,CAAC,CAACJ,QAAQ,EAAEM,GAAG,KACxDN,QAAQ,CAACuB,SAAS,CAACjB,GAAG,CACxB,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMkB,aAAa,GAAGpB,cAAc,CAAC,CAACJ,QAAQ,EAAEM,GAAG,KACxDN,QAAQ,CAACyB,SAAS,CAACnB,GAAG,CACxB,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMoB,cAAc,GAAGtB,cAAc,CAAC,CAACJ,QAAQ,EAAEM,GAAG,KACzDN,QAAQ,CAAC2B,UAAU,CAACrB,GAAG,CACzB,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMsB,aAAa,GAAGxB,cAAc,CAAC,CAACJ,QAAQ,EAAEM,GAAG,KACxDN,QAAQ,CAAC6B,SAAS,CAACvB,GAAG,CACxB,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASwB,aAAaA,CAC3BxB,GAAW,EACXN,QAAe,EAMf;EACA,MAAM,CAAC+B,IAAI,EAAEC,OAAO,CAAC,GAAGV,aAAa,CAAChB,GAAG,EAAEN,QAAQ,CAAC;EAEpD,MAAMU,KAAK,GAAGzB,OAAO,CAAC,MAAM;IAC1B,IAAI8C,IAAI,IAAI,IAAI,EAAE,OAAO9B,SAAS;IAClC,OAAOgC,IAAI,CAACC,KAAK,CAACH,IAAI,CAAC;EACzB,CAAC,EAAE,CAACA,IAAI,CAAC,CAAC;EAEV,MAAMI,QAAQ,GAAGjD,WAAW,CACzB0B,CAA6D,IAAK;IACjE,IAAIA,CAAC,YAAYwB,QAAQ,EAAE;MACzBJ,OAAO,CAAEK,WAAW,IAAK;QACvB,MAAMC,YAAY,GAChBD,WAAW,IAAI,IAAI,GAAIJ,IAAI,CAACC,KAAK,CAACG,WAAW,CAAC,GAASpC,SAAS;QAClE,MAAMY,QAAQ,GAAGD,CAAC,CAAC0B,YAAY,CAAC;QAChC;QACA,OAAOzB,QAAQ,IAAI,IAAI,GAAGoB,IAAI,CAACM,SAAS,CAAC1B,QAAQ,CAAC,GAAGZ,SAAS;MAChE,CAAC,CAAC;IACJ,CAAC,MAAM;MACL;MACA,MAAMY,QAAQ,GAAGD,CAAC,IAAI,IAAI,GAAGqB,IAAI,CAACM,SAAS,CAAC3B,CAAC,CAAC,GAAGX,SAAS;MAC1D+B,OAAO,CAACnB,QAAQ,CAAC;IACnB;EACF,CAAC,EACD,CAACmB,OAAO,CACV,CAAC;EAED,OAAO,CAACtB,KAAK,EAAEyB,QAAQ,CAAC;AAC1B;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASK,eAAeA,CAC7BC,oBAA2C,EAC3CzC,QAAe,EACT;EACN,MAAM0C,GAAG,GAAG3D,MAAM,CAAC0D,oBAAoB,CAAC;EACxCC,GAAG,CAACvC,OAAO,GAAGsC,oBAAoB;EAElC,MAAMlC,IAAI,GAAGP,QAAQ,IAAIH,kBAAkB,CAAC,CAAC;EAE7CV,SAAS,CAAC,MAAM;IACd,MAAM8B,QAAQ,GAAGV,IAAI,CAACW,yBAAyB,CAAEC,UAAU,IAAK;MAC9DuB,GAAG,CAACvC,OAAO,CAACgB,UAAU,CAAC;IACzB,CAAC,CAAC;IACF,OAAO,MAAMF,QAAQ,CAACI,MAAM,CAAC,CAAC;EAChC,CAAC,EAAE,CAACd,IAAI,CAAC,CAAC;AACZ","ignoreList":[]}
|