@abeman/react-native-nitro-blur 0.1.0
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/LICENSE +20 -0
- package/NitroBlur.podspec +29 -0
- package/README.md +200 -0
- package/android/CMakeLists.txt +24 -0
- package/android/build.gradle +120 -0
- package/android/src/main/AndroidManifest.xml +2 -0
- package/android/src/main/cpp/cpp-adapter.cpp +6 -0
- package/android/src/main/java/com/margelo/nitro/nitroblur/NitroBlur.kt +229 -0
- package/android/src/main/java/com/margelo/nitro/nitroblur/NitroBlurPackage.kt +31 -0
- package/android/src/main/java/com/margelo/nitro/nitroblur/NitroBlurTarget.kt +149 -0
- package/android/src/main/java/com/margelo/nitro/nitroblur/NitroBlurTargetViewGroupManager.kt +47 -0
- package/android/src/main/java/com/margelo/nitro/nitroblur/TintStyle.kt +85 -0
- package/ios/NitroBlur.swift +173 -0
- package/ios/NitroBlurTarget.swift +5 -0
- package/lib/module/NitroBlur.nitro.js +4 -0
- package/lib/module/NitroBlur.nitro.js.map +1 -0
- package/lib/module/NitroBlurTarget.nitro.js +4 -0
- package/lib/module/NitroBlurTarget.nitro.js.map +1 -0
- package/lib/module/index.js +114 -0
- package/lib/module/index.js.map +1 -0
- package/lib/module/package.json +1 -0
- package/lib/typescript/package.json +1 -0
- package/lib/typescript/src/NitroBlur.nitro.d.ts +25 -0
- package/lib/typescript/src/NitroBlur.nitro.d.ts.map +1 -0
- package/lib/typescript/src/NitroBlurTarget.nitro.d.ts +7 -0
- package/lib/typescript/src/NitroBlurTarget.nitro.d.ts.map +1 -0
- package/lib/typescript/src/index.d.ts +201 -0
- package/lib/typescript/src/index.d.ts.map +1 -0
- package/nitro.json +33 -0
- package/nitrogen/generated/android/c++/JBlurMethod.hpp +61 -0
- package/nitrogen/generated/android/c++/JBlurTint.hpp +115 -0
- package/nitrogen/generated/android/c++/JHybridNitroBlurSpec.cpp +99 -0
- package/nitrogen/generated/android/c++/JHybridNitroBlurSpec.hpp +72 -0
- package/nitrogen/generated/android/c++/JHybridNitroBlurTargetSpec.cpp +49 -0
- package/nitrogen/generated/android/c++/JHybridNitroBlurTargetSpec.hpp +63 -0
- package/nitrogen/generated/android/c++/views/JHybridNitroBlurStateUpdater.cpp +72 -0
- package/nitrogen/generated/android/c++/views/JHybridNitroBlurStateUpdater.hpp +49 -0
- package/nitrogen/generated/android/c++/views/JHybridNitroBlurTargetStateUpdater.cpp +53 -0
- package/nitrogen/generated/android/c++/views/JHybridNitroBlurTargetStateUpdater.hpp +49 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroblur/BlurMethod.kt +24 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroblur/BlurTint.kt +42 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroblur/HybridNitroBlurSpec.kt +81 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroblur/HybridNitroBlurTargetSpec.kt +53 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroblur/nitroblurOnLoad.kt +35 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroblur/views/HybridNitroBlurManager.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroblur/views/HybridNitroBlurStateUpdater.kt +23 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroblur/views/HybridNitroBlurTargetManager.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroblur/views/HybridNitroBlurTargetStateUpdater.kt +23 -0
- package/nitrogen/generated/android/nitroblur+autolinking.cmake +87 -0
- package/nitrogen/generated/android/nitroblur+autolinking.gradle +27 -0
- package/nitrogen/generated/android/nitroblurOnLoad.cpp +74 -0
- package/nitrogen/generated/android/nitroblurOnLoad.hpp +34 -0
- package/nitrogen/generated/ios/NitroBlur+autolinking.rb +60 -0
- package/nitrogen/generated/ios/NitroBlur-Swift-Cxx-Bridge.cpp +50 -0
- package/nitrogen/generated/ios/NitroBlur-Swift-Cxx-Bridge.hpp +57 -0
- package/nitrogen/generated/ios/NitroBlur-Swift-Cxx-Umbrella.hpp +52 -0
- package/nitrogen/generated/ios/NitroBlurAutolinking.mm +41 -0
- package/nitrogen/generated/ios/NitroBlurAutolinking.swift +38 -0
- package/nitrogen/generated/ios/c++/HybridNitroBlurSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridNitroBlurSpecSwift.hpp +110 -0
- package/nitrogen/generated/ios/c++/HybridNitroBlurTargetSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridNitroBlurTargetSpecSwift.hpp +75 -0
- package/nitrogen/generated/ios/c++/views/HybridNitroBlurComponent.mm +142 -0
- package/nitrogen/generated/ios/c++/views/HybridNitroBlurTargetComponent.mm +118 -0
- package/nitrogen/generated/ios/swift/BlurMethod.swift +44 -0
- package/nitrogen/generated/ios/swift/BlurTint.swift +116 -0
- package/nitrogen/generated/ios/swift/HybridNitroBlurSpec.swift +59 -0
- package/nitrogen/generated/ios/swift/HybridNitroBlurSpec_cxx.swift +200 -0
- package/nitrogen/generated/ios/swift/HybridNitroBlurTargetSpec.swift +55 -0
- package/nitrogen/generated/ios/swift/HybridNitroBlurTargetSpec_cxx.swift +147 -0
- package/nitrogen/generated/shared/c++/BlurMethod.hpp +80 -0
- package/nitrogen/generated/shared/c++/BlurTint.hpp +152 -0
- package/nitrogen/generated/shared/c++/HybridNitroBlurSpec.cpp +30 -0
- package/nitrogen/generated/shared/c++/HybridNitroBlurSpec.hpp +75 -0
- package/nitrogen/generated/shared/c++/HybridNitroBlurTargetSpec.cpp +21 -0
- package/nitrogen/generated/shared/c++/HybridNitroBlurTargetSpec.hpp +62 -0
- package/nitrogen/generated/shared/c++/views/HybridNitroBlurComponent.cpp +127 -0
- package/nitrogen/generated/shared/c++/views/HybridNitroBlurComponent.hpp +116 -0
- package/nitrogen/generated/shared/c++/views/HybridNitroBlurTargetComponent.cpp +72 -0
- package/nitrogen/generated/shared/c++/views/HybridNitroBlurTargetComponent.hpp +109 -0
- package/nitrogen/generated/shared/json/NitroBlurConfig.json +14 -0
- package/nitrogen/generated/shared/json/NitroBlurTargetConfig.json +9 -0
- package/package.json +174 -0
- package/src/NitroBlur.nitro.ts +56 -0
- package/src/NitroBlurTarget.nitro.ts +13 -0
- package/src/index.tsx +215 -0
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNitroBlurSpec.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#if __has_include(<NitroModules/HybridObject.hpp>)
|
|
11
|
+
#include <NitroModules/HybridObject.hpp>
|
|
12
|
+
#else
|
|
13
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
|
+
#endif
|
|
15
|
+
|
|
16
|
+
// Forward declaration of `BlurTint` to properly resolve imports.
|
|
17
|
+
namespace margelo::nitro::nitroblur { enum class BlurTint; }
|
|
18
|
+
// Forward declaration of `BlurMethod` to properly resolve imports.
|
|
19
|
+
namespace margelo::nitro::nitroblur { enum class BlurMethod; }
|
|
20
|
+
|
|
21
|
+
#include "BlurTint.hpp"
|
|
22
|
+
#include "BlurMethod.hpp"
|
|
23
|
+
|
|
24
|
+
namespace margelo::nitro::nitroblur {
|
|
25
|
+
|
|
26
|
+
using namespace margelo::nitro;
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* An abstract base class for `NitroBlur`
|
|
30
|
+
* Inherit this class to create instances of `HybridNitroBlurSpec` in C++.
|
|
31
|
+
* You must explicitly call `HybridObject`'s constructor yourself, because it is virtual.
|
|
32
|
+
* @example
|
|
33
|
+
* ```cpp
|
|
34
|
+
* class HybridNitroBlur: public HybridNitroBlurSpec {
|
|
35
|
+
* public:
|
|
36
|
+
* HybridNitroBlur(...): HybridObject(TAG) { ... }
|
|
37
|
+
* // ...
|
|
38
|
+
* };
|
|
39
|
+
* ```
|
|
40
|
+
*/
|
|
41
|
+
class HybridNitroBlurSpec: public virtual HybridObject {
|
|
42
|
+
public:
|
|
43
|
+
// Constructor
|
|
44
|
+
explicit HybridNitroBlurSpec(): HybridObject(TAG) { }
|
|
45
|
+
|
|
46
|
+
// Destructor
|
|
47
|
+
~HybridNitroBlurSpec() override = default;
|
|
48
|
+
|
|
49
|
+
public:
|
|
50
|
+
// Properties
|
|
51
|
+
virtual BlurTint getTint() = 0;
|
|
52
|
+
virtual void setTint(BlurTint tint) = 0;
|
|
53
|
+
virtual double getIntensity() = 0;
|
|
54
|
+
virtual void setIntensity(double intensity) = 0;
|
|
55
|
+
virtual double getBlurReductionFactor() = 0;
|
|
56
|
+
virtual void setBlurReductionFactor(double blurReductionFactor) = 0;
|
|
57
|
+
virtual double getBlurTargetId() = 0;
|
|
58
|
+
virtual void setBlurTargetId(double blurTargetId) = 0;
|
|
59
|
+
virtual BlurMethod getBlurMethod() = 0;
|
|
60
|
+
virtual void setBlurMethod(BlurMethod blurMethod) = 0;
|
|
61
|
+
|
|
62
|
+
public:
|
|
63
|
+
// Methods
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
protected:
|
|
67
|
+
// Hybrid Setup
|
|
68
|
+
void loadHybridMethods() override;
|
|
69
|
+
|
|
70
|
+
protected:
|
|
71
|
+
// Tag for logging
|
|
72
|
+
static constexpr auto TAG = "NitroBlur";
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
} // namespace margelo::nitro::nitroblur
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNitroBlurTargetSpec.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "HybridNitroBlurTargetSpec.hpp"
|
|
9
|
+
|
|
10
|
+
namespace margelo::nitro::nitroblur {
|
|
11
|
+
|
|
12
|
+
void HybridNitroBlurTargetSpec::loadHybridMethods() {
|
|
13
|
+
// load base methods/properties
|
|
14
|
+
HybridObject::loadHybridMethods();
|
|
15
|
+
// load custom methods/properties
|
|
16
|
+
registerHybrids(this, [](Prototype& prototype) {
|
|
17
|
+
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
} // namespace margelo::nitro::nitroblur
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNitroBlurTargetSpec.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#if __has_include(<NitroModules/HybridObject.hpp>)
|
|
11
|
+
#include <NitroModules/HybridObject.hpp>
|
|
12
|
+
#else
|
|
13
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
|
+
#endif
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
namespace margelo::nitro::nitroblur {
|
|
21
|
+
|
|
22
|
+
using namespace margelo::nitro;
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* An abstract base class for `NitroBlurTarget`
|
|
26
|
+
* Inherit this class to create instances of `HybridNitroBlurTargetSpec` in C++.
|
|
27
|
+
* You must explicitly call `HybridObject`'s constructor yourself, because it is virtual.
|
|
28
|
+
* @example
|
|
29
|
+
* ```cpp
|
|
30
|
+
* class HybridNitroBlurTarget: public HybridNitroBlurTargetSpec {
|
|
31
|
+
* public:
|
|
32
|
+
* HybridNitroBlurTarget(...): HybridObject(TAG) { ... }
|
|
33
|
+
* // ...
|
|
34
|
+
* };
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
class HybridNitroBlurTargetSpec: public virtual HybridObject {
|
|
38
|
+
public:
|
|
39
|
+
// Constructor
|
|
40
|
+
explicit HybridNitroBlurTargetSpec(): HybridObject(TAG) { }
|
|
41
|
+
|
|
42
|
+
// Destructor
|
|
43
|
+
~HybridNitroBlurTargetSpec() override = default;
|
|
44
|
+
|
|
45
|
+
public:
|
|
46
|
+
// Properties
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
public:
|
|
50
|
+
// Methods
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
protected:
|
|
54
|
+
// Hybrid Setup
|
|
55
|
+
void loadHybridMethods() override;
|
|
56
|
+
|
|
57
|
+
protected:
|
|
58
|
+
// Tag for logging
|
|
59
|
+
static constexpr auto TAG = "NitroBlurTarget";
|
|
60
|
+
};
|
|
61
|
+
|
|
62
|
+
} // namespace margelo::nitro::nitroblur
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNitroBlurComponent.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "HybridNitroBlurComponent.hpp"
|
|
9
|
+
|
|
10
|
+
#include <string>
|
|
11
|
+
#include <exception>
|
|
12
|
+
#include <utility>
|
|
13
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
14
|
+
#include <NitroModules/JSIConverter.hpp>
|
|
15
|
+
#include <NitroModules/PropNameIDCache.hpp>
|
|
16
|
+
#include <react/renderer/core/RawValue.h>
|
|
17
|
+
#include <react/renderer/core/ShadowNode.h>
|
|
18
|
+
#include <react/renderer/core/ComponentDescriptor.h>
|
|
19
|
+
#include <react/renderer/components/view/ViewProps.h>
|
|
20
|
+
|
|
21
|
+
namespace margelo::nitro::nitroblur::views {
|
|
22
|
+
|
|
23
|
+
extern const char HybridNitroBlurComponentName[] = "NitroBlur";
|
|
24
|
+
|
|
25
|
+
HybridNitroBlurProps::HybridNitroBlurProps(const react::PropsParserContext& context,
|
|
26
|
+
const HybridNitroBlurProps& sourceProps,
|
|
27
|
+
const react::RawProps& rawProps):
|
|
28
|
+
react::ViewProps(context, sourceProps, rawProps, filterObjectKeys),
|
|
29
|
+
tint([&]() -> CachedProp<BlurTint> {
|
|
30
|
+
try {
|
|
31
|
+
const react::RawValue* rawValue = rawProps.at("tint", nullptr, nullptr);
|
|
32
|
+
if (rawValue == nullptr) return sourceProps.tint;
|
|
33
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
34
|
+
return CachedProp<BlurTint>::fromRawValue(*runtime, value, sourceProps.tint);
|
|
35
|
+
} catch (const std::exception& exc) {
|
|
36
|
+
throw std::runtime_error(std::string("NitroBlur.tint: ") + exc.what());
|
|
37
|
+
}
|
|
38
|
+
}()),
|
|
39
|
+
intensity([&]() -> CachedProp<double> {
|
|
40
|
+
try {
|
|
41
|
+
const react::RawValue* rawValue = rawProps.at("intensity", nullptr, nullptr);
|
|
42
|
+
if (rawValue == nullptr) return sourceProps.intensity;
|
|
43
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
44
|
+
return CachedProp<double>::fromRawValue(*runtime, value, sourceProps.intensity);
|
|
45
|
+
} catch (const std::exception& exc) {
|
|
46
|
+
throw std::runtime_error(std::string("NitroBlur.intensity: ") + exc.what());
|
|
47
|
+
}
|
|
48
|
+
}()),
|
|
49
|
+
blurReductionFactor([&]() -> CachedProp<double> {
|
|
50
|
+
try {
|
|
51
|
+
const react::RawValue* rawValue = rawProps.at("blurReductionFactor", nullptr, nullptr);
|
|
52
|
+
if (rawValue == nullptr) return sourceProps.blurReductionFactor;
|
|
53
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
54
|
+
return CachedProp<double>::fromRawValue(*runtime, value, sourceProps.blurReductionFactor);
|
|
55
|
+
} catch (const std::exception& exc) {
|
|
56
|
+
throw std::runtime_error(std::string("NitroBlur.blurReductionFactor: ") + exc.what());
|
|
57
|
+
}
|
|
58
|
+
}()),
|
|
59
|
+
blurTargetId([&]() -> CachedProp<double> {
|
|
60
|
+
try {
|
|
61
|
+
const react::RawValue* rawValue = rawProps.at("blurTargetId", nullptr, nullptr);
|
|
62
|
+
if (rawValue == nullptr) return sourceProps.blurTargetId;
|
|
63
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
64
|
+
return CachedProp<double>::fromRawValue(*runtime, value, sourceProps.blurTargetId);
|
|
65
|
+
} catch (const std::exception& exc) {
|
|
66
|
+
throw std::runtime_error(std::string("NitroBlur.blurTargetId: ") + exc.what());
|
|
67
|
+
}
|
|
68
|
+
}()),
|
|
69
|
+
blurMethod([&]() -> CachedProp<BlurMethod> {
|
|
70
|
+
try {
|
|
71
|
+
const react::RawValue* rawValue = rawProps.at("blurMethod", nullptr, nullptr);
|
|
72
|
+
if (rawValue == nullptr) return sourceProps.blurMethod;
|
|
73
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
74
|
+
return CachedProp<BlurMethod>::fromRawValue(*runtime, value, sourceProps.blurMethod);
|
|
75
|
+
} catch (const std::exception& exc) {
|
|
76
|
+
throw std::runtime_error(std::string("NitroBlur.blurMethod: ") + exc.what());
|
|
77
|
+
}
|
|
78
|
+
}()),
|
|
79
|
+
hybridRef([&]() -> CachedProp<std::optional<std::function<void(const std::shared_ptr<HybridNitroBlurSpec>& /* ref */)>>> {
|
|
80
|
+
try {
|
|
81
|
+
const react::RawValue* rawValue = rawProps.at("hybridRef", nullptr, nullptr);
|
|
82
|
+
if (rawValue == nullptr) return sourceProps.hybridRef;
|
|
83
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
84
|
+
return CachedProp<std::optional<std::function<void(const std::shared_ptr<HybridNitroBlurSpec>& /* ref */)>>>::fromRawValue(*runtime, value.asObject(*runtime).getProperty(*runtime, PropNameIDCache::get(*runtime, "f")), sourceProps.hybridRef);
|
|
85
|
+
} catch (const std::exception& exc) {
|
|
86
|
+
throw std::runtime_error(std::string("NitroBlur.hybridRef: ") + exc.what());
|
|
87
|
+
}
|
|
88
|
+
}()) { }
|
|
89
|
+
|
|
90
|
+
bool HybridNitroBlurProps::filterObjectKeys(const std::string& propName) {
|
|
91
|
+
switch (hashString(propName)) {
|
|
92
|
+
case hashString("tint"): return true;
|
|
93
|
+
case hashString("intensity"): return true;
|
|
94
|
+
case hashString("blurReductionFactor"): return true;
|
|
95
|
+
case hashString("blurTargetId"): return true;
|
|
96
|
+
case hashString("blurMethod"): return true;
|
|
97
|
+
case hashString("hybridRef"): return true;
|
|
98
|
+
default: return false;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
HybridNitroBlurComponentDescriptor::HybridNitroBlurComponentDescriptor(const react::ComponentDescriptorParameters& parameters)
|
|
103
|
+
: ConcreteComponentDescriptor(parameters,
|
|
104
|
+
react::RawPropsParser(/* enableJsiParser */ true)) {}
|
|
105
|
+
|
|
106
|
+
std::shared_ptr<const react::Props> HybridNitroBlurComponentDescriptor::cloneProps(const react::PropsParserContext& context,
|
|
107
|
+
const std::shared_ptr<const react::Props>& props,
|
|
108
|
+
react::RawProps rawProps) const {
|
|
109
|
+
// 1. Prepare raw props parser
|
|
110
|
+
rawProps.parse(rawPropsParser_);
|
|
111
|
+
// 2. Copy props with Nitro's cached copy constructor
|
|
112
|
+
return HybridNitroBlurShadowNode::Props(context, /* & */ rawProps, props);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
#ifdef ANDROID
|
|
116
|
+
void HybridNitroBlurComponentDescriptor::adopt(react::ShadowNode& shadowNode) const {
|
|
117
|
+
// This is called immediately after `ShadowNode` is created, cloned or in progress.
|
|
118
|
+
// On Android, we need to wrap props in our state, which gets routed through Java and later unwrapped in JNI/C++.
|
|
119
|
+
auto& concreteShadowNode = static_cast<HybridNitroBlurShadowNode&>(shadowNode);
|
|
120
|
+
const std::shared_ptr<const HybridNitroBlurProps>& constProps = concreteShadowNode.getConcreteSharedProps();
|
|
121
|
+
const std::shared_ptr<HybridNitroBlurProps>& props = std::const_pointer_cast<HybridNitroBlurProps>(constProps);
|
|
122
|
+
HybridNitroBlurState state{props};
|
|
123
|
+
concreteShadowNode.setStateData(std::move(state));
|
|
124
|
+
}
|
|
125
|
+
#endif
|
|
126
|
+
|
|
127
|
+
} // namespace margelo::nitro::nitroblur::views
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNitroBlurComponent.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include <optional>
|
|
11
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
12
|
+
#include <NitroModules/NitroHash.hpp>
|
|
13
|
+
#include <NitroModules/CachedProp.hpp>
|
|
14
|
+
#include <react/renderer/core/ConcreteComponentDescriptor.h>
|
|
15
|
+
#include <react/renderer/core/PropsParserContext.h>
|
|
16
|
+
#include <react/renderer/components/view/ConcreteViewShadowNode.h>
|
|
17
|
+
#include <react/renderer/components/view/ViewProps.h>
|
|
18
|
+
|
|
19
|
+
#include "BlurTint.hpp"
|
|
20
|
+
#include "BlurMethod.hpp"
|
|
21
|
+
#include <memory>
|
|
22
|
+
#include "HybridNitroBlurSpec.hpp"
|
|
23
|
+
#include <functional>
|
|
24
|
+
#include <optional>
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::nitroblur::views {
|
|
27
|
+
|
|
28
|
+
using namespace facebook;
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* The name of the actual native View.
|
|
32
|
+
*/
|
|
33
|
+
extern const char HybridNitroBlurComponentName[];
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Props for the "NitroBlur" View.
|
|
37
|
+
*/
|
|
38
|
+
class HybridNitroBlurProps final: public react::ViewProps {
|
|
39
|
+
public:
|
|
40
|
+
HybridNitroBlurProps() = default;
|
|
41
|
+
HybridNitroBlurProps(const react::PropsParserContext& context,
|
|
42
|
+
const HybridNitroBlurProps& sourceProps,
|
|
43
|
+
const react::RawProps& rawProps);
|
|
44
|
+
|
|
45
|
+
public:
|
|
46
|
+
CachedProp<BlurTint> tint;
|
|
47
|
+
CachedProp<double> intensity;
|
|
48
|
+
CachedProp<double> blurReductionFactor;
|
|
49
|
+
CachedProp<double> blurTargetId;
|
|
50
|
+
CachedProp<BlurMethod> blurMethod;
|
|
51
|
+
CachedProp<std::optional<std::function<void(const std::shared_ptr<HybridNitroBlurSpec>& /* ref */)>>> hybridRef;
|
|
52
|
+
|
|
53
|
+
private:
|
|
54
|
+
static bool filterObjectKeys(const std::string& propName);
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* State for the "NitroBlur" View.
|
|
59
|
+
*/
|
|
60
|
+
class HybridNitroBlurState final {
|
|
61
|
+
public:
|
|
62
|
+
HybridNitroBlurState() = default;
|
|
63
|
+
explicit HybridNitroBlurState(const std::shared_ptr<HybridNitroBlurProps>& props):
|
|
64
|
+
_props(props) {}
|
|
65
|
+
|
|
66
|
+
public:
|
|
67
|
+
[[nodiscard]]
|
|
68
|
+
const std::shared_ptr<HybridNitroBlurProps>& getProps() const {
|
|
69
|
+
return _props;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
public:
|
|
73
|
+
#ifdef ANDROID
|
|
74
|
+
HybridNitroBlurState(const HybridNitroBlurState& /* previousState */, folly::dynamic /* data */) {}
|
|
75
|
+
folly::dynamic getDynamic() const {
|
|
76
|
+
throw std::runtime_error("HybridNitroBlurState does not support folly!");
|
|
77
|
+
}
|
|
78
|
+
react::MapBuffer getMapBuffer() const {
|
|
79
|
+
throw std::runtime_error("HybridNitroBlurState does not support MapBuffer!");
|
|
80
|
+
};
|
|
81
|
+
#endif
|
|
82
|
+
|
|
83
|
+
private:
|
|
84
|
+
std::shared_ptr<HybridNitroBlurProps> _props;
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
/**
|
|
88
|
+
* The Shadow Node for the "NitroBlur" View.
|
|
89
|
+
*/
|
|
90
|
+
using HybridNitroBlurShadowNode = react::ConcreteViewShadowNode<HybridNitroBlurComponentName /* "HybridNitroBlur" */,
|
|
91
|
+
HybridNitroBlurProps /* custom props */,
|
|
92
|
+
react::ViewEventEmitter /* default */,
|
|
93
|
+
HybridNitroBlurState /* custom state */>;
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* The Component Descriptor for the "NitroBlur" View.
|
|
97
|
+
*/
|
|
98
|
+
class HybridNitroBlurComponentDescriptor final: public react::ConcreteComponentDescriptor<HybridNitroBlurShadowNode> {
|
|
99
|
+
public:
|
|
100
|
+
explicit HybridNitroBlurComponentDescriptor(const react::ComponentDescriptorParameters& parameters);
|
|
101
|
+
|
|
102
|
+
public:
|
|
103
|
+
/**
|
|
104
|
+
* A faster path for cloning props - reuses the caching logic from `HybridNitroBlurProps`.
|
|
105
|
+
*/
|
|
106
|
+
std::shared_ptr<const react::Props> cloneProps(const react::PropsParserContext& context,
|
|
107
|
+
const std::shared_ptr<const react::Props>& props,
|
|
108
|
+
react::RawProps rawProps) const override;
|
|
109
|
+
#ifdef ANDROID
|
|
110
|
+
void adopt(react::ShadowNode& shadowNode) const override;
|
|
111
|
+
#endif
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
/* The actual view for "NitroBlur" needs to be implemented in platform-specific code. */
|
|
115
|
+
|
|
116
|
+
} // namespace margelo::nitro::nitroblur::views
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNitroBlurTargetComponent.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "HybridNitroBlurTargetComponent.hpp"
|
|
9
|
+
|
|
10
|
+
#include <string>
|
|
11
|
+
#include <exception>
|
|
12
|
+
#include <utility>
|
|
13
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
14
|
+
#include <NitroModules/JSIConverter.hpp>
|
|
15
|
+
#include <NitroModules/PropNameIDCache.hpp>
|
|
16
|
+
#include <react/renderer/core/RawValue.h>
|
|
17
|
+
#include <react/renderer/core/ShadowNode.h>
|
|
18
|
+
#include <react/renderer/core/ComponentDescriptor.h>
|
|
19
|
+
#include <react/renderer/components/view/ViewProps.h>
|
|
20
|
+
|
|
21
|
+
namespace margelo::nitro::nitroblur::views {
|
|
22
|
+
|
|
23
|
+
extern const char HybridNitroBlurTargetComponentName[] = "NitroBlurTarget";
|
|
24
|
+
|
|
25
|
+
HybridNitroBlurTargetProps::HybridNitroBlurTargetProps(const react::PropsParserContext& context,
|
|
26
|
+
const HybridNitroBlurTargetProps& sourceProps,
|
|
27
|
+
const react::RawProps& rawProps):
|
|
28
|
+
react::ViewProps(context, sourceProps, rawProps, filterObjectKeys),
|
|
29
|
+
hybridRef([&]() -> CachedProp<std::optional<std::function<void(const std::shared_ptr<HybridNitroBlurTargetSpec>& /* ref */)>>> {
|
|
30
|
+
try {
|
|
31
|
+
const react::RawValue* rawValue = rawProps.at("hybridRef", nullptr, nullptr);
|
|
32
|
+
if (rawValue == nullptr) return sourceProps.hybridRef;
|
|
33
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
34
|
+
return CachedProp<std::optional<std::function<void(const std::shared_ptr<HybridNitroBlurTargetSpec>& /* ref */)>>>::fromRawValue(*runtime, value.asObject(*runtime).getProperty(*runtime, PropNameIDCache::get(*runtime, "f")), sourceProps.hybridRef);
|
|
35
|
+
} catch (const std::exception& exc) {
|
|
36
|
+
throw std::runtime_error(std::string("NitroBlurTarget.hybridRef: ") + exc.what());
|
|
37
|
+
}
|
|
38
|
+
}()) { }
|
|
39
|
+
|
|
40
|
+
bool HybridNitroBlurTargetProps::filterObjectKeys(const std::string& propName) {
|
|
41
|
+
switch (hashString(propName)) {
|
|
42
|
+
case hashString("hybridRef"): return true;
|
|
43
|
+
default: return false;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
HybridNitroBlurTargetComponentDescriptor::HybridNitroBlurTargetComponentDescriptor(const react::ComponentDescriptorParameters& parameters)
|
|
48
|
+
: ConcreteComponentDescriptor(parameters,
|
|
49
|
+
react::RawPropsParser(/* enableJsiParser */ true)) {}
|
|
50
|
+
|
|
51
|
+
std::shared_ptr<const react::Props> HybridNitroBlurTargetComponentDescriptor::cloneProps(const react::PropsParserContext& context,
|
|
52
|
+
const std::shared_ptr<const react::Props>& props,
|
|
53
|
+
react::RawProps rawProps) const {
|
|
54
|
+
// 1. Prepare raw props parser
|
|
55
|
+
rawProps.parse(rawPropsParser_);
|
|
56
|
+
// 2. Copy props with Nitro's cached copy constructor
|
|
57
|
+
return HybridNitroBlurTargetShadowNode::Props(context, /* & */ rawProps, props);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
#ifdef ANDROID
|
|
61
|
+
void HybridNitroBlurTargetComponentDescriptor::adopt(react::ShadowNode& shadowNode) const {
|
|
62
|
+
// This is called immediately after `ShadowNode` is created, cloned or in progress.
|
|
63
|
+
// On Android, we need to wrap props in our state, which gets routed through Java and later unwrapped in JNI/C++.
|
|
64
|
+
auto& concreteShadowNode = static_cast<HybridNitroBlurTargetShadowNode&>(shadowNode);
|
|
65
|
+
const std::shared_ptr<const HybridNitroBlurTargetProps>& constProps = concreteShadowNode.getConcreteSharedProps();
|
|
66
|
+
const std::shared_ptr<HybridNitroBlurTargetProps>& props = std::const_pointer_cast<HybridNitroBlurTargetProps>(constProps);
|
|
67
|
+
HybridNitroBlurTargetState state{props};
|
|
68
|
+
concreteShadowNode.setStateData(std::move(state));
|
|
69
|
+
}
|
|
70
|
+
#endif
|
|
71
|
+
|
|
72
|
+
} // namespace margelo::nitro::nitroblur::views
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNitroBlurTargetComponent.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include <optional>
|
|
11
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
12
|
+
#include <NitroModules/NitroHash.hpp>
|
|
13
|
+
#include <NitroModules/CachedProp.hpp>
|
|
14
|
+
#include <react/renderer/core/ConcreteComponentDescriptor.h>
|
|
15
|
+
#include <react/renderer/core/PropsParserContext.h>
|
|
16
|
+
#include <react/renderer/components/view/ConcreteViewShadowNode.h>
|
|
17
|
+
#include <react/renderer/components/view/ViewProps.h>
|
|
18
|
+
|
|
19
|
+
#include <memory>
|
|
20
|
+
#include "HybridNitroBlurTargetSpec.hpp"
|
|
21
|
+
#include <functional>
|
|
22
|
+
#include <optional>
|
|
23
|
+
|
|
24
|
+
namespace margelo::nitro::nitroblur::views {
|
|
25
|
+
|
|
26
|
+
using namespace facebook;
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* The name of the actual native View.
|
|
30
|
+
*/
|
|
31
|
+
extern const char HybridNitroBlurTargetComponentName[];
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Props for the "NitroBlurTarget" View.
|
|
35
|
+
*/
|
|
36
|
+
class HybridNitroBlurTargetProps final: public react::ViewProps {
|
|
37
|
+
public:
|
|
38
|
+
HybridNitroBlurTargetProps() = default;
|
|
39
|
+
HybridNitroBlurTargetProps(const react::PropsParserContext& context,
|
|
40
|
+
const HybridNitroBlurTargetProps& sourceProps,
|
|
41
|
+
const react::RawProps& rawProps);
|
|
42
|
+
|
|
43
|
+
public:
|
|
44
|
+
CachedProp<std::optional<std::function<void(const std::shared_ptr<HybridNitroBlurTargetSpec>& /* ref */)>>> hybridRef;
|
|
45
|
+
|
|
46
|
+
private:
|
|
47
|
+
static bool filterObjectKeys(const std::string& propName);
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* State for the "NitroBlurTarget" View.
|
|
52
|
+
*/
|
|
53
|
+
class HybridNitroBlurTargetState final {
|
|
54
|
+
public:
|
|
55
|
+
HybridNitroBlurTargetState() = default;
|
|
56
|
+
explicit HybridNitroBlurTargetState(const std::shared_ptr<HybridNitroBlurTargetProps>& props):
|
|
57
|
+
_props(props) {}
|
|
58
|
+
|
|
59
|
+
public:
|
|
60
|
+
[[nodiscard]]
|
|
61
|
+
const std::shared_ptr<HybridNitroBlurTargetProps>& getProps() const {
|
|
62
|
+
return _props;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
public:
|
|
66
|
+
#ifdef ANDROID
|
|
67
|
+
HybridNitroBlurTargetState(const HybridNitroBlurTargetState& /* previousState */, folly::dynamic /* data */) {}
|
|
68
|
+
folly::dynamic getDynamic() const {
|
|
69
|
+
throw std::runtime_error("HybridNitroBlurTargetState does not support folly!");
|
|
70
|
+
}
|
|
71
|
+
react::MapBuffer getMapBuffer() const {
|
|
72
|
+
throw std::runtime_error("HybridNitroBlurTargetState does not support MapBuffer!");
|
|
73
|
+
};
|
|
74
|
+
#endif
|
|
75
|
+
|
|
76
|
+
private:
|
|
77
|
+
std::shared_ptr<HybridNitroBlurTargetProps> _props;
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* The Shadow Node for the "NitroBlurTarget" View.
|
|
82
|
+
*/
|
|
83
|
+
using HybridNitroBlurTargetShadowNode = react::ConcreteViewShadowNode<HybridNitroBlurTargetComponentName /* "HybridNitroBlurTarget" */,
|
|
84
|
+
HybridNitroBlurTargetProps /* custom props */,
|
|
85
|
+
react::ViewEventEmitter /* default */,
|
|
86
|
+
HybridNitroBlurTargetState /* custom state */>;
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* The Component Descriptor for the "NitroBlurTarget" View.
|
|
90
|
+
*/
|
|
91
|
+
class HybridNitroBlurTargetComponentDescriptor final: public react::ConcreteComponentDescriptor<HybridNitroBlurTargetShadowNode> {
|
|
92
|
+
public:
|
|
93
|
+
explicit HybridNitroBlurTargetComponentDescriptor(const react::ComponentDescriptorParameters& parameters);
|
|
94
|
+
|
|
95
|
+
public:
|
|
96
|
+
/**
|
|
97
|
+
* A faster path for cloning props - reuses the caching logic from `HybridNitroBlurTargetProps`.
|
|
98
|
+
*/
|
|
99
|
+
std::shared_ptr<const react::Props> cloneProps(const react::PropsParserContext& context,
|
|
100
|
+
const std::shared_ptr<const react::Props>& props,
|
|
101
|
+
react::RawProps rawProps) const override;
|
|
102
|
+
#ifdef ANDROID
|
|
103
|
+
void adopt(react::ShadowNode& shadowNode) const override;
|
|
104
|
+
#endif
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
/* The actual view for "NitroBlurTarget" needs to be implemented in platform-specific code. */
|
|
108
|
+
|
|
109
|
+
} // namespace margelo::nitro::nitroblur::views
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
{
|
|
2
|
+
"uiViewClassName": "NitroBlur",
|
|
3
|
+
"supportsRawText": false,
|
|
4
|
+
"bubblingEventTypes": {},
|
|
5
|
+
"directEventTypes": {},
|
|
6
|
+
"validAttributes": {
|
|
7
|
+
"tint": true,
|
|
8
|
+
"intensity": true,
|
|
9
|
+
"blurReductionFactor": true,
|
|
10
|
+
"blurTargetId": true,
|
|
11
|
+
"blurMethod": true,
|
|
12
|
+
"hybridRef": true
|
|
13
|
+
}
|
|
14
|
+
}
|