react-native-unistyles 2.9.2 → 3.0.0-alpha.1
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +1 -1
- package/android/CMakeLists.txt +33 -6
- package/android/build.gradle +4 -2
- package/android/src/main/cxx/cpp-adapter.cpp +82 -65
- package/android/src/main/java/com/unistyles/UnistylesPackage.kt +19 -9
- package/cxx/common/Breakpoints.h +43 -0
- package/cxx/common/Constants.h +10 -0
- package/cxx/common/Helpers.h +93 -0
- package/cxx/core/HostStyle.cpp +57 -0
- package/cxx/core/HostStyle.h +25 -0
- package/cxx/core/MediaQueries.cpp +87 -0
- package/cxx/core/MediaQueries.h +47 -0
- package/cxx/core/StyleSheet.h +32 -0
- package/cxx/core/StyleSheetRegistry.cpp +45 -0
- package/cxx/core/StyleSheetRegistry.h +26 -0
- package/cxx/core/Unistyle.h +81 -0
- package/cxx/core/UnistyleWrapper.cpp +5 -0
- package/cxx/core/UnistyleWrapper.h +50 -0
- package/cxx/core/UnistylesCommitHook.cpp +53 -0
- package/cxx/core/UnistylesCommitHook.h +27 -0
- package/cxx/core/UnistylesCommitShadowNode.h +26 -0
- package/cxx/core/UnistylesRegistry.cpp +176 -0
- package/cxx/core/UnistylesRegistry.h +59 -0
- package/cxx/core/UnistylesState.cpp +95 -0
- package/cxx/core/UnistylesState.h +50 -0
- package/cxx/hybridObjects/HybridNavigationBar.cpp +17 -0
- package/cxx/hybridObjects/HybridNavigationBar.h +19 -0
- package/cxx/hybridObjects/HybridShadowRegistry.cpp +26 -0
- package/cxx/hybridObjects/HybridShadowRegistry.h +33 -0
- package/cxx/hybridObjects/HybridStatusBar.cpp +17 -0
- package/cxx/hybridObjects/HybridStatusBar.h +19 -0
- package/cxx/hybridObjects/HybridStyleSheet.cpp +245 -0
- package/cxx/hybridObjects/HybridStyleSheet.h +61 -0
- package/cxx/hybridObjects/HybridUnistylesRuntime.cpp +199 -0
- package/cxx/hybridObjects/HybridUnistylesRuntime.h +70 -0
- package/cxx/parser/Parser.cpp +714 -0
- package/cxx/parser/Parser.h +55 -0
- package/cxx/shadowTree/ShadowLeafUpdate.h +13 -0
- package/cxx/shadowTree/ShadowTreeManager.cpp +124 -0
- package/cxx/shadowTree/ShadowTreeManager.h +23 -0
- package/ios/Equatable.swift +64 -0
- package/ios/Extensions.swift +11 -0
- package/ios/NativePlatform+ios.swift +291 -0
- package/ios/NativePlatform.swift +17 -0
- package/ios/NativePlatformListener+ios.swift +41 -0
- package/ios/Unistyles.h +3 -0
- package/ios/UnistylesModuleOnLoad.h +11 -0
- package/ios/UnistylesModuleOnLoad.mm +51 -0
- package/lib/commonjs/common.js +1 -58
- package/lib/commonjs/common.js.map +1 -1
- package/lib/commonjs/index.js +27 -66
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/{utils/mq.js → mq.js} +12 -2
- package/lib/commonjs/mq.js.map +1 -0
- package/lib/commonjs/package.json +1 -0
- package/lib/commonjs/specs/NativePlatform/NativePlatform.nitro.js +25 -0
- package/lib/commonjs/specs/NativePlatform/NativePlatform.nitro.js.map +1 -0
- package/lib/commonjs/specs/NativePlatform/index.js +13 -0
- package/lib/commonjs/specs/NativePlatform/index.js.map +1 -0
- package/lib/commonjs/specs/NavigtionBar/UnistylesNavigationBar.nitro.js +6 -0
- package/lib/commonjs/specs/NavigtionBar/UnistylesNavigationBar.nitro.js.map +1 -0
- package/lib/commonjs/specs/NavigtionBar/index.js +17 -0
- package/lib/commonjs/specs/NavigtionBar/index.js.map +1 -0
- package/lib/commonjs/{types/plugin.js → specs/ShadowRegistry/ShadowRegistry.nitro.js} +1 -1
- package/lib/commonjs/specs/ShadowRegistry/ShadowRegistry.nitro.js.map +1 -0
- package/lib/commonjs/specs/ShadowRegistry/index.js +30 -0
- package/lib/commonjs/specs/ShadowRegistry/index.js.map +1 -0
- package/lib/commonjs/specs/ShadowRegistry/types.js +2 -0
- package/lib/commonjs/specs/ShadowRegistry/types.js.map +1 -0
- package/lib/commonjs/{types/normalizer.js → specs/StatusBar/UnistylesStatusBar.nitro.js} +1 -1
- package/lib/commonjs/specs/StatusBar/UnistylesStatusBar.nitro.js.map +1 -0
- package/lib/commonjs/specs/StatusBar/index.js +33 -0
- package/lib/commonjs/specs/StatusBar/index.js.map +1 -0
- package/lib/commonjs/specs/StyleSheet/UnistylesStyleSheet.nitro.js +6 -0
- package/lib/commonjs/specs/StyleSheet/UnistylesStyleSheet.nitro.js.map +1 -0
- package/lib/commonjs/specs/StyleSheet/index.js +18 -0
- package/lib/commonjs/specs/StyleSheet/index.js.map +1 -0
- package/lib/commonjs/specs/TurboUnistyles/NativeTurboUnistyles.js +8 -0
- package/lib/commonjs/specs/TurboUnistyles/NativeTurboUnistyles.js.map +1 -0
- package/lib/commonjs/specs/TurboUnistyles/index.js +4 -0
- package/lib/commonjs/specs/TurboUnistyles/index.js.map +1 -0
- package/lib/commonjs/{types/unistyles.js → specs/UnistylesRuntime/UnistylesRuntime.nitro.js} +1 -1
- package/lib/commonjs/specs/UnistylesRuntime/UnistylesRuntime.nitro.js.map +1 -0
- package/lib/commonjs/specs/UnistylesRuntime/index.js +26 -0
- package/lib/commonjs/specs/UnistylesRuntime/index.js.map +1 -0
- package/lib/commonjs/specs/index.js +47 -0
- package/lib/commonjs/specs/index.js.map +1 -0
- package/lib/commonjs/specs/index.web.js +24 -0
- package/lib/commonjs/specs/index.web.js.map +1 -0
- package/lib/commonjs/specs/types.js +24 -0
- package/lib/commonjs/specs/types.js.map +1 -0
- package/lib/commonjs/types/accessibility.js +37 -0
- package/lib/commonjs/types/accessibility.js.map +1 -0
- package/lib/commonjs/types/index.js +16 -30
- package/lib/commonjs/types/index.js.map +1 -1
- package/lib/commonjs/types/stylesheet.js +3 -0
- package/lib/commonjs/types/stylesheet.js.map +1 -1
- package/lib/commonjs/types/variants.js +4 -0
- package/lib/module/common.js +2 -56
- package/lib/module/common.js.map +1 -1
- package/lib/module/global.js +1 -1
- package/lib/module/index.js +12 -29
- package/lib/module/index.js.map +1 -1
- package/lib/module/{utils/mq.js → mq.js} +14 -2
- package/lib/module/mq.js.map +1 -0
- package/lib/module/package.json +1 -0
- package/lib/module/specs/NativePlatform/NativePlatform.nitro.js +23 -0
- package/lib/module/specs/NativePlatform/NativePlatform.nitro.js.map +1 -0
- package/lib/module/specs/NativePlatform/index.js +4 -0
- package/lib/module/specs/NativePlatform/index.js.map +1 -0
- package/lib/module/specs/NavigtionBar/UnistylesNavigationBar.nitro.js +4 -0
- package/lib/module/specs/NavigtionBar/UnistylesNavigationBar.nitro.js.map +1 -0
- package/lib/module/specs/NavigtionBar/index.js +12 -0
- package/lib/module/specs/NavigtionBar/index.js.map +1 -0
- package/lib/module/specs/ShadowRegistry/ShadowRegistry.nitro.js +4 -0
- package/lib/module/specs/ShadowRegistry/ShadowRegistry.nitro.js.map +1 -0
- package/lib/module/specs/ShadowRegistry/index.js +26 -0
- package/lib/module/specs/ShadowRegistry/index.js.map +1 -0
- package/lib/module/specs/ShadowRegistry/types.js +2 -0
- package/lib/module/specs/ShadowRegistry/types.js.map +1 -0
- package/lib/module/specs/StatusBar/UnistylesStatusBar.nitro.js +4 -0
- package/lib/module/specs/StatusBar/UnistylesStatusBar.nitro.js.map +1 -0
- package/lib/module/specs/StatusBar/index.js +28 -0
- package/lib/module/specs/StatusBar/index.js.map +1 -0
- package/lib/module/specs/StyleSheet/UnistylesStyleSheet.nitro.js +4 -0
- package/lib/module/specs/StyleSheet/UnistylesStyleSheet.nitro.js.map +1 -0
- package/lib/module/specs/StyleSheet/index.js +14 -0
- package/lib/module/specs/StyleSheet/index.js.map +1 -0
- package/lib/module/specs/TurboUnistyles/NativeTurboUnistyles.js +9 -0
- package/lib/module/specs/TurboUnistyles/NativeTurboUnistyles.js.map +1 -0
- package/lib/module/specs/TurboUnistyles/index.js +4 -0
- package/lib/module/specs/TurboUnistyles/index.js.map +1 -0
- package/lib/module/specs/UnistylesRuntime/UnistylesRuntime.nitro.js +4 -0
- package/lib/module/specs/UnistylesRuntime/UnistylesRuntime.nitro.js.map +1 -0
- package/lib/module/specs/UnistylesRuntime/index.js +22 -0
- package/lib/module/specs/UnistylesRuntime/index.js.map +1 -0
- package/lib/module/specs/index.js +10 -0
- package/lib/module/specs/index.js.map +1 -0
- package/lib/module/specs/index.web.js +5 -0
- package/lib/module/specs/index.web.js.map +1 -0
- package/lib/module/specs/types.js +20 -0
- package/lib/module/specs/types.js.map +1 -0
- package/lib/module/types/accessibility.js +33 -0
- package/lib/module/types/accessibility.js.map +1 -0
- package/lib/module/types/breakpoints.js +2 -0
- package/lib/module/types/common.js +1 -1
- package/lib/module/types/core.js +2 -0
- package/lib/module/types/index.js +3 -3
- package/lib/module/types/index.js.map +1 -1
- package/lib/module/types/stylesheet.js +5 -0
- package/lib/module/types/stylesheet.js.map +1 -1
- package/lib/module/types/variants.js +2 -0
- package/lib/typescript/example/App.d.ts +4 -0
- package/lib/typescript/example/App.d.ts.map +1 -0
- package/lib/typescript/example/unistyles.d.ts +63 -0
- package/lib/typescript/example/unistyles.d.ts.map +1 -0
- package/lib/typescript/expo-example/App.d.ts +4 -0
- package/lib/typescript/expo-example/App.d.ts.map +1 -0
- package/lib/typescript/expo-example/unistyles.d.ts +63 -0
- package/lib/typescript/expo-example/unistyles.d.ts.map +1 -0
- package/lib/typescript/src/common.d.ts +0 -50
- package/lib/typescript/src/common.d.ts.map +1 -1
- package/lib/typescript/src/index.d.ts +3 -76
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/{utils/mq.d.ts → mq.d.ts} +2 -2
- package/lib/typescript/src/mq.d.ts.map +1 -0
- package/lib/typescript/src/specs/NativePlatform/NativePlatform.nitro.d.ts +57 -0
- package/lib/typescript/src/specs/NativePlatform/NativePlatform.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/NativePlatform/index.d.ts +3 -0
- package/lib/typescript/src/specs/NativePlatform/index.d.ts.map +1 -0
- package/lib/typescript/src/specs/NavigtionBar/UnistylesNavigationBar.nitro.d.ts +11 -0
- package/lib/typescript/src/specs/NavigtionBar/UnistylesNavigationBar.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/NavigtionBar/index.d.ts +11 -0
- package/lib/typescript/src/specs/NavigtionBar/index.d.ts.map +1 -0
- package/lib/typescript/src/specs/ShadowRegistry/ShadowRegistry.nitro.d.ts +7 -0
- package/lib/typescript/src/specs/ShadowRegistry/ShadowRegistry.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ShadowRegistry/index.d.ts +12 -0
- package/lib/typescript/src/specs/ShadowRegistry/index.d.ts.map +1 -0
- package/lib/typescript/src/specs/ShadowRegistry/types.d.ts +27 -0
- package/lib/typescript/src/specs/ShadowRegistry/types.d.ts.map +1 -0
- package/lib/typescript/src/specs/StatusBar/UnistylesStatusBar.nitro.d.ts +11 -0
- package/lib/typescript/src/specs/StatusBar/UnistylesStatusBar.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/StatusBar/index.d.ts +15 -0
- package/lib/typescript/src/specs/StatusBar/index.d.ts.map +1 -0
- package/lib/typescript/src/specs/StyleSheet/UnistylesStyleSheet.nitro.d.ts +9 -0
- package/lib/typescript/src/specs/StyleSheet/UnistylesStyleSheet.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/StyleSheet/index.d.ts +28 -0
- package/lib/typescript/src/specs/StyleSheet/index.d.ts.map +1 -0
- package/lib/typescript/src/specs/TurboUnistyles/NativeTurboUnistyles.d.ts +2 -0
- package/lib/typescript/src/specs/TurboUnistyles/NativeTurboUnistyles.d.ts.map +1 -0
- package/lib/typescript/src/specs/TurboUnistyles/index.d.ts +2 -0
- package/lib/typescript/src/specs/TurboUnistyles/index.d.ts.map +1 -0
- package/lib/typescript/src/specs/UnistylesRuntime/UnistylesRuntime.nitro.d.ts +41 -0
- package/lib/typescript/src/specs/UnistylesRuntime/UnistylesRuntime.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/UnistylesRuntime/index.d.ts +25 -0
- package/lib/typescript/src/specs/UnistylesRuntime/index.d.ts.map +1 -0
- package/lib/typescript/src/specs/index.d.ts +10 -0
- package/lib/typescript/src/specs/index.d.ts.map +1 -0
- package/lib/typescript/src/specs/index.web.d.ts +4 -0
- package/lib/typescript/src/specs/index.web.d.ts.map +1 -0
- package/lib/typescript/src/specs/types.d.ts +32 -0
- package/lib/typescript/src/specs/types.d.ts.map +1 -0
- package/lib/typescript/src/types/accessibility.d.ts +28 -0
- package/lib/typescript/src/types/accessibility.d.ts.map +1 -0
- package/lib/typescript/src/types/breakpoints.d.ts +12 -5
- package/lib/typescript/src/types/breakpoints.d.ts.map +1 -1
- package/lib/typescript/src/types/common.d.ts +1 -0
- package/lib/typescript/src/types/common.d.ts.map +1 -1
- package/lib/typescript/src/types/index.d.ts +2 -5
- package/lib/typescript/src/types/index.d.ts.map +1 -1
- package/lib/typescript/src/types/stylesheet.d.ts +31 -9
- package/lib/typescript/src/types/stylesheet.d.ts.map +1 -1
- package/lib/typescript/src/types/variants.d.ts +5 -8
- package/lib/typescript/src/types/variants.d.ts.map +1 -1
- package/lib/typescript/web/convert/boxShadow.d.ts +3 -0
- package/lib/typescript/web/convert/boxShadow.d.ts.map +1 -0
- package/lib/typescript/web/convert/breakpoint.d.ts +3 -0
- package/lib/typescript/web/convert/breakpoint.d.ts.map +1 -0
- package/lib/typescript/web/convert/index.d.ts +4 -0
- package/lib/typescript/web/convert/index.d.ts.map +1 -0
- package/lib/typescript/web/convert/shadow.d.ts +2 -0
- package/lib/typescript/web/convert/shadow.d.ts.map +1 -0
- package/lib/typescript/web/convert/style.d.ts +3 -0
- package/lib/typescript/web/convert/style.d.ts.map +1 -0
- package/lib/typescript/web/convert/textShadow.d.ts +3 -0
- package/lib/typescript/web/convert/textShadow.d.ts.map +1 -0
- package/lib/typescript/web/convert/transform.d.ts +5 -0
- package/lib/typescript/web/convert/transform.d.ts.map +1 -0
- package/lib/typescript/web/convert/types.d.ts +13 -0
- package/lib/typescript/web/convert/types.d.ts.map +1 -0
- package/lib/typescript/web/convert/utils.d.ts +8 -0
- package/lib/typescript/web/convert/utils.d.ts.map +1 -0
- package/lib/typescript/web/create.d.ts +2449 -0
- package/lib/typescript/web/create.d.ts.map +1 -0
- package/lib/typescript/web/index.d.ts +2464 -0
- package/lib/typescript/web/index.d.ts.map +1 -0
- package/lib/typescript/web/listener/index.d.ts +2 -0
- package/lib/typescript/web/listener/index.d.ts.map +1 -0
- package/lib/typescript/web/listener/listener.d.ts +10 -0
- package/lib/typescript/web/listener/listener.d.ts.map +1 -0
- package/lib/typescript/web/mock.d.ts +14 -0
- package/lib/typescript/web/mock.d.ts.map +1 -0
- package/lib/typescript/web/mq.d.ts +4 -0
- package/lib/typescript/web/mq.d.ts.map +1 -0
- package/lib/typescript/web/pseudo.d.ts +4 -0
- package/lib/typescript/web/pseudo.d.ts.map +1 -0
- package/lib/typescript/web/registry.d.ts +12 -0
- package/lib/typescript/web/registry.d.ts.map +1 -0
- package/lib/typescript/web/runtime.d.ts +42 -0
- package/lib/typescript/web/runtime.d.ts.map +1 -0
- package/lib/typescript/web/state.d.ts +24 -0
- package/lib/typescript/web/state.d.ts.map +1 -0
- package/lib/typescript/web/useVariants.d.ts +3 -0
- package/lib/typescript/web/useVariants.d.ts.map +1 -0
- package/lib/typescript/web/utils.d.ts +18 -0
- package/lib/typescript/web/utils.d.ts.map +1 -0
- package/nitrogen/generated/android/UnistylesOnLoad.cpp +34 -0
- package/nitrogen/generated/android/UnistylesOnLoad.hpp +25 -0
- package/nitrogen/generated/android/UnistylesOnLoad.kt +1 -0
- package/nitrogen/generated/android/c++/JColorScheme.hpp +61 -0
- package/nitrogen/generated/android/c++/JDimensions.hpp +56 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__vector_UnistyleDependency_.hpp +60 -0
- package/nitrogen/generated/android/c++/JHybridNativePlatformSpec.cpp +145 -0
- package/nitrogen/generated/android/c++/JHybridNativePlatformSpec.hpp +70 -0
- package/nitrogen/generated/android/c++/JInsets.hpp +68 -0
- package/nitrogen/generated/android/c++/JOrientation.hpp +58 -0
- package/nitrogen/generated/android/c++/JUnistyleDependency.hpp +94 -0
- package/nitrogen/generated/android/c++/JUnistylesNativeMiniRuntime.hpp +96 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/unistyles/ColorScheme.kt +22 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/unistyles/Dimensions.kt +21 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/unistyles/Func_void_std__vector_UnistyleDependency_.kt +45 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/unistyles/HybridNativePlatformSpec.kt +134 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/unistyles/Insets.kt +24 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/unistyles/Orientation.kt +21 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/unistyles/UnistyleDependency.kt +33 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/unistyles/UnistylesNativeMiniRuntime.kt +29 -0
- package/nitrogen/generated/android/unistyles+autolinking.cmake +52 -0
- package/nitrogen/generated/android/unistyles+autolinking.gradle +25 -0
- package/nitrogen/generated/ios/Unistyles+autolinking.rb +56 -0
- package/nitrogen/generated/ios/Unistyles-Swift-Cxx-Bridge.cpp +8 -0
- package/nitrogen/generated/ios/Unistyles-Swift-Cxx-Bridge.hpp +86 -0
- package/nitrogen/generated/ios/Unistyles-Swift-Cxx-Umbrella.hpp +88 -0
- package/nitrogen/generated/ios/c++/HybridNativePlatformSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridNativePlatformSpecSwift.hpp +151 -0
- package/nitrogen/generated/ios/swift/ColorScheme.swift +44 -0
- package/nitrogen/generated/ios/swift/Dimensions.swift +46 -0
- package/nitrogen/generated/ios/swift/HybridNativePlatformSpec.swift +65 -0
- package/nitrogen/generated/ios/swift/HybridNativePlatformSpecCxx.swift +273 -0
- package/nitrogen/generated/ios/swift/Insets.swift +79 -0
- package/nitrogen/generated/ios/swift/Orientation.swift +40 -0
- package/nitrogen/generated/ios/swift/UnistyleDependency.swift +88 -0
- package/nitrogen/generated/ios/swift/UnistylesNativeMiniRuntime.swift +134 -0
- package/nitrogen/generated/shared/c++/ColorScheme.hpp +82 -0
- package/nitrogen/generated/shared/c++/Dimensions.hpp +72 -0
- package/nitrogen/generated/shared/c++/HybridNativePlatformSpec.cpp +38 -0
- package/nitrogen/generated/shared/c++/HybridNativePlatformSpec.hpp +95 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesNavigationBarSpec.cpp +24 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesNavigationBarSpec.hpp +61 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesRuntimeSpec.cpp +36 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesRuntimeSpec.hpp +88 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesShadowRegistrySpec.cpp +21 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesShadowRegistrySpec.hpp +59 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesStatusBarSpec.cpp +24 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesStatusBarSpec.hpp +61 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesStyleSheetSpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridUnistylesStyleSheetSpec.hpp +60 -0
- package/nitrogen/generated/shared/c++/Insets.hpp +84 -0
- package/nitrogen/generated/shared/c++/Orientation.hpp +78 -0
- package/nitrogen/generated/shared/c++/UnistyleDependency.hpp +76 -0
- package/nitrogen/generated/shared/c++/UnistylesCxxMiniRuntime.hpp +128 -0
- package/nitrogen/generated/shared/c++/UnistylesNativeMiniRuntime.hpp +115 -0
- package/package.json +34 -59
- package/plugin/__tests__/dependencies.spec.js +360 -0
- package/plugin/__tests__/ref.spec.js +991 -0
- package/plugin/__tests__/stylesheet.spec.js +396 -0
- package/plugin/common.js +119 -0
- package/plugin/import.js +8 -0
- package/plugin/index.js +122 -0
- package/plugin/ref.js +179 -0
- package/plugin/style.js +58 -0
- package/plugin/stylesheet.js +147 -0
- package/src/common.ts +0 -58
- package/src/index.ts +11 -52
- package/src/{utils/mq.ts → mq.ts} +13 -4
- package/src/specs/NativePlatform/NativePlatform.nitro.ts +61 -0
- package/src/specs/NativePlatform/index.ts +2 -0
- package/src/specs/NavigtionBar/UnistylesNavigationBar.nitro.ts +10 -0
- package/src/specs/NavigtionBar/index.ts +25 -0
- package/src/specs/ShadowRegistry/ShadowRegistry.nitro.ts +3 -0
- package/src/specs/ShadowRegistry/index.ts +51 -0
- package/src/specs/ShadowRegistry/types.ts +29 -0
- package/src/specs/StatusBar/UnistylesStatusBar.nitro.ts +10 -0
- package/src/specs/StatusBar/index.ts +48 -0
- package/src/specs/StyleSheet/UnistylesStyleSheet.nitro.ts +6 -0
- package/src/specs/StyleSheet/index.ts +44 -0
- package/src/specs/TurboUnistyles/NativeTurboUnistyles.ts +8 -0
- package/src/specs/TurboUnistyles/index.ts +1 -0
- package/src/specs/UnistylesRuntime/UnistylesRuntime.nitro.ts +47 -0
- package/src/specs/UnistylesRuntime/index.ts +64 -0
- package/src/specs/index.ts +23 -0
- package/src/specs/index.web.ts +5 -0
- package/src/specs/types.ts +38 -0
- package/src/types/accessibility.ts +29 -0
- package/src/types/breakpoints.ts +21 -14
- package/src/types/common.ts +1 -0
- package/src/types/index.ts +2 -5
- package/src/types/stylesheet.ts +41 -9
- package/src/types/variants.ts +7 -11
- package/web/convert/boxShadow.ts +72 -0
- package/web/convert/breakpoint.ts +21 -0
- package/web/convert/index.ts +78 -0
- package/web/convert/shadow.ts +68 -0
- package/web/convert/style.ts +94 -0
- package/web/convert/textShadow.ts +69 -0
- package/web/convert/transform.ts +89 -0
- package/web/convert/types.ts +16 -0
- package/web/convert/utils.ts +54 -0
- package/web/create.ts +102 -0
- package/web/index.ts +24 -0
- package/web/listener/index.ts +1 -0
- package/web/listener/listener.ts +33 -0
- package/web/mock.ts +35 -0
- package/web/mq.ts +19 -0
- package/web/pseudo.ts +11 -0
- package/web/registry.ts +41 -0
- package/web/runtime.ts +198 -0
- package/web/state.ts +148 -0
- package/web/useVariants.ts +99 -0
- package/web/utils.ts +95 -0
- package/android/src/main/java/com/unistyles/Models.kt +0 -27
- package/android/src/main/java/com/unistyles/Platform.kt +0 -318
- package/android/src/main/java/com/unistyles/UnistylesModule.kt +0 -217
- package/cxx/Macros.h +0 -11
- package/cxx/UnistylesImpl.cpp +0 -310
- package/cxx/UnistylesModel.cpp +0 -230
- package/cxx/UnistylesModel.h +0 -143
- package/cxx/UnistylesRuntime.cpp +0 -36
- package/cxx/UnistylesRuntime.h +0 -81
- package/ios/UnistylesModule.h +0 -28
- package/ios/UnistylesModule.mm +0 -77
- package/ios/platform/Platform_Shared.h +0 -8
- package/ios/platform/Platform_Shared.mm +0 -160
- package/ios/platform/Platform_iOS.h +0 -20
- package/ios/platform/Platform_iOS.mm +0 -193
- package/ios/platform/Platform_macOS.h +0 -19
- package/ios/platform/Platform_macOS.mm +0 -117
- package/ios/platform/Platform_tvOS.h +0 -16
- package/ios/platform/Platform_tvOS.mm +0 -92
- package/ios/platform/Platform_visionOS.h +0 -19
- package/ios/platform/Platform_visionOS.mm +0 -116
- package/lib/commonjs/core/UnistyleRegistry.js +0 -110
- package/lib/commonjs/core/UnistyleRegistry.js.map +0 -1
- package/lib/commonjs/core/Unistyles.js +0 -39
- package/lib/commonjs/core/Unistyles.js.map +0 -1
- package/lib/commonjs/core/UnistylesModule.js +0 -268
- package/lib/commonjs/core/UnistylesModule.js.map +0 -1
- package/lib/commonjs/core/UnistylesModule.native.js +0 -9
- package/lib/commonjs/core/UnistylesModule.native.js.map +0 -1
- package/lib/commonjs/core/UnistylesModule.windows.js +0 -11
- package/lib/commonjs/core/UnistylesModule.windows.js.map +0 -1
- package/lib/commonjs/core/UnistylesRuntime.js +0 -272
- package/lib/commonjs/core/UnistylesRuntime.js.map +0 -1
- package/lib/commonjs/core/index.js +0 -13
- package/lib/commonjs/core/index.js.map +0 -1
- package/lib/commonjs/core/mocks/UnistylesMockedBridge.js +0 -36
- package/lib/commonjs/core/mocks/UnistylesMockedBridge.js.map +0 -1
- package/lib/commonjs/core/mocks/UnistylesMockedRegistry.js +0 -46
- package/lib/commonjs/core/mocks/UnistylesMockedRegistry.js.map +0 -1
- package/lib/commonjs/core/mocks/UnistylesMockedRuntime.js +0 -116
- package/lib/commonjs/core/mocks/UnistylesMockedRuntime.js.map +0 -1
- package/lib/commonjs/core/mocks/index.js +0 -27
- package/lib/commonjs/core/mocks/index.js.map +0 -1
- package/lib/commonjs/createStyleSheet.js +0 -14
- package/lib/commonjs/createStyleSheet.js.map +0 -1
- package/lib/commonjs/hooks/index.js +0 -34
- package/lib/commonjs/hooks/index.js.map +0 -1
- package/lib/commonjs/hooks/useCSS.js +0 -44
- package/lib/commonjs/hooks/useCSS.js.map +0 -1
- package/lib/commonjs/hooks/useCSS.native.js +0 -9
- package/lib/commonjs/hooks/useCSS.native.js.map +0 -1
- package/lib/commonjs/hooks/useInitialTheme.js +0 -17
- package/lib/commonjs/hooks/useInitialTheme.js.map +0 -1
- package/lib/commonjs/hooks/useUnistyles.js +0 -74
- package/lib/commonjs/hooks/useUnistyles.js.map +0 -1
- package/lib/commonjs/hooks/useVariants.js +0 -14
- package/lib/commonjs/hooks/useVariants.js.map +0 -1
- package/lib/commonjs/normalizer/index.js +0 -32
- package/lib/commonjs/normalizer/index.js.map +0 -1
- package/lib/commonjs/normalizer/module.d.js +0 -2
- package/lib/commonjs/normalizer/module.d.js.map +0 -1
- package/lib/commonjs/normalizer/normalizeStyle.js +0 -59
- package/lib/commonjs/normalizer/normalizeStyle.js.map +0 -1
- package/lib/commonjs/normalizer/normalizer.js +0 -88
- package/lib/commonjs/normalizer/normalizer.js.map +0 -1
- package/lib/commonjs/normalizer/normalizer.macos.js +0 -3
- package/lib/commonjs/normalizer/normalizer.macos.js.map +0 -1
- package/lib/commonjs/plugins/cssMediaQueriesPlugin.js +0 -14
- package/lib/commonjs/plugins/cssMediaQueriesPlugin.js.map +0 -1
- package/lib/commonjs/plugins/index.js +0 -20
- package/lib/commonjs/plugins/index.js.map +0 -1
- package/lib/commonjs/plugins/normalizeWebStylesPlugin.js +0 -12
- package/lib/commonjs/plugins/normalizeWebStylesPlugin.js.map +0 -1
- package/lib/commonjs/types/color.js +0 -2
- package/lib/commonjs/types/color.js.map +0 -1
- package/lib/commonjs/types/normalizer.js.map +0 -1
- package/lib/commonjs/types/plugin.js.map +0 -1
- package/lib/commonjs/types/unistyles.js.map +0 -1
- package/lib/commonjs/useStyles.js +0 -47
- package/lib/commonjs/useStyles.js.map +0 -1
- package/lib/commonjs/utils/breakpoints.js +0 -33
- package/lib/commonjs/utils/breakpoints.js.map +0 -1
- package/lib/commonjs/utils/cssMediaQuery.js +0 -244
- package/lib/commonjs/utils/cssMediaQuery.js.map +0 -1
- package/lib/commonjs/utils/generateId.js +0 -15
- package/lib/commonjs/utils/generateId.js.map +0 -1
- package/lib/commonjs/utils/hash32.js +0 -43
- package/lib/commonjs/utils/hash32.js.map +0 -1
- package/lib/commonjs/utils/index.js +0 -91
- package/lib/commonjs/utils/index.js.map +0 -1
- package/lib/commonjs/utils/mq.js.map +0 -1
- package/lib/commonjs/utils/mqParser.js +0 -89
- package/lib/commonjs/utils/mqParser.js.map +0 -1
- package/lib/commonjs/utils/parseColor.js +0 -35
- package/lib/commonjs/utils/parseColor.js.map +0 -1
- package/lib/commonjs/utils/styles.js +0 -73
- package/lib/commonjs/utils/styles.js.map +0 -1
- package/lib/commonjs/utils/withPlugins.js +0 -15
- package/lib/commonjs/utils/withPlugins.js.map +0 -1
- package/lib/module/core/UnistyleRegistry.js +0 -103
- package/lib/module/core/UnistyleRegistry.js.map +0 -1
- package/lib/module/core/Unistyles.js +0 -33
- package/lib/module/core/Unistyles.js.map +0 -1
- package/lib/module/core/UnistylesModule.js +0 -261
- package/lib/module/core/UnistylesModule.js.map +0 -1
- package/lib/module/core/UnistylesModule.native.js +0 -3
- package/lib/module/core/UnistylesModule.native.js.map +0 -1
- package/lib/module/core/UnistylesModule.windows.js +0 -5
- package/lib/module/core/UnistylesModule.windows.js.map +0 -1
- package/lib/module/core/UnistylesRuntime.js +0 -266
- package/lib/module/core/UnistylesRuntime.js.map +0 -1
- package/lib/module/core/index.js +0 -3
- package/lib/module/core/index.js.map +0 -1
- package/lib/module/core/mocks/UnistylesMockedBridge.js +0 -29
- package/lib/module/core/mocks/UnistylesMockedBridge.js.map +0 -1
- package/lib/module/core/mocks/UnistylesMockedRegistry.js +0 -39
- package/lib/module/core/mocks/UnistylesMockedRegistry.js.map +0 -1
- package/lib/module/core/mocks/UnistylesMockedRuntime.js +0 -108
- package/lib/module/core/mocks/UnistylesMockedRuntime.js.map +0 -1
- package/lib/module/core/mocks/index.js +0 -4
- package/lib/module/core/mocks/index.js.map +0 -1
- package/lib/module/createStyleSheet.js +0 -7
- package/lib/module/createStyleSheet.js.map +0 -1
- package/lib/module/hooks/index.js +0 -5
- package/lib/module/hooks/index.js.map +0 -1
- package/lib/module/hooks/useCSS.js +0 -37
- package/lib/module/hooks/useCSS.js.map +0 -1
- package/lib/module/hooks/useCSS.native.js +0 -2
- package/lib/module/hooks/useCSS.native.js.map +0 -1
- package/lib/module/hooks/useInitialTheme.js +0 -10
- package/lib/module/hooks/useInitialTheme.js.map +0 -1
- package/lib/module/hooks/useUnistyles.js +0 -67
- package/lib/module/hooks/useUnistyles.js.map +0 -1
- package/lib/module/hooks/useVariants.js +0 -7
- package/lib/module/hooks/useVariants.js.map +0 -1
- package/lib/module/normalizer/index.js +0 -3
- package/lib/module/normalizer/index.js.map +0 -1
- package/lib/module/normalizer/module.d.js +0 -2
- package/lib/module/normalizer/module.d.js.map +0 -1
- package/lib/module/normalizer/normalizeStyle.js +0 -52
- package/lib/module/normalizer/normalizeStyle.js.map +0 -1
- package/lib/module/normalizer/normalizer.js +0 -78
- package/lib/module/normalizer/normalizer.js.map +0 -1
- package/lib/module/normalizer/normalizer.macos.js +0 -2
- package/lib/module/normalizer/normalizer.macos.js.map +0 -1
- package/lib/module/plugins/cssMediaQueriesPlugin.js +0 -7
- package/lib/module/plugins/cssMediaQueriesPlugin.js.map +0 -1
- package/lib/module/plugins/index.js +0 -3
- package/lib/module/plugins/index.js.map +0 -1
- package/lib/module/plugins/normalizeWebStylesPlugin.js +0 -6
- package/lib/module/plugins/normalizeWebStylesPlugin.js.map +0 -1
- package/lib/module/types/color.js +0 -2
- package/lib/module/types/color.js.map +0 -1
- package/lib/module/types/normalizer.js +0 -2
- package/lib/module/types/normalizer.js.map +0 -1
- package/lib/module/types/plugin.js +0 -2
- package/lib/module/types/plugin.js.map +0 -1
- package/lib/module/types/unistyles.js +0 -2
- package/lib/module/types/unistyles.js.map +0 -1
- package/lib/module/useStyles.js +0 -40
- package/lib/module/useStyles.js.map +0 -1
- package/lib/module/utils/breakpoints.js +0 -26
- package/lib/module/utils/breakpoints.js.map +0 -1
- package/lib/module/utils/cssMediaQuery.js +0 -237
- package/lib/module/utils/cssMediaQuery.js.map +0 -1
- package/lib/module/utils/generateId.js +0 -7
- package/lib/module/utils/generateId.js.map +0 -1
- package/lib/module/utils/hash32.js +0 -36
- package/lib/module/utils/hash32.js.map +0 -1
- package/lib/module/utils/index.js +0 -8
- package/lib/module/utils/index.js.map +0 -1
- package/lib/module/utils/mq.js.map +0 -1
- package/lib/module/utils/mqParser.js +0 -78
- package/lib/module/utils/mqParser.js.map +0 -1
- package/lib/module/utils/parseColor.js +0 -28
- package/lib/module/utils/parseColor.js.map +0 -1
- package/lib/module/utils/styles.js +0 -64
- package/lib/module/utils/styles.js.map +0 -1
- package/lib/module/utils/withPlugins.js +0 -8
- package/lib/module/utils/withPlugins.js.map +0 -1
- package/lib/typescript/src/core/UnistyleRegistry.d.ts +0 -57
- package/lib/typescript/src/core/UnistyleRegistry.d.ts.map +0 -1
- package/lib/typescript/src/core/Unistyles.d.ts +0 -13
- package/lib/typescript/src/core/Unistyles.d.ts.map +0 -1
- package/lib/typescript/src/core/UnistylesModule.d.ts +0 -21
- package/lib/typescript/src/core/UnistylesModule.d.ts.map +0 -1
- package/lib/typescript/src/core/UnistylesModule.native.d.ts +0 -6
- package/lib/typescript/src/core/UnistylesModule.native.d.ts.map +0 -1
- package/lib/typescript/src/core/UnistylesModule.windows.d.ts +0 -6
- package/lib/typescript/src/core/UnistylesModule.windows.d.ts.map +0 -1
- package/lib/typescript/src/core/UnistylesRuntime.d.ts +0 -173
- package/lib/typescript/src/core/UnistylesRuntime.d.ts.map +0 -1
- package/lib/typescript/src/core/index.d.ts +0 -5
- package/lib/typescript/src/core/index.d.ts.map +0 -1
- package/lib/typescript/src/core/mocks/UnistylesMockedBridge.d.ts +0 -28
- package/lib/typescript/src/core/mocks/UnistylesMockedBridge.d.ts.map +0 -1
- package/lib/typescript/src/core/mocks/UnistylesMockedRegistry.d.ts +0 -21
- package/lib/typescript/src/core/mocks/UnistylesMockedRegistry.d.ts.map +0 -1
- package/lib/typescript/src/core/mocks/UnistylesMockedRuntime.d.ts +0 -78
- package/lib/typescript/src/core/mocks/UnistylesMockedRuntime.d.ts.map +0 -1
- package/lib/typescript/src/core/mocks/index.d.ts +0 -4
- package/lib/typescript/src/core/mocks/index.d.ts.map +0 -1
- package/lib/typescript/src/createStyleSheet.d.ts +0 -8
- package/lib/typescript/src/createStyleSheet.d.ts.map +0 -1
- package/lib/typescript/src/hooks/index.d.ts +0 -5
- package/lib/typescript/src/hooks/index.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useCSS.d.ts +0 -3
- package/lib/typescript/src/hooks/useCSS.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useCSS.native.d.ts +0 -3
- package/lib/typescript/src/hooks/useCSS.native.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useInitialTheme.d.ts +0 -3
- package/lib/typescript/src/hooks/useInitialTheme.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useUnistyles.d.ts +0 -27
- package/lib/typescript/src/hooks/useUnistyles.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useVariants.d.ts +0 -3
- package/lib/typescript/src/hooks/useVariants.d.ts.map +0 -1
- package/lib/typescript/src/normalizer/index.d.ts +0 -3
- package/lib/typescript/src/normalizer/index.d.ts.map +0 -1
- package/lib/typescript/src/normalizer/normalizeStyle.d.ts +0 -3
- package/lib/typescript/src/normalizer/normalizeStyle.d.ts.map +0 -1
- package/lib/typescript/src/normalizer/normalizer.d.ts +0 -11
- package/lib/typescript/src/normalizer/normalizer.d.ts.map +0 -1
- package/lib/typescript/src/normalizer/normalizer.macos.d.ts +0 -1
- package/lib/typescript/src/normalizer/normalizer.macos.d.ts.map +0 -1
- package/lib/typescript/src/plugins/cssMediaQueriesPlugin.d.ts +0 -3
- package/lib/typescript/src/plugins/cssMediaQueriesPlugin.d.ts.map +0 -1
- package/lib/typescript/src/plugins/index.d.ts +0 -3
- package/lib/typescript/src/plugins/index.d.ts.map +0 -1
- package/lib/typescript/src/plugins/normalizeWebStylesPlugin.d.ts +0 -3
- package/lib/typescript/src/plugins/normalizeWebStylesPlugin.d.ts.map +0 -1
- package/lib/typescript/src/types/color.d.ts +0 -4
- package/lib/typescript/src/types/color.d.ts.map +0 -1
- package/lib/typescript/src/types/normalizer.d.ts +0 -20
- package/lib/typescript/src/types/normalizer.d.ts.map +0 -1
- package/lib/typescript/src/types/plugin.d.ts +0 -7
- package/lib/typescript/src/types/plugin.d.ts.map +0 -1
- package/lib/typescript/src/types/unistyles.d.ts +0 -81
- package/lib/typescript/src/types/unistyles.d.ts.map +0 -1
- package/lib/typescript/src/useStyles.d.ts +0 -16
- package/lib/typescript/src/useStyles.d.ts.map +0 -1
- package/lib/typescript/src/utils/breakpoints.d.ts +0 -3
- package/lib/typescript/src/utils/breakpoints.d.ts.map +0 -1
- package/lib/typescript/src/utils/cssMediaQuery.d.ts +0 -4
- package/lib/typescript/src/utils/cssMediaQuery.d.ts.map +0 -1
- package/lib/typescript/src/utils/generateId.d.ts +0 -2
- package/lib/typescript/src/utils/generateId.d.ts.map +0 -1
- package/lib/typescript/src/utils/hash32.d.ts +0 -2
- package/lib/typescript/src/utils/hash32.d.ts.map +0 -1
- package/lib/typescript/src/utils/index.d.ts +0 -9
- package/lib/typescript/src/utils/index.d.ts.map +0 -1
- package/lib/typescript/src/utils/mq.d.ts.map +0 -1
- package/lib/typescript/src/utils/mqParser.d.ts +0 -16
- package/lib/typescript/src/utils/mqParser.d.ts.map +0 -1
- package/lib/typescript/src/utils/parseColor.d.ts +0 -3
- package/lib/typescript/src/utils/parseColor.d.ts.map +0 -1
- package/lib/typescript/src/utils/styles.d.ts +0 -5
- package/lib/typescript/src/utils/styles.d.ts.map +0 -1
- package/lib/typescript/src/utils/withPlugins.d.ts +0 -3
- package/lib/typescript/src/utils/withPlugins.d.ts.map +0 -1
- package/react-native-unistyles.podspec +0 -25
- package/react-native.config.js +0 -11
- package/src/__tests__/mocks.ts +0 -24
- package/src/core/UnistyleRegistry.ts +0 -130
- package/src/core/Unistyles.ts +0 -44
- package/src/core/UnistylesModule.native.ts +0 -7
- package/src/core/UnistylesModule.ts +0 -305
- package/src/core/UnistylesModule.windows.ts +0 -9
- package/src/core/UnistylesRuntime.ts +0 -271
- package/src/core/index.ts +0 -8
- package/src/core/mocks/UnistylesMockedBridge.ts +0 -30
- package/src/core/mocks/UnistylesMockedRegistry.ts +0 -47
- package/src/core/mocks/UnistylesMockedRuntime.ts +0 -136
- package/src/core/mocks/index.ts +0 -3
- package/src/createStyleSheet.ts +0 -8
- package/src/hooks/index.ts +0 -4
- package/src/hooks/useCSS.native.ts +0 -3
- package/src/hooks/useCSS.ts +0 -51
- package/src/hooks/useInitialTheme.ts +0 -11
- package/src/hooks/useUnistyles.ts +0 -74
- package/src/hooks/useVariants.ts +0 -10
- package/src/normalizer/index.ts +0 -2
- package/src/normalizer/normalizeStyle.ts +0 -82
- package/src/normalizer/normalizer.macos.ts +0 -1
- package/src/normalizer/normalizer.ts +0 -100
- package/src/plugins/cssMediaQueriesPlugin.ts +0 -8
- package/src/plugins/index.ts +0 -2
- package/src/plugins/normalizeWebStylesPlugin.ts +0 -7
- package/src/types/color.ts +0 -26
- package/src/types/normalizer.ts +0 -29
- package/src/types/plugin.ts +0 -7
- package/src/types/unistyles.ts +0 -98
- package/src/useStyles.ts +0 -60
- package/src/utils/breakpoints.ts +0 -44
- package/src/utils/cssMediaQuery.ts +0 -268
- package/src/utils/generateId.ts +0 -10
- package/src/utils/hash32.ts +0 -53
- package/src/utils/index.ts +0 -8
- package/src/utils/mqParser.ts +0 -99
- package/src/utils/parseColor.ts +0 -33
- package/src/utils/styles.ts +0 -90
- package/src/utils/withPlugins.ts +0 -13
- package/windows/ExperimentalFeatures.props +0 -40
- package/windows/NuGet.Config +0 -13
- package/windows/ReactNativeUnistyles/PropertySheet.props +0 -16
- package/windows/ReactNativeUnistyles/ReactNativeUnistyles.def +0 -3
- package/windows/ReactNativeUnistyles/ReactNativeUnistyles.h +0 -149
- package/windows/ReactNativeUnistyles/ReactNativeUnistyles.vcxproj +0 -162
- package/windows/ReactNativeUnistyles/ReactNativeUnistyles.vcxproj.filters +0 -25
- package/windows/ReactNativeUnistyles/ReactPackageProvider.cpp +0 -19
- package/windows/ReactNativeUnistyles/ReactPackageProvider.h +0 -21
- package/windows/ReactNativeUnistyles/ReactPackageProvider.idl +0 -9
- package/windows/ReactNativeUnistyles/packages.lock.json +0 -133
- package/windows/ReactNativeUnistyles/pch.cpp +0 -1
- package/windows/ReactNativeUnistyles/pch.h +0 -21
- package/windows/ReactNativeUnistyles.sln +0 -156
- /package/{src/normalizer → web/convert}/module.d.ts +0 -0
@@ -0,0 +1,32 @@
|
|
1
|
+
#pragma once
|
2
|
+
|
3
|
+
#include <jsi/jsi.h>
|
4
|
+
#include "Unistyle.h"
|
5
|
+
#include "UnistyleWrapper.h"
|
6
|
+
#include "Helpers.h"
|
7
|
+
#include "Constants.h"
|
8
|
+
|
9
|
+
namespace margelo::nitro::unistyles::core {
|
10
|
+
|
11
|
+
using namespace facebook;
|
12
|
+
|
13
|
+
enum class StyleSheetType {
|
14
|
+
Static,
|
15
|
+
Themable,
|
16
|
+
ThemableWithMiniRuntime
|
17
|
+
};
|
18
|
+
|
19
|
+
struct StyleSheet {
|
20
|
+
StyleSheet(int tag, StyleSheetType type, jsi::Object rawValue): tag{tag}, type{type}, rawValue{std::move(rawValue)} {};
|
21
|
+
|
22
|
+
StyleSheet(const StyleSheet&) = delete;
|
23
|
+
StyleSheet(StyleSheet&& other) = delete;
|
24
|
+
|
25
|
+
int tag;
|
26
|
+
StyleSheetType type;
|
27
|
+
jsi::Object rawValue;
|
28
|
+
std::unordered_map<std::string, Unistyle::Shared> unistyles{};
|
29
|
+
std::vector<std::pair<std::string, std::string>> variants{};
|
30
|
+
};
|
31
|
+
|
32
|
+
}
|
@@ -0,0 +1,45 @@
|
|
1
|
+
#include "StyleSheetRegistry.h"
|
2
|
+
#include "UnistylesRegistry.h"
|
3
|
+
|
4
|
+
using namespace margelo::nitro::unistyles::core;
|
5
|
+
using namespace facebook;
|
6
|
+
|
7
|
+
std::shared_ptr<StyleSheet> StyleSheetRegistry::addStyleSheetFromValue(jsi::Runtime& rt, jsi::Object rawStyleSheet) {
|
8
|
+
static unsigned int tag = 0;
|
9
|
+
|
10
|
+
if (rawStyleSheet.isFunction(rt)) {
|
11
|
+
return this->addFromFunction(rt, ++tag, rawStyleSheet.asFunction(rt));
|
12
|
+
}
|
13
|
+
|
14
|
+
return this->addFromObject(rt, ++tag, std::move(rawStyleSheet));
|
15
|
+
}
|
16
|
+
|
17
|
+
std::shared_ptr<StyleSheet> StyleSheetRegistry::addFromFunction(jsi::Runtime& rt, unsigned int tag, jsi::Function styleSheetFn) {
|
18
|
+
auto numberOfArgs = styleSheetFn.getProperty(rt, "length").getNumber();
|
19
|
+
|
20
|
+
helpers::assertThat(rt, numberOfArgs <= 2, "expected up to 2 arguments.");
|
21
|
+
|
22
|
+
auto& registry = UnistylesRegistry::get();
|
23
|
+
|
24
|
+
// stylesheet is still static, remove the function wrapper
|
25
|
+
if (numberOfArgs == 0) {
|
26
|
+
auto staticStyleSheet = styleSheetFn.call(rt).asObject(rt);
|
27
|
+
|
28
|
+
return registry.addStyleSheet(tag, core::StyleSheetType::Static, std::move(staticStyleSheet));
|
29
|
+
}
|
30
|
+
|
31
|
+
// stylesheet depends only on theme
|
32
|
+
if (numberOfArgs == 1) {
|
33
|
+
return registry.addStyleSheet(tag, core::StyleSheetType::Themable, std::move(styleSheetFn));
|
34
|
+
}
|
35
|
+
|
36
|
+
// stylesheet depends on theme and mini runtime
|
37
|
+
return registry.addStyleSheet(tag, core::StyleSheetType::ThemableWithMiniRuntime, std::move(styleSheetFn));
|
38
|
+
}
|
39
|
+
|
40
|
+
std::shared_ptr<StyleSheet> StyleSheetRegistry::addFromObject(jsi::Runtime& rt, unsigned int tag, jsi::Object rawStyleSheet) {
|
41
|
+
auto& registry = UnistylesRegistry::get();
|
42
|
+
|
43
|
+
return registry.addStyleSheet(tag, core::StyleSheetType::Static, std::move(rawStyleSheet));
|
44
|
+
}
|
45
|
+
|
@@ -0,0 +1,26 @@
|
|
1
|
+
#pragma once
|
2
|
+
|
3
|
+
#include <jsi/jsi.h>
|
4
|
+
#include "StyleSheet.h"
|
5
|
+
#include "Unistyle.h"
|
6
|
+
#include "UnistylesState.h"
|
7
|
+
|
8
|
+
namespace margelo::nitro::unistyles::core {
|
9
|
+
|
10
|
+
using namespace facebook;
|
11
|
+
|
12
|
+
struct StyleSheetRegistry {
|
13
|
+
StyleSheetRegistry() = default;
|
14
|
+
virtual ~StyleSheetRegistry() = default;
|
15
|
+
|
16
|
+
StyleSheetRegistry(const StyleSheetRegistry&) = delete;
|
17
|
+
StyleSheetRegistry(StyleSheetRegistry&&) = delete;
|
18
|
+
|
19
|
+
virtual std::shared_ptr<StyleSheet> addStyleSheetFromValue(jsi::Runtime& rt, jsi::Object rawStyleSheet);
|
20
|
+
|
21
|
+
private:
|
22
|
+
virtual std::shared_ptr<StyleSheet> addFromFunction(jsi::Runtime& rt, unsigned int tag, jsi::Function styleSheetFn);
|
23
|
+
virtual std::shared_ptr<StyleSheet> addFromObject(jsi::Runtime& rt, unsigned int tag, jsi::Object rawStyleSheet);
|
24
|
+
};
|
25
|
+
|
26
|
+
}
|
@@ -0,0 +1,81 @@
|
|
1
|
+
#pragma once
|
2
|
+
|
3
|
+
#include "string"
|
4
|
+
#include <jsi/jsi.h>
|
5
|
+
#include <folly/dynamic.h>
|
6
|
+
#include "Unistyles-Swift-Cxx-Umbrella.hpp"
|
7
|
+
|
8
|
+
namespace margelo::nitro::unistyles::core {
|
9
|
+
|
10
|
+
using namespace facebook;
|
11
|
+
|
12
|
+
enum class UnistyleType {
|
13
|
+
Object,
|
14
|
+
DynamicFunction
|
15
|
+
};
|
16
|
+
|
17
|
+
struct DynamicFunctionMetadata {
|
18
|
+
size_t count;
|
19
|
+
std::vector<folly::dynamic> arguments;
|
20
|
+
};
|
21
|
+
|
22
|
+
struct Unistyle {
|
23
|
+
using Shared = std::shared_ptr<Unistyle>;
|
24
|
+
|
25
|
+
Unistyle(UnistyleType type, std::string styleKey, jsi::Object& rawObject)
|
26
|
+
: styleKey{styleKey}, type{type}, rawValue{std::move(rawObject)} {}
|
27
|
+
virtual ~Unistyle() = default;
|
28
|
+
|
29
|
+
Unistyle(const Unistyle&) = delete;
|
30
|
+
Unistyle(Unistyle&& other) = delete;
|
31
|
+
|
32
|
+
UnistyleType type;
|
33
|
+
std::string styleKey;
|
34
|
+
jsi::Object rawValue;
|
35
|
+
std::optional<jsi::Object> parsedStyle;
|
36
|
+
std::vector<UnistyleDependency> dependencies{};
|
37
|
+
|
38
|
+
inline void addDependency(UnistyleDependency dependency) {
|
39
|
+
// we can't add dependencies if unistyle is sealed
|
40
|
+
if (this->_isSealed) {
|
41
|
+
return;
|
42
|
+
}
|
43
|
+
|
44
|
+
auto it = std::find(this->dependencies.begin(), this->dependencies.end(), dependency);
|
45
|
+
|
46
|
+
if (it == this->dependencies.end()) {
|
47
|
+
this->dependencies.push_back(dependency);
|
48
|
+
}
|
49
|
+
}
|
50
|
+
|
51
|
+
inline bool dependsOn(UnistyleDependency dependency) {
|
52
|
+
return std::find(this->dependencies.begin(), this->dependencies.end(), dependency) != this->dependencies.end();
|
53
|
+
}
|
54
|
+
|
55
|
+
inline void seal() {
|
56
|
+
this->_isSealed = true;
|
57
|
+
}
|
58
|
+
|
59
|
+
private:
|
60
|
+
bool _isSealed = false;
|
61
|
+
};
|
62
|
+
|
63
|
+
struct UnistyleDynamicFunction: public Unistyle {
|
64
|
+
// dynamic function must have 4 different value types
|
65
|
+
// rawValue <- original user function
|
66
|
+
// proxiedFunction <- host function that is a wrapper for user's original function
|
67
|
+
// unprocessedValue <- object generated after calling proxy and user's original function
|
68
|
+
// parsedStyle <- parsed with Unistyle's parser
|
69
|
+
|
70
|
+
UnistyleDynamicFunction(UnistyleType type, std::string styleKey, jsi::Object& rawObject)
|
71
|
+
: Unistyle(type, styleKey, rawObject) {}
|
72
|
+
|
73
|
+
UnistyleDynamicFunction(const UnistyleDynamicFunction&) = delete;
|
74
|
+
UnistyleDynamicFunction(UnistyleDynamicFunction&& other) = delete;
|
75
|
+
|
76
|
+
std::optional<jsi::Object> unprocessedValue;
|
77
|
+
std::optional<jsi::Function> proxiedFunction = std::nullopt;
|
78
|
+
std::optional<DynamicFunctionMetadata> dynamicFunctionMetadata = std::nullopt;
|
79
|
+
};
|
80
|
+
|
81
|
+
}
|
@@ -0,0 +1,50 @@
|
|
1
|
+
#pragma once
|
2
|
+
|
3
|
+
#include <jsi/jsi.h>
|
4
|
+
#include "Unistyle.h"
|
5
|
+
#include "Helpers.h"
|
6
|
+
#include "Constants.h"
|
7
|
+
|
8
|
+
namespace margelo::nitro::unistyles::core {
|
9
|
+
|
10
|
+
struct UnistyleWrapper: public jsi::NativeState {
|
11
|
+
explicit UnistyleWrapper(Unistyle::Shared unistyle)
|
12
|
+
: unistyle(std::move(unistyle)) {}
|
13
|
+
|
14
|
+
~UnistyleWrapper() override;
|
15
|
+
|
16
|
+
Unistyle::Shared unistyle;
|
17
|
+
};
|
18
|
+
|
19
|
+
inline static Unistyle::Shared unistyleFromValue(jsi::Runtime& rt, const jsi::Value& value) {
|
20
|
+
if (value.isNull()) {
|
21
|
+
return nullptr;
|
22
|
+
}
|
23
|
+
|
24
|
+
return value.getObject(rt).getNativeState<UnistyleWrapper>(rt)->unistyle;
|
25
|
+
}
|
26
|
+
|
27
|
+
inline static jsi::Value valueFromUnistyle(jsi::Runtime& rt, Unistyle::Shared unistyle) {
|
28
|
+
auto wrappedUnistyle = std::make_shared<UnistyleWrapper>(unistyle);
|
29
|
+
|
30
|
+
if (unistyle->type == UnistyleType::Object) {
|
31
|
+
jsi::Object obj = jsi::Object(rt);
|
32
|
+
|
33
|
+
obj.setNativeState(rt, std::move(wrappedUnistyle));
|
34
|
+
helpers::defineHiddenProperty(rt, obj, helpers::UNISTYLES_ID.c_str(), unistyle->styleKey);
|
35
|
+
|
36
|
+
helpers::mergeJSIObjects(rt, obj, unistyle->parsedStyle.value());
|
37
|
+
|
38
|
+
return obj;
|
39
|
+
}
|
40
|
+
|
41
|
+
auto unistyleFn = std::dynamic_pointer_cast<UnistyleDynamicFunction>(unistyle);
|
42
|
+
auto hostFn = jsi::Value(rt, unistyleFn->proxiedFunction.value()).asObject(rt).asFunction(rt);
|
43
|
+
|
44
|
+
hostFn.setNativeState(rt, std::move(wrappedUnistyle));
|
45
|
+
hostFn.setProperty(rt, helpers::UNISTYLES_ID.c_str(), unistyleFn->styleKey);
|
46
|
+
|
47
|
+
return std::move(hostFn);
|
48
|
+
}
|
49
|
+
|
50
|
+
}
|
@@ -0,0 +1,53 @@
|
|
1
|
+
#include "UnistylesCommitHook.h"
|
2
|
+
|
3
|
+
using namespace margelo::nitro::unistyles;
|
4
|
+
using namespace facebook::react;
|
5
|
+
|
6
|
+
core::UnistylesCommitHook::UnistylesCommitHook(UIManager& uiManager, std::shared_ptr<HybridUnistylesRuntime> unistylesRuntime)
|
7
|
+
: _unistylesRuntime{unistylesRuntime} {
|
8
|
+
uiManager.registerCommitHook(*this);
|
9
|
+
};
|
10
|
+
|
11
|
+
core::UnistylesCommitHook::~UnistylesCommitHook() noexcept {}
|
12
|
+
|
13
|
+
void core::UnistylesCommitHook::commitHookWasRegistered(const UIManager &uiManager) noexcept {}
|
14
|
+
void core::UnistylesCommitHook::commitHookWasUnregistered(const UIManager &uiManager) noexcept {}
|
15
|
+
|
16
|
+
RootShadowNode::Unshared core::UnistylesCommitHook::shadowTreeWillCommit(
|
17
|
+
const ShadowTree &shadowTree,
|
18
|
+
const RootShadowNode::Shared &oldRootShadowNode,
|
19
|
+
const RootShadowNode::Unshared &newRootShadowNode
|
20
|
+
) noexcept {
|
21
|
+
RootShadowNode::Unshared rootNode = newRootShadowNode;
|
22
|
+
auto unistylesRootNode = std::reinterpret_pointer_cast<core::UnistylesCommitShadowNode>(newRootShadowNode);
|
23
|
+
|
24
|
+
// skip only unistyles commits
|
25
|
+
if (unistylesRootNode->hasUnistylesCommitTrait()) {
|
26
|
+
unistylesRootNode->removeUnistylesCommitTrait();
|
27
|
+
|
28
|
+
return newRootShadowNode;
|
29
|
+
}
|
30
|
+
|
31
|
+
auto shadowLeafUpdates = this->getUnistylesUpdates();
|
32
|
+
|
33
|
+
if (shadowLeafUpdates.size() == 0) {
|
34
|
+
return newRootShadowNode;
|
35
|
+
}
|
36
|
+
|
37
|
+
auto affectedNodes = shadow::ShadowTreeManager::findAffectedNodes(*rootNode, shadowLeafUpdates);
|
38
|
+
|
39
|
+
return std::static_pointer_cast<RootShadowNode>(shadow::ShadowTreeManager::cloneShadowTree(
|
40
|
+
this->_unistylesRuntime->getRuntime(),
|
41
|
+
*rootNode,
|
42
|
+
shadowLeafUpdates,
|
43
|
+
affectedNodes
|
44
|
+
));
|
45
|
+
}
|
46
|
+
|
47
|
+
shadow::ShadowLeafUpdates core::UnistylesCommitHook::getUnistylesUpdates() {
|
48
|
+
auto& registry = core::UnistylesRegistry::get();
|
49
|
+
auto parser = parser::Parser(this->_unistylesRuntime);
|
50
|
+
auto dependencyMap = registry.buildDependencyMap();
|
51
|
+
|
52
|
+
return parser.dependencyMapToShadowLeafUpdates(dependencyMap);
|
53
|
+
}
|
@@ -0,0 +1,27 @@
|
|
1
|
+
#pragma once
|
2
|
+
|
3
|
+
#include <react/renderer/uimanager/UIManager.h>
|
4
|
+
#include <react/renderer/uimanager/UIManagerCommitHook.h>
|
5
|
+
#include "HybridUnistylesRuntime.h"
|
6
|
+
#include "Parser.h"
|
7
|
+
#include "ShadowTreeManager.h"
|
8
|
+
|
9
|
+
namespace margelo::nitro::unistyles::core {
|
10
|
+
|
11
|
+
using namespace facebook::react;
|
12
|
+
|
13
|
+
struct UnistylesCommitHook : public UIManagerCommitHook {
|
14
|
+
UnistylesCommitHook(UIManager& uiManager, std::shared_ptr<HybridUnistylesRuntime> unistylesRuntime);
|
15
|
+
~UnistylesCommitHook() noexcept override;
|
16
|
+
|
17
|
+
void commitHookWasRegistered(const UIManager &uiManager) noexcept override;
|
18
|
+
void commitHookWasUnregistered(const UIManager &uiManager) noexcept override;
|
19
|
+
RootShadowNode::Unshared shadowTreeWillCommit(const ShadowTree &shadowTree, const RootShadowNode::Shared &oldRootShadowNode, const RootShadowNode::Unshared &newRootShadowNode) noexcept override;
|
20
|
+
|
21
|
+
shadow::ShadowLeafUpdates getUnistylesUpdates();
|
22
|
+
|
23
|
+
private:
|
24
|
+
std::shared_ptr<HybridUnistylesRuntime> _unistylesRuntime;
|
25
|
+
};
|
26
|
+
|
27
|
+
}
|
@@ -0,0 +1,26 @@
|
|
1
|
+
#pragma once
|
2
|
+
|
3
|
+
#include <react/renderer/core/ShadowNode.h>
|
4
|
+
|
5
|
+
namespace margelo::nitro::unistyles::core {
|
6
|
+
|
7
|
+
// used to distinguish Unistyles commits
|
8
|
+
// React Native uses 0-10
|
9
|
+
// Reanimated uses 27-28
|
10
|
+
constexpr shadow::ShadowNodeTraits::Trait UnistylesCommitTrait{1 << 30};
|
11
|
+
|
12
|
+
struct UnistylesCommitShadowNode: public shadow::ShadowNode {
|
13
|
+
inline void addUnistylesCommitTrait() {
|
14
|
+
traits_.set(UnistylesCommitTrait);
|
15
|
+
}
|
16
|
+
|
17
|
+
inline void removeUnistylesCommitTrait() {
|
18
|
+
traits_.unset(UnistylesCommitTrait);
|
19
|
+
}
|
20
|
+
|
21
|
+
inline bool hasUnistylesCommitTrait() {
|
22
|
+
return traits_.check(UnistylesCommitTrait);
|
23
|
+
}
|
24
|
+
};
|
25
|
+
|
26
|
+
}
|
@@ -0,0 +1,176 @@
|
|
1
|
+
#include "UnistylesRegistry.h"
|
2
|
+
#include "UnistylesState.h"
|
3
|
+
|
4
|
+
using namespace margelo::nitro::unistyles;
|
5
|
+
using namespace facebook;
|
6
|
+
using namespace facebook::react;
|
7
|
+
|
8
|
+
using DependencyMap = std::unordered_map<
|
9
|
+
std::shared_ptr<core::StyleSheet>,
|
10
|
+
std::unordered_map<const ShadowNodeFamily*, std::vector<core::Unistyle::Shared>>
|
11
|
+
>;
|
12
|
+
|
13
|
+
void core::UnistylesRegistry::registerTheme(jsi::Runtime& rt, std::string name, jsi::Object&& theme) {
|
14
|
+
auto& state = this->getState(rt);
|
15
|
+
|
16
|
+
state._jsThemes.emplace(name, jsi::WeakObject(rt, std::move(theme)));
|
17
|
+
state._registeredThemeNames.push_back(name);
|
18
|
+
}
|
19
|
+
|
20
|
+
void core::UnistylesRegistry::registerBreakpoints(jsi::Runtime& rt, std::vector<std::pair<std::string, double>>& sortedBreakpoints) {
|
21
|
+
auto& state = this->getState(rt);
|
22
|
+
|
23
|
+
state._sortedBreakpointPairs = std::move(sortedBreakpoints);
|
24
|
+
}
|
25
|
+
|
26
|
+
void core::UnistylesRegistry::setPrefersAdaptiveThemes(jsi::Runtime& rt, bool prefersAdaptiveThemes) {
|
27
|
+
auto& state = this->getState(rt);
|
28
|
+
|
29
|
+
state._prefersAdaptiveThemes = prefersAdaptiveThemes;
|
30
|
+
}
|
31
|
+
|
32
|
+
void core::UnistylesRegistry::setInitialThemeName(jsi::Runtime& rt, std::string themeName) {
|
33
|
+
auto& state = this->getState(rt);
|
34
|
+
|
35
|
+
state._initialThemeName = themeName;
|
36
|
+
}
|
37
|
+
|
38
|
+
core::UnistylesState& core::UnistylesRegistry::getState(jsi::Runtime& rt) {
|
39
|
+
auto it = this->_states.find(&rt);
|
40
|
+
|
41
|
+
helpers::assertThat(rt, it != this->_states.end(), "Unistyles was loaded, but it's not configured. Did you forget to call StyleSheet.configure? If you don't want to use any themes or breakpoints, simply call it with an empty object {}.");
|
42
|
+
|
43
|
+
return it->second;
|
44
|
+
}
|
45
|
+
|
46
|
+
void core::UnistylesRegistry::createState(jsi::Runtime& rt) {
|
47
|
+
auto it = this->_states.find(&rt);
|
48
|
+
|
49
|
+
// remove old state, so we can swap it with new config
|
50
|
+
// during live reload
|
51
|
+
if (it != this->_states.end()) {
|
52
|
+
this->_states.extract(&rt);
|
53
|
+
}
|
54
|
+
|
55
|
+
this->_states.emplace(
|
56
|
+
std::piecewise_construct,
|
57
|
+
std::forward_as_tuple(&rt),
|
58
|
+
std::forward_as_tuple(rt)
|
59
|
+
);
|
60
|
+
}
|
61
|
+
|
62
|
+
void core::UnistylesRegistry::updateTheme(jsi::Runtime& rt, std::string& themeName, jsi::Function&& callback) {
|
63
|
+
auto& state = this->getState(rt);
|
64
|
+
auto it = state._jsThemes.find(themeName);
|
65
|
+
|
66
|
+
helpers::assertThat(rt, it != state._jsThemes.end(), "you're trying to update theme '" + themeName + "' but it wasn't registered.");
|
67
|
+
|
68
|
+
auto currentThemeValue = it->second.lock(rt);
|
69
|
+
|
70
|
+
helpers::assertThat(rt, currentThemeValue.isObject(), "unable to update your theme from C++. It was already garbage collected.");
|
71
|
+
|
72
|
+
auto result = callback.call(rt, currentThemeValue.asObject(rt));
|
73
|
+
|
74
|
+
helpers::assertThat(rt, result.isObject(), "returned theme is not an object. Please check your updateTheme function.");
|
75
|
+
|
76
|
+
it->second = jsi::WeakObject(rt, result.asObject(rt));
|
77
|
+
}
|
78
|
+
|
79
|
+
void core::UnistylesRegistry::linkShadowNodeWithUnistyle(const ShadowNodeFamily* shadowNodeFamily, const core::Unistyle::Shared unistyle) {
|
80
|
+
if (!this->_shadowRegistry.contains(shadowNodeFamily)) {
|
81
|
+
this->_shadowRegistry[shadowNodeFamily] = {};
|
82
|
+
}
|
83
|
+
|
84
|
+
this->_shadowRegistry[shadowNodeFamily].emplace_back(unistyle);
|
85
|
+
}
|
86
|
+
|
87
|
+
void core::UnistylesRegistry::unlinkShadowNodeWithUnistyle(const ShadowNodeFamily* shadowNodeFamily, const core::Unistyle::Shared unistyle) {
|
88
|
+
auto& unistylesVec = this->_shadowRegistry[shadowNodeFamily];
|
89
|
+
auto it = std::find(unistylesVec.begin(), unistylesVec.end(), unistyle);
|
90
|
+
|
91
|
+
if (it != unistylesVec.end()) {
|
92
|
+
this->_shadowRegistry[shadowNodeFamily].erase(it);
|
93
|
+
}
|
94
|
+
}
|
95
|
+
|
96
|
+
std::shared_ptr<core::StyleSheet> core::UnistylesRegistry::addStyleSheet(int tag, core::StyleSheetType type, jsi::Object&& rawValue) {
|
97
|
+
this->_styleSheetRegistry.emplace_back(std::make_shared<core::StyleSheet>(tag, type, std::move(rawValue)));
|
98
|
+
|
99
|
+
return this->_styleSheetRegistry.back();
|
100
|
+
}
|
101
|
+
|
102
|
+
std::shared_ptr<core::StyleSheet> core::UnistylesRegistry::getStyleSheetById(int tag) {
|
103
|
+
auto it = std::find_if(
|
104
|
+
this->_styleSheetRegistry.begin(),
|
105
|
+
this->_styleSheetRegistry.end(),
|
106
|
+
[tag](std::shared_ptr<StyleSheet> styleSheet){
|
107
|
+
return styleSheet->tag == tag;
|
108
|
+
}
|
109
|
+
);
|
110
|
+
|
111
|
+
if (it == this->_styleSheetRegistry.cend()) {
|
112
|
+
throw std::runtime_error("stylesheet with tag: " + std::to_string(tag) + " cannot be found.");
|
113
|
+
}
|
114
|
+
|
115
|
+
return *it;
|
116
|
+
}
|
117
|
+
|
118
|
+
DependencyMap core::UnistylesRegistry::buildDependencyMap(std::vector<UnistyleDependency>& deps) {
|
119
|
+
DependencyMap dependencyMap;
|
120
|
+
|
121
|
+
for (const auto& styleSheet : this->_styleSheetRegistry) {
|
122
|
+
for (const auto& [_, unistyle] : styleSheet->unistyles) {
|
123
|
+
// check if in the given stylesheet we have unistyle
|
124
|
+
// that depends on something affected
|
125
|
+
bool hasAnyOfDependencies = std::any_of(
|
126
|
+
unistyle->dependencies.begin(),
|
127
|
+
unistyle->dependencies.end(),
|
128
|
+
[&deps](UnistyleDependency dep) {
|
129
|
+
return std::find(deps.begin(), deps.end(), dep) != deps.end();
|
130
|
+
}
|
131
|
+
);
|
132
|
+
|
133
|
+
if (!hasAnyOfDependencies) {
|
134
|
+
continue;
|
135
|
+
}
|
136
|
+
|
137
|
+
// if so, we need to find shadow family too
|
138
|
+
for (const auto& pair : this->_shadowRegistry) {
|
139
|
+
const auto& [family, unistyles] = pair;
|
140
|
+
|
141
|
+
for (const auto& shadowUnistyle : unistyles) {
|
142
|
+
if (unistyle != shadowUnistyle) {
|
143
|
+
continue;
|
144
|
+
}
|
145
|
+
|
146
|
+
dependencyMap[styleSheet][family].push_back(shadowUnistyle);
|
147
|
+
}
|
148
|
+
}
|
149
|
+
}
|
150
|
+
}
|
151
|
+
|
152
|
+
return dependencyMap;
|
153
|
+
}
|
154
|
+
|
155
|
+
DependencyMap core::UnistylesRegistry::buildDependencyMap() {
|
156
|
+
DependencyMap dependencyMap;
|
157
|
+
|
158
|
+
for (const auto& styleSheet : this->_styleSheetRegistry) {
|
159
|
+
for (const auto& [_, unistyle] : styleSheet->unistyles) {
|
160
|
+
for (const auto& pair : this->_shadowRegistry) {
|
161
|
+
const auto& [family, unistyles] = pair;
|
162
|
+
|
163
|
+
for (const auto& shadowUnistyle : unistyles) {
|
164
|
+
if (unistyle != shadowUnistyle) {
|
165
|
+
continue;
|
166
|
+
}
|
167
|
+
|
168
|
+
// make sure to use base Unistyle class
|
169
|
+
dependencyMap[styleSheet][family].push_back(shadowUnistyle);
|
170
|
+
}
|
171
|
+
}
|
172
|
+
}
|
173
|
+
}
|
174
|
+
|
175
|
+
return dependencyMap;
|
176
|
+
}
|
@@ -0,0 +1,59 @@
|
|
1
|
+
#pragma once
|
2
|
+
|
3
|
+
#include <jsi/jsi.h>
|
4
|
+
#include <react/renderer/uimanager/UIManager.h>
|
5
|
+
#include <unordered_map>
|
6
|
+
#include <unordered_set>
|
7
|
+
#include "Breakpoints.h"
|
8
|
+
#include "StyleSheetRegistry.h"
|
9
|
+
#include "StyleSheet.h"
|
10
|
+
#include "Unistyle.h"
|
11
|
+
|
12
|
+
namespace margelo::nitro::unistyles::core {
|
13
|
+
|
14
|
+
struct UnistylesState;
|
15
|
+
|
16
|
+
using namespace facebook;
|
17
|
+
using namespace facebook::react;
|
18
|
+
|
19
|
+
using DependencyMap = std::unordered_map<
|
20
|
+
std::shared_ptr<core::StyleSheet>,
|
21
|
+
std::unordered_map<const ShadowNodeFamily*, std::vector<core::Unistyle::Shared>>
|
22
|
+
>;
|
23
|
+
|
24
|
+
struct UnistylesRegistry: public StyleSheetRegistry {
|
25
|
+
static UnistylesRegistry& get();
|
26
|
+
|
27
|
+
UnistylesRegistry(const UnistylesRegistry&) = delete;
|
28
|
+
UnistylesRegistry(const UnistylesRegistry&&) = delete;
|
29
|
+
|
30
|
+
void registerTheme(jsi::Runtime& rt, std::string name, jsi::Object&& theme);
|
31
|
+
void registerBreakpoints(jsi::Runtime& rt, std::vector<std::pair<std::string, double>>& sortedBreakpoints);
|
32
|
+
void setPrefersAdaptiveThemes(jsi::Runtime& rt, bool prefersAdaptiveThemes);
|
33
|
+
void setInitialThemeName(jsi::Runtime& rt, std::string themeName);
|
34
|
+
void updateTheme(jsi::Runtime& rt, std::string& themeName, jsi::Function&& callback);
|
35
|
+
|
36
|
+
UnistylesState& getState(jsi::Runtime& rt);
|
37
|
+
void createState(jsi::Runtime& rt);
|
38
|
+
void linkShadowNodeWithUnistyle(const ShadowNodeFamily*, const core::Unistyle::Shared);
|
39
|
+
void unlinkShadowNodeWithUnistyle(const ShadowNodeFamily*, const core::Unistyle::Shared);
|
40
|
+
std::shared_ptr<core::StyleSheet> addStyleSheet(int tag, core::StyleSheetType type, jsi::Object&& rawValue);
|
41
|
+
std::shared_ptr<core::StyleSheet> getStyleSheetById(int tag);
|
42
|
+
DependencyMap buildDependencyMap(std::vector<UnistyleDependency>& deps);
|
43
|
+
DependencyMap buildDependencyMap();
|
44
|
+
|
45
|
+
private:
|
46
|
+
UnistylesRegistry() = default;
|
47
|
+
|
48
|
+
std::unordered_map<jsi::Runtime*, UnistylesState> _states{};
|
49
|
+
std::vector<std::shared_ptr<core::StyleSheet>> _styleSheetRegistry{};
|
50
|
+
std::unordered_map<const ShadowNodeFamily*, std::vector<core::Unistyle::Shared>> _shadowRegistry{};
|
51
|
+
};
|
52
|
+
|
53
|
+
UnistylesRegistry& UnistylesRegistry::get() {
|
54
|
+
static UnistylesRegistry cache;
|
55
|
+
|
56
|
+
return cache;
|
57
|
+
}
|
58
|
+
|
59
|
+
}
|
@@ -0,0 +1,95 @@
|
|
1
|
+
#include "UnistylesState.h"
|
2
|
+
#include "UnistylesRegistry.h"
|
3
|
+
|
4
|
+
using namespace margelo::nitro::unistyles;
|
5
|
+
|
6
|
+
bool core::UnistylesState::hasAdaptiveThemes() {
|
7
|
+
if (!this->_prefersAdaptiveThemes.has_value() || !this->_prefersAdaptiveThemes.value()) {
|
8
|
+
return false;
|
9
|
+
}
|
10
|
+
|
11
|
+
return helpers::vecContainsKeys(this->_registeredThemeNames, {"light", "dark"});
|
12
|
+
}
|
13
|
+
|
14
|
+
void core::UnistylesState::setTheme(std::string themeName) {
|
15
|
+
helpers::assertThat(*_rt, helpers::vecContainsKeys(this->_registeredThemeNames, {themeName}), "You're trying to set theme to: '" + std::string(themeName) + "', but it wasn't registered.");
|
16
|
+
|
17
|
+
if (themeName != this->_currentThemeName) {
|
18
|
+
this->_currentThemeName = themeName;
|
19
|
+
}
|
20
|
+
}
|
21
|
+
|
22
|
+
std::optional<std::string>& core::UnistylesState::getCurrentThemeName() {
|
23
|
+
return this->_currentThemeName;
|
24
|
+
}
|
25
|
+
|
26
|
+
jsi::Object core::UnistylesState::getJSTheme() {
|
27
|
+
auto hasSomeThemes = _registeredThemeNames.size() > 0;
|
28
|
+
|
29
|
+
// return empty object, if user didn't register any themes
|
30
|
+
if (!hasSomeThemes) {
|
31
|
+
return jsi::Object(*_rt);
|
32
|
+
}
|
33
|
+
|
34
|
+
helpers::assertThat(*_rt, _currentThemeName.has_value(), "one of your stylesheets is trying to get the theme, but no theme has been selected yet. Did you forget to select an initial theme?");
|
35
|
+
|
36
|
+
auto it = this->_jsThemes.find(_currentThemeName.value());
|
37
|
+
|
38
|
+
helpers::assertThat(*_rt, it != this->_jsThemes.end(), "you're trying to get theme '" + _currentThemeName.value() + "', but it was not registered. Did you forget to register it with StyleSheet.configure?");
|
39
|
+
|
40
|
+
auto maybeTheme = it->second.lock(*_rt);
|
41
|
+
|
42
|
+
helpers::assertThat(*_rt, maybeTheme.isObject(), "unable to retrieve your theme from C++ as it has already been garbage collected, likely due to multiple hot reloads. Please live reload the app.");
|
43
|
+
|
44
|
+
return maybeTheme.asObject(*_rt);
|
45
|
+
}
|
46
|
+
|
47
|
+
void core::UnistylesState::computeCurrentBreakpoint(int screenWidth) {
|
48
|
+
this->_currentBreakpointName = helpers::getBreakpointFromScreenWidth(
|
49
|
+
screenWidth,
|
50
|
+
this->_sortedBreakpointPairs
|
51
|
+
);
|
52
|
+
}
|
53
|
+
|
54
|
+
bool core::UnistylesState::hasTheme(std::string themeName) {
|
55
|
+
return helpers::vecContainsKeys(this->_registeredThemeNames, {themeName});
|
56
|
+
}
|
57
|
+
|
58
|
+
bool core::UnistylesState::hasInitialTheme() {
|
59
|
+
return this->_initialThemeName.has_value();
|
60
|
+
}
|
61
|
+
|
62
|
+
std::vector<std::string> core::UnistylesState::getRegisteredThemeNames() {
|
63
|
+
return std::vector<std::string>(this->_registeredThemeNames);
|
64
|
+
}
|
65
|
+
|
66
|
+
std::vector<std::pair<std::string, double>> core::UnistylesState::getSortedBreakpointPairs() {
|
67
|
+
return std::vector<std::pair<std::string, double>>(this->_sortedBreakpointPairs);
|
68
|
+
}
|
69
|
+
|
70
|
+
std::optional<std::string> core::UnistylesState::getInitialTheme() {
|
71
|
+
return this->_initialThemeName;
|
72
|
+
}
|
73
|
+
|
74
|
+
std::optional<std::string> core::UnistylesState::getCurrentBreakpointName() {
|
75
|
+
return this->_currentBreakpointName;
|
76
|
+
}
|
77
|
+
|
78
|
+
bool core::UnistylesState::getPrefersAdaptiveThemes() {
|
79
|
+
return this->_prefersAdaptiveThemes.has_value() && this->_prefersAdaptiveThemes.value();
|
80
|
+
}
|
81
|
+
|
82
|
+
void core::UnistylesState::registerProcessColorFunction(jsi::Function&& fn) {
|
83
|
+
this->_processColorFn = std::make_shared<jsi::Function>(std::move(fn));
|
84
|
+
}
|
85
|
+
|
86
|
+
int core::UnistylesState::parseColor(jsi::Value& maybeColor) {
|
87
|
+
if (!maybeColor.isString()) {
|
88
|
+
return 0;
|
89
|
+
}
|
90
|
+
|
91
|
+
// we must convert it to uint32_t first, otherwise color will be broken
|
92
|
+
uint32_t color = this->_processColorFn.get()->call(*_rt, maybeColor.asString(*_rt)).asNumber();
|
93
|
+
|
94
|
+
return color;
|
95
|
+
}
|