react-native-turbo-tracking-transparency 0.2.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 ADDED
@@ -0,0 +1,20 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2026 Solanki Yogesh
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy
5
+ of this software and associated documentation files (the "Software"), to deal
6
+ in the Software without restriction, including without limitation the rights
7
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
+ copies of the Software, and to permit persons to whom the Software is
9
+ furnished to do so, subject to the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be included in all
12
+ copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,86 @@
1
+ # react-native-turbo-tracking-transparency ๐Ÿ›ก๏ธ
2
+
3
+ A high-performance **React Native Turbo Module** for handling iOS App Tracking Transparency (ATT). Built with the new React Native architecture for maximum efficiency and seamless Type-Safety.
4
+
5
+ [![npm version](https://img.shields.io/npm/v/react-native-turbo-tracking-transparency.svg?style=flat-square)](https://www.npmjs.com/package/react-native-turbo-tracking-transparency)
6
+ [![license](https://img.shields.io/npm/l/react-native-turbo-tracking-transparency.svg?style=flat-square)](https://github.com/SolankiYogesh/react-native-turbo-tracking-transparency/blob/main/LICENSE)
7
+
8
+ ## โœจ Features
9
+
10
+ - ๐ŸŽ๏ธ **Turbo Module Support**: Utilizes the New Architecture (JSI) for near-instant native calls.
11
+ - ๐Ÿ“ **Type-Safe**: Full TypeScript support with explicit Enums for tracking status.
12
+ - ๐Ÿ“ฑ **iOS 14+ Ready**: Implements `ATTrackingManager` following Apple's privacy guidelines.
13
+ - ๐Ÿ›ก๏ธ **Safe Fallbacks**: Gracefully handles non-iOS platforms.
14
+
15
+ ## ๐Ÿ“ฆ Installation
16
+
17
+ ```sh
18
+ npm install react-native-turbo-tracking-transparency
19
+ # or
20
+ yarn add react-native-turbo-tracking-transparency
21
+ ```
22
+
23
+ Don't forget to install pods:
24
+
25
+ ```sh
26
+ npx pod-install
27
+ ```
28
+
29
+ ## ๐Ÿ› ๏ธ iOS Setup
30
+
31
+ You **must** add the `NSUserTrackingUsageDescription` key to your `Info.plist` file. This message will be displayed in the permission prompt.
32
+
33
+ ```xml
34
+ <key>NSUserTrackingUsageDescription</key>
35
+ <string>We use your data to provide a personalized experience and show relevant ads.</string>
36
+ ```
37
+
38
+ ## ๐Ÿš€ Usage
39
+
40
+ ```tsx
41
+ import {
42
+ getTrackingStatus,
43
+ requestTrackingPermission,
44
+ TrackingStatusEnum
45
+ } from 'react-native-turbo-tracking-transparency';
46
+
47
+ // 1. Get current status
48
+ const status = getTrackingStatus();
49
+ console.log('Current tracking status:', status);
50
+
51
+ // 2. Request permission
52
+ const requestStatus = await requestTrackingPermission();
53
+ if (requestStatus === TrackingStatusEnum.Authorized) {
54
+ // Safe to use IDFA
55
+ }
56
+ ```
57
+
58
+ ### Tracking Status Values
59
+
60
+ | Value | Description |
61
+ | :--- | :--- |
62
+ | `authorized` | Permission granted. |
63
+ | `denied` | Permission denied by user. |
64
+ | `restricted` | Permission restricted (e.g., parental controls). |
65
+ | `not-determined` | Permission not yet requested. |
66
+ | `unavailable` | ATT is not available on this device/platform. |
67
+
68
+ ## ๐Ÿงช Testing
69
+
70
+ The library includes comprehensive tests using Jest.
71
+
72
+ ```sh
73
+ yarn test
74
+ ```
75
+
76
+ ## ๐Ÿค Contributing
77
+
78
+ Contributions are welcome! See the [Contributing Guide](CONTRIBUTING.md) to learn how to get started.
79
+
80
+ ## ๐Ÿ“„ License
81
+
82
+ MIT
83
+
84
+ ---
85
+
86
+ Made with โค๏ธ by [Solanki Yogesh](https://github.com/SolankiYogesh)
@@ -0,0 +1,23 @@
1
+ require "json"
2
+
3
+ package = JSON.parse(File.read(File.join(__dir__, "package.json")))
4
+
5
+ Pod::Spec.new do |s|
6
+ s.name = "TurboTrackingTransparency"
7
+ s.version = package["version"]
8
+ s.summary = package["description"]
9
+ s.homepage = package["homepage"]
10
+ s.license = package["license"]
11
+ s.authors = package["author"]
12
+
13
+ s.platforms = { :ios => min_ios_version_supported }
14
+ s.source = { :git => "https://github.com/SolankiYogesh/react-native-turbo-tracking-transparency.git", :tag => "#{s.version}" }
15
+
16
+ s.source_files = "ios/**/*.{h,m,mm,swift,cpp}"
17
+ s.private_header_files = "ios/**/*.h"
18
+
19
+ s.frameworks = "AppTrackingTransparency"
20
+
21
+ install_modules_dependencies(s)
22
+ end
23
+
@@ -0,0 +1,67 @@
1
+ buildscript {
2
+ ext.TurboTrackingTransparency = [
3
+ kotlinVersion: "2.0.21",
4
+ minSdkVersion: 24,
5
+ compileSdkVersion: 36,
6
+ targetSdkVersion: 36
7
+ ]
8
+
9
+ ext.getExtOrDefault = { prop ->
10
+ if (rootProject.ext.has(prop)) {
11
+ return rootProject.ext.get(prop)
12
+ }
13
+
14
+ return TurboTrackingTransparency[prop]
15
+ }
16
+
17
+ repositories {
18
+ google()
19
+ mavenCentral()
20
+ }
21
+
22
+ dependencies {
23
+ classpath "com.android.tools.build:gradle:8.7.2"
24
+ // noinspection DifferentKotlinGradleVersion
25
+ classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:${getExtOrDefault('kotlinVersion')}"
26
+ }
27
+ }
28
+
29
+
30
+ apply plugin: "com.android.library"
31
+ apply plugin: "kotlin-android"
32
+
33
+ apply plugin: "com.facebook.react"
34
+
35
+ android {
36
+ namespace "com.turbotrackingtransparency"
37
+
38
+ compileSdkVersion getExtOrDefault("compileSdkVersion")
39
+
40
+ defaultConfig {
41
+ minSdkVersion getExtOrDefault("minSdkVersion")
42
+ targetSdkVersion getExtOrDefault("targetSdkVersion")
43
+ }
44
+
45
+ buildFeatures {
46
+ buildConfig true
47
+ }
48
+
49
+ buildTypes {
50
+ release {
51
+ minifyEnabled false
52
+ }
53
+ }
54
+
55
+ lint {
56
+ disable "GradleCompatible"
57
+ }
58
+
59
+ compileOptions {
60
+ sourceCompatibility JavaVersion.VERSION_1_8
61
+ targetCompatibility JavaVersion.VERSION_1_8
62
+ }
63
+ }
64
+
65
+ dependencies {
66
+ implementation "com.facebook.react:react-android"
67
+ }
@@ -0,0 +1,2 @@
1
+ <manifest xmlns:android="http://schemas.android.com/apk/res/android">
2
+ </manifest>
@@ -0,0 +1,19 @@
1
+ package com.turbotrackingtransparency
2
+
3
+ import com.facebook.react.bridge.ReactApplicationContext
4
+
5
+ class TurboTrackingTransparencyModule(reactContext: ReactApplicationContext) :
6
+ NativeTurboTrackingTransparencySpec(reactContext) {
7
+
8
+ override fun getTrackingStatus(): String {
9
+ return "authorized"
10
+ }
11
+
12
+ override fun requestTrackingPermission(promise: com.facebook.react.bridge.Promise) {
13
+ promise.resolve("authorized")
14
+ }
15
+
16
+ companion object {
17
+ const val NAME = NativeTurboTrackingTransparencySpec.NAME
18
+ }
19
+ }
@@ -0,0 +1,33 @@
1
+ package com.turbotrackingtransparency
2
+
3
+ import com.facebook.react.BaseReactPackage
4
+ import com.facebook.react.bridge.NativeModule
5
+ import com.facebook.react.bridge.ReactApplicationContext
6
+ import com.facebook.react.module.model.ReactModuleInfo
7
+ import com.facebook.react.module.model.ReactModuleInfoProvider
8
+ import java.util.HashMap
9
+
10
+ class TurboTrackingTransparencyPackage : BaseReactPackage() {
11
+ override fun getModule(name: String, reactContext: ReactApplicationContext): NativeModule? {
12
+ return if (name == TurboTrackingTransparencyModule.NAME) {
13
+ TurboTrackingTransparencyModule(reactContext)
14
+ } else {
15
+ null
16
+ }
17
+ }
18
+
19
+ override fun getReactModuleInfoProvider(): ReactModuleInfoProvider {
20
+ return ReactModuleInfoProvider {
21
+ val moduleInfos: MutableMap<String, ReactModuleInfo> = HashMap()
22
+ moduleInfos[TurboTrackingTransparencyModule.NAME] = ReactModuleInfo(
23
+ TurboTrackingTransparencyModule.NAME,
24
+ TurboTrackingTransparencyModule.NAME,
25
+ false, // canOverrideExistingModule
26
+ false, // needsEagerInit
27
+ false, // isCxxModule
28
+ true // isTurboModule
29
+ )
30
+ moduleInfos
31
+ }
32
+ }
33
+ }
@@ -0,0 +1,5 @@
1
+ #import <TurboTrackingTransparencySpec/TurboTrackingTransparencySpec.h>
2
+
3
+ @interface TurboTrackingTransparency : NSObject <NativeTurboTrackingTransparencySpec>
4
+
5
+ @end
@@ -0,0 +1,55 @@
1
+ #import "TurboTrackingTransparency.h"
2
+ #import <AppTrackingTransparency/AppTrackingTransparency.h>
3
+ #import <Foundation/Foundation.h>
4
+ #include <memory>
5
+
6
+ @implementation TurboTrackingTransparency
7
+
8
+ - (std::shared_ptr<facebook::react::TurboModule>)getTurboModule:
9
+ (const facebook::react::ObjCTurboModule::InitParams &)params {
10
+ return std::make_shared<
11
+ facebook::react::NativeTurboTrackingTransparencySpecJSI>(params);
12
+ }
13
+
14
+ + (NSString *)moduleName {
15
+ return @"TurboTrackingTransparency";
16
+ }
17
+
18
+ - (NSString *)getTrackingStatus {
19
+ if (@available(iOS 14, *)) {
20
+ ATTrackingManagerAuthorizationStatus status =
21
+ [ATTrackingManager trackingAuthorizationStatus];
22
+ return [self mapStatusToString:status];
23
+ } else {
24
+ return @"unavailable";
25
+ }
26
+ }
27
+
28
+ - (void)requestTrackingPermission:(nonnull RCTPromiseResolveBlock)resolve
29
+ reject:(nonnull RCTPromiseRejectBlock)reject {
30
+ if (@available(iOS 14, *)) {
31
+ [ATTrackingManager requestTrackingAuthorizationWithCompletionHandler:^(
32
+ ATTrackingManagerAuthorizationStatus status) {
33
+ resolve([self mapStatusToString:status]);
34
+ }];
35
+ } else {
36
+ resolve(@"unavailable");
37
+ }
38
+ }
39
+
40
+ - (NSString *)mapStatusToString:(ATTrackingManagerAuthorizationStatus)status {
41
+ switch (status) {
42
+ case ATTrackingManagerAuthorizationStatusNotDetermined:
43
+ return @"not-determined";
44
+ case ATTrackingManagerAuthorizationStatusRestricted:
45
+ return @"restricted";
46
+ case ATTrackingManagerAuthorizationStatusDenied:
47
+ return @"denied";
48
+ case ATTrackingManagerAuthorizationStatusAuthorized:
49
+ return @"authorized";
50
+ default:
51
+ return @"unavailable";
52
+ }
53
+ }
54
+
55
+ @end
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+
3
+ import { TurboModuleRegistry } from 'react-native';
4
+ export let TrackingStatusEnum = /*#__PURE__*/function (TrackingStatusEnum) {
5
+ TrackingStatusEnum["Authorized"] = "authorized";
6
+ TrackingStatusEnum["Denied"] = "denied";
7
+ TrackingStatusEnum["Restricted"] = "restricted";
8
+ TrackingStatusEnum["NotDetermined"] = "not-determined";
9
+ TrackingStatusEnum["Unavailable"] = "unavailable";
10
+ return TrackingStatusEnum;
11
+ }({});
12
+ export default TurboModuleRegistry.getEnforcing('TurboTrackingTransparency');
13
+ //# sourceMappingURL=NativeTurboTrackingTransparency.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["TurboModuleRegistry","TrackingStatusEnum","getEnforcing"],"sourceRoot":"../../src","sources":["NativeTurboTrackingTransparency.ts"],"mappings":";;AAAA,SAASA,mBAAmB,QAA0B,cAAc;AACpE,WAAYC,kBAAkB,0BAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAA,OAAlBA,kBAAkB;AAAA;AAY9B,eAAeD,mBAAmB,CAACE,YAAY,CAC7C,2BACF,CAAC","ignoreList":[]}
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+
3
+ import { Platform } from 'react-native';
4
+ import TurboTrackingTransparency, { TrackingStatusEnum } from "./NativeTurboTrackingTransparency.js";
5
+ export function getTrackingStatus() {
6
+ if (Platform.OS !== 'ios' || !TurboTrackingTransparency) {
7
+ return TrackingStatusEnum.Authorized;
8
+ }
9
+ return TurboTrackingTransparency.getTrackingStatus();
10
+ }
11
+ export function requestTrackingPermission() {
12
+ if (Platform.OS !== 'ios' || !TurboTrackingTransparency) {
13
+ return Promise.resolve(TrackingStatusEnum.Authorized);
14
+ }
15
+ return TurboTrackingTransparency.requestTrackingPermission();
16
+ }
17
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Platform","TurboTrackingTransparency","TrackingStatusEnum","getTrackingStatus","OS","Authorized","requestTrackingPermission","Promise","resolve"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":";;AAAA,SAASA,QAAQ,QAAQ,cAAc;AACvC,OAAOC,yBAAyB,IAC9BC,kBAAkB,QACb,sCAAmC;AAE1C,OAAO,SAASC,iBAAiBA,CAAA,EAAG;EAClC,IAAIH,QAAQ,CAACI,EAAE,KAAK,KAAK,IAAI,CAACH,yBAAyB,EAAE;IACvD,OAAOC,kBAAkB,CAACG,UAAU;EACtC;EACA,OAAOJ,yBAAyB,CAACE,iBAAiB,CAAC,CAAC;AACtD;AAEA,OAAO,SAASG,yBAAyBA,CAAA,EAAG;EAC1C,IAAIN,QAAQ,CAACI,EAAE,KAAK,KAAK,IAAI,CAACH,yBAAyB,EAAE;IACvD,OAAOM,OAAO,CAACC,OAAO,CAACN,kBAAkB,CAACG,UAAU,CAAC;EACvD;EACA,OAAOJ,yBAAyB,CAACK,yBAAyB,CAAC,CAAC;AAC9D","ignoreList":[]}
@@ -0,0 +1 @@
1
+ {"type":"module"}
@@ -0,0 +1 @@
1
+ {"type":"module"}
@@ -0,0 +1,15 @@
1
+ import { type TurboModule } from 'react-native';
2
+ export declare enum TrackingStatusEnum {
3
+ Authorized = "authorized",
4
+ Denied = "denied",
5
+ Restricted = "restricted",
6
+ NotDetermined = "not-determined",
7
+ Unavailable = "unavailable"
8
+ }
9
+ export interface Spec extends TurboModule {
10
+ getTrackingStatus(): TrackingStatusEnum;
11
+ requestTrackingPermission(): Promise<TrackingStatusEnum>;
12
+ }
13
+ declare const _default: Spec;
14
+ export default _default;
15
+ //# sourceMappingURL=NativeTurboTrackingTransparency.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NativeTurboTrackingTransparency.d.ts","sourceRoot":"","sources":["../../../src/NativeTurboTrackingTransparency.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuB,KAAK,WAAW,EAAE,MAAM,cAAc,CAAC;AACrE,oBAAY,kBAAkB;IAC5B,UAAU,eAAe;IACzB,MAAM,WAAW;IACjB,UAAU,eAAe;IACzB,aAAa,mBAAmB;IAChC,WAAW,gBAAgB;CAC5B;AACD,MAAM,WAAW,IAAK,SAAQ,WAAW;IACvC,iBAAiB,IAAI,kBAAkB,CAAC;IACxC,yBAAyB,IAAI,OAAO,CAAC,kBAAkB,CAAC,CAAC;CAC1D;;AAED,wBAEE"}
@@ -0,0 +1,4 @@
1
+ import { TrackingStatusEnum } from './NativeTurboTrackingTransparency';
2
+ export declare function getTrackingStatus(): TrackingStatusEnum;
3
+ export declare function requestTrackingPermission(): Promise<TrackingStatusEnum>;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AACA,OAAkC,EAChC,kBAAkB,EACnB,MAAM,mCAAmC,CAAC;AAE3C,wBAAgB,iBAAiB,uBAKhC;AAED,wBAAgB,yBAAyB,gCAKxC"}
package/package.json ADDED
@@ -0,0 +1,169 @@
1
+ {
2
+ "name": "react-native-turbo-tracking-transparency",
3
+ "version": "0.2.0",
4
+ "description": "A React Native Library for interacting with the tracking API for ios iOS",
5
+ "main": "./lib/module/index.js",
6
+ "types": "./lib/typescript/src/index.d.ts",
7
+ "exports": {
8
+ ".": {
9
+ "source": "./src/index.ts",
10
+ "types": "./lib/typescript/src/index.d.ts",
11
+ "default": "./lib/module/index.js"
12
+ },
13
+ "./package.json": "./package.json"
14
+ },
15
+ "files": [
16
+ "src",
17
+ "lib",
18
+ "android",
19
+ "ios",
20
+ "cpp",
21
+ "*.podspec",
22
+ "react-native.config.js",
23
+ "!ios/build",
24
+ "!android/build",
25
+ "!android/gradle",
26
+ "!android/gradlew",
27
+ "!android/gradlew.bat",
28
+ "!android/local.properties",
29
+ "!**/__tests__",
30
+ "!**/__fixtures__",
31
+ "!**/__mocks__",
32
+ "!**/.*"
33
+ ],
34
+ "scripts": {
35
+ "example": "yarn workspace react-native-turbo-tracking-transparency-example",
36
+ "clean": "del-cli android/build example/android/build example/android/app/build example/ios/build lib",
37
+ "prepare": "bob build",
38
+ "typecheck": "tsc",
39
+ "lint": "eslint \"**/*.{js,ts,tsx}\"",
40
+ "test": "jest",
41
+ "release": "release-it --only-version"
42
+ },
43
+ "keywords": [
44
+ "react-native",
45
+ "ios",
46
+ "android"
47
+ ],
48
+ "repository": {
49
+ "type": "git",
50
+ "url": "git+https://github.com/SolankiYogesh/react-native-turbo-tracking-transparency.git"
51
+ },
52
+ "author": "Solanki Yogesh <solankiyogesh3500@gmail.com> (https://github.com/SolankiYogesh)",
53
+ "license": "MIT",
54
+ "bugs": {
55
+ "url": "https://github.com/SolankiYogesh/react-native-turbo-tracking-transparency/issues"
56
+ },
57
+ "homepage": "https://github.com/SolankiYogesh/react-native-turbo-tracking-transparency#readme",
58
+ "publishConfig": {
59
+ "registry": "https://registry.npmjs.org/"
60
+ },
61
+ "devDependencies": {
62
+ "@commitlint/config-conventional": "^19.8.1",
63
+ "@eslint/compat": "^1.3.2",
64
+ "@eslint/eslintrc": "^3.3.1",
65
+ "@eslint/js": "^9.35.0",
66
+ "@react-native/babel-preset": "0.83.0",
67
+ "@react-native/eslint-config": "0.83.0",
68
+ "@release-it/conventional-changelog": "^10.0.1",
69
+ "@types/jest": "^29.5.14",
70
+ "@types/react": "^19.2.0",
71
+ "commitlint": "^19.8.1",
72
+ "del-cli": "^6.0.0",
73
+ "eslint": "^9.35.0",
74
+ "eslint-config-prettier": "^10.1.8",
75
+ "eslint-plugin-prettier": "^5.5.4",
76
+ "jest": "^29.7.0",
77
+ "lefthook": "^2.0.3",
78
+ "prettier": "^2.8.8",
79
+ "react": "19.2.0",
80
+ "react-native": "0.83.0",
81
+ "react-native-builder-bob": "^0.40.13",
82
+ "release-it": "^19.0.4",
83
+ "turbo": "^2.5.6",
84
+ "typescript": "^5.9.2"
85
+ },
86
+ "peerDependencies": {
87
+ "react": "*",
88
+ "react-native": "*"
89
+ },
90
+ "workspaces": [
91
+ "example"
92
+ ],
93
+ "packageManager": "yarn@4.11.0",
94
+ "react-native-builder-bob": {
95
+ "source": "src",
96
+ "output": "lib",
97
+ "targets": [
98
+ [
99
+ "module",
100
+ {
101
+ "esm": true
102
+ }
103
+ ],
104
+ [
105
+ "typescript",
106
+ {
107
+ "project": "tsconfig.build.json"
108
+ }
109
+ ]
110
+ ]
111
+ },
112
+ "codegenConfig": {
113
+ "name": "TurboTrackingTransparencySpec",
114
+ "type": "modules",
115
+ "jsSrcsDir": "src",
116
+ "android": {
117
+ "javaPackageName": "com.turbotrackingtransparency"
118
+ }
119
+ },
120
+ "prettier": {
121
+ "quoteProps": "consistent",
122
+ "singleQuote": true,
123
+ "tabWidth": 2,
124
+ "trailingComma": "es5",
125
+ "useTabs": false
126
+ },
127
+ "jest": {
128
+ "preset": "react-native",
129
+ "modulePathIgnorePatterns": [
130
+ "<rootDir>/example/node_modules",
131
+ "<rootDir>/lib/"
132
+ ]
133
+ },
134
+ "commitlint": {
135
+ "extends": [
136
+ "@commitlint/config-conventional"
137
+ ]
138
+ },
139
+ "release-it": {
140
+ "git": {
141
+ "commitMessage": "chore: release ${version}",
142
+ "tagName": "v${version}"
143
+ },
144
+ "npm": {
145
+ "publish": true
146
+ },
147
+ "github": {
148
+ "release": true
149
+ },
150
+ "plugins": {
151
+ "@release-it/conventional-changelog": {
152
+ "preset": {
153
+ "name": "angular"
154
+ }
155
+ }
156
+ }
157
+ },
158
+ "create-react-native-library": {
159
+ "type": "turbo-module",
160
+ "languages": "kotlin-objc",
161
+ "tools": [
162
+ "eslint",
163
+ "jest",
164
+ "lefthook",
165
+ "release-it"
166
+ ],
167
+ "version": "0.57.0"
168
+ }
169
+ }
@@ -0,0 +1,16 @@
1
+ import { TurboModuleRegistry, type TurboModule } from 'react-native';
2
+ export enum TrackingStatusEnum {
3
+ Authorized = 'authorized',
4
+ Denied = 'denied',
5
+ Restricted = 'restricted',
6
+ NotDetermined = 'not-determined',
7
+ Unavailable = 'unavailable',
8
+ }
9
+ export interface Spec extends TurboModule {
10
+ getTrackingStatus(): TrackingStatusEnum;
11
+ requestTrackingPermission(): Promise<TrackingStatusEnum>;
12
+ }
13
+
14
+ export default TurboModuleRegistry.getEnforcing<Spec>(
15
+ 'TurboTrackingTransparency'
16
+ );
package/src/index.ts ADDED
@@ -0,0 +1,18 @@
1
+ import { Platform } from 'react-native';
2
+ import TurboTrackingTransparency, {
3
+ TrackingStatusEnum,
4
+ } from './NativeTurboTrackingTransparency';
5
+
6
+ export function getTrackingStatus() {
7
+ if (Platform.OS !== 'ios' || !TurboTrackingTransparency) {
8
+ return TrackingStatusEnum.Authorized;
9
+ }
10
+ return TurboTrackingTransparency.getTrackingStatus();
11
+ }
12
+
13
+ export function requestTrackingPermission() {
14
+ if (Platform.OS !== 'ios' || !TurboTrackingTransparency) {
15
+ return Promise.resolve(TrackingStatusEnum.Authorized);
16
+ }
17
+ return TurboTrackingTransparency.requestTrackingPermission();
18
+ }