UNPKG

@kirz/react-native-toolkit

Version:

Toolkit to speed up React Native development

65 lines (63 loc) 2.67 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.IdfaPlugin = void 0; var _asyncStorage = _interopRequireDefault(require("@react-native-async-storage/async-storage")); var _reactNativeIdfaAaid = _interopRequireDefault(require("@sparkfabrik/react-native-idfa-aaid")); var _reactNative = require("react-native"); var _wait = require("../../utils/promise/wait"); var _Plugin = require("../Plugin"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } class IdfaPlugin extends _Plugin.Plugin { constructor(options) { super(); this.options = options; _defineProperty(this, "name", 'IdfaPlugin'); _defineProperty(this, "features", ['IDFA']); _defineProperty(this, "initializationTimeout", null); _defineProperty(this, "_idfa", null); } get idfa() { return this._idfa; } async initialize() { const storedIdfa = await _asyncStorage.default.getItem('__IdfaPlugin__'); if (storedIdfa) { this._idfa = storedIdfa === 'null' ? null : storedIdfa; return; } let subscription; if (_reactNative.AppState.currentState !== 'active') { await new Promise(resolve => { subscription = _reactNative.AppState.addEventListener('change', nextAppState => { if (nextAppState === 'active') { resolve(); } }); }); } // @ts-ignore if (subscription) { subscription.remove(); } if (this.options.delay) { await (0, _wait.wait)(this.options.delay ?? 100); } try { const res = await _reactNativeIdfaAaid.default.getAdvertisingInfo(); if (!res.id) { return; } this._idfa = res.id; } catch { // no-op } await _asyncStorage.default.setItem('__IdfaPlugin__', this._idfa ? this._idfa : 'null'); } } exports.IdfaPlugin = IdfaPlugin; //# sourceMappingURL=IdfaPlugin.js.map