@mediacubeco/react-native-base 0.1.4 → 0.1.6
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/dist/helpers/index.cjs +1 -1
- package/dist/helpers/index.cjs.map +1 -1
- package/dist/helpers/index.d.ts +78 -2
- package/dist/helpers/index.d.ts.map +1 -1
- package/dist/helpers/index.mjs +1 -1
- package/dist/helpers/index.mjs.map +1 -1
- package/dist/hooks/index.cjs +1 -1
- package/dist/hooks/index.cjs.map +1 -1
- package/dist/hooks/index.d.ts +2 -1
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.mjs +1 -1
- package/dist/hooks/index.mjs.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +80 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/dist/utils/index.cjs +1 -1
- package/dist/utils/index.cjs.map +1 -1
- package/dist/utils/index.mjs +1 -1
- package/dist/utils/index.mjs.map +1 -1
- package/package.json +2 -2
package/dist/helpers/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var t=require("@react-native-clipboard/clipboard"),
|
|
1
|
+
"use strict";var t=require("axios"),e=require("@react-native-clipboard/clipboard"),s=require("react-native");function r(t){return t&&t.__esModule?t:{default:t}}var i=r(e);const n=t=>t instanceof Error,a=t=>{for(let e in t)return!1;return!0},o=(t="?",...e)=>{const s=(t&&(r=t,"string"==typeof r)?t:"?").toUpperCase();var r;const i=e.reduce((t,e,s,{length:r})=>{const i=s===r-1?[]:["|"];return t.push(e,...i),t},e.length?["-"]:[]);return[`[${s}]`,...i]};var c,u,d;(d=c||(c={})).StartGroup="group",d.EndGroup="groupEnd",d.Default="log",function(t){t.Info="[36m%s[0m",t.Success="[32m%s[0m",t.Warning="[33m%s[0m",t.Danger="[31m%s[0m"}(u||(u={}));class l{static formatted={info:(...t)=>l.info(...o(...t)),success:(...t)=>l.success(...o(...t)),warning:(...t)=>l.warning(...o(...t)),danger:(...t)=>l.danger(...o(...t))};static#t(t,...e){console[t](...e)}static startGroup(t,e,...s){l.#t(c.StartGroup,...((t,...e)=>["%c%s",t,...e])(`font-size: 16px;${e}`,...o(t,...s)))}static endGroup(){l.#t(c.EndGroup)}static info(...t){l.#t(c.Default,u.Info,...t)}static success(...t){l.#t(c.Default,u.Success,...t)}static warning(...t){l.#t(c.Default,u.Warning,...t)}static danger(...t){l.#t(c.Default,u.Danger,...t)}}class f{static ignore(t){}static create(t,e){return new Error(t,{cause:e})}static throw(t,e){throw f.create(t,e)}static capture(t,e){const{signal:s,message:r,payload:i,stack:a}=e,o=[r,n(t)?t.message:void 0].filter(Boolean);l.formatted.danger(s,...o,{error:t,payload:i,stack:a})}static forward(t,e){throw f.capture(t,e),t}static parse(e){const s="Some error!",r=0,i={};switch(!0){case t.isAxiosError(e):{const{status:t=r,data:n,config:o}=e.response??{},{message:c=s,errors:u=i}=n??{};return{message:c,status:t,errors:u,isExternal:a(u)}}case n(e):return{message:e.message,status:r,errors:i,isExternal:!0};default:return{message:s,status:r,errors:i,isExternal:!0}}}}class h{static get windowWidth(){return s.Dimensions.get("window").width}static get windowHeight(){return s.Dimensions.get("window").height}static get statusBarWidth(){return h.windowWidth}static get statusBarHeight(){return s.StatusBar.currentHeight??0}static get ratio(){const t=h.windowWidth/375,e=h.windowHeight/812;return Math.min(t,e)}static byWindowWidth(t){return h.windowWidth*t}static byWindowHeight(t){return h.windowHeight*t}static byRatio(t){return h.ratio*t}}const g=(t,...e)=>{if((t=>t instanceof Function)(t))return t(...e)};var p,m,w;!function(t){t.Active="active",t.Inactive="inactive",t.Background="background",t.Extension="extension",t.Unknown="unknown"}(p||(p={})),function(t){t.onWillShow="keyboardWillShow",t.onDidShow="keyboardDidShow",t.onWillHide="keyboardWillHide",t.onDidHide="keyboardDidHide",t.onWillChangeFrame="keyboardWillChangeFrame",t.onDidChangeFrame="keyboardDidChangeFrame"}(m||(m={}));class v{isDefaultPrevented=!1;constructor(){this.preventDefault=this.preventDefault.bind(this),this.overrideDefault=this.overrideDefault.bind(this)}preventDefault(){this.isDefaultPrevented=!0}overrideDefault(){this.isDefaultPrevented=!1}}exports.PlatformOS=void 0,(w=exports.PlatformOS||(exports.PlatformOS={})).Ios="ios",w.Android="android";class b{static get OS(){return s.Platform.OS}static get version(){return s.Platform.Version}static get isIos(){return"ios"===b.OS}static get isAndroid(){return"android"===b.OS}static by(t,e=exports.PlatformOS.Ios){return s.Platform.select({...t,default:t[e]})}}exports.Clipboard=class{static copy(t){return l.formatted.info("copy",t),i.default.setString(t.toString())}static async paste(){const t=await i.default.getString();return l.formatted.info("paste",t),t}},exports.Dimensions=h,exports.ErrorHandler=f,exports.EventEmitter=class{#e={};constructor(){this.emit=this.emit.bind(this),this.on=this.on.bind(this),this.off=this.off.bind(this),this.clear=this.clear.bind(this)}get eventNameList(){return Object.keys(this.#e)}emit(t,e,s){const r=this.#e[t];if(!r)return g(s);const{event:i,listenerList:n}=r;n.forEach(t=>g(t,{...i,...e})),!i.isDefaultPrevented&&g(s)}on(t,e){const s=this.#e[t];return s?s.listenerList.push(e):this.#e[t]={event:new v,listenerList:[e]},()=>this.off(t,e)}off(t,e){const s=this.#e[t];if(!s)return;const{event:r,listenerList:i}=s;this.#e[t]={event:r,listenerList:i.filter(t=>t!==e)},r.overrideDefault()}clear(t){delete this.#e[t]}},exports.Log=l,exports.Platform=b;
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sources":["../../node_modules/@mediacubeco/javascript-base/dist/helpers/index.mjs","../../src/helpers/Dimensions/Dimensions.ts","../../src/helpers/Dimensions/Dimensions.constants.ts","../../src/helpers/Platform/Platform.constants.ts","../../src/helpers/Platform/Platform.ts","../../src/helpers/Clipboard/Clipboard.ts"],"sourcesContent":["const t=t=>t instanceof Error,s=(t=\"?\",...s)=>{const r=(t&&(a=t,\"string\"==typeof a)?t:\"?\").toUpperCase();var a;const e=s.reduce((t,s,r,{length:a})=>{const e=r===a-1?[]:[\"|\"];return t.push(s,...e),t},s.length?[\"-\"]:[]);return[`[${r}]`,...e]};var r,a;!function(t){t.StartGroup=\"group\",t.EndGroup=\"groupEnd\",t.Default=\"log\"}(r||(r={})),function(t){t.Info=\"\u001b[36m%s\u001b[0m\",t.Success=\"\u001b[32m%s\u001b[0m\",t.Warning=\"\u001b[33m%s\u001b[0m\",t.Danger=\"\u001b[31m%s\u001b[0m\"}(a||(a={}));class e{static formatted={info:(...t)=>e.info(...s(...t)),success:(...t)=>e.success(...s(...t)),warning:(...t)=>e.warning(...s(...t)),danger:(...t)=>e.danger(...s(...t))};static#t(t,...s){console[t](...s)}static startGroup(t,a,...o){e.#t(r.StartGroup,...((t,...s)=>[\"%c%s\",t,...s])(`font-size: 16px;${a}`,...s(t,...o)))}static endGroup(){e.#t(r.EndGroup)}static info(...t){e.#t(r.Default,a.Info,...t)}static success(...t){e.#t(r.Default,a.Success,...t)}static warning(...t){e.#t(r.Default,a.Warning,...t)}static danger(...t){e.#t(r.Default,a.Danger,...t)}}class o{static create(t,s){return new Error(t,{cause:s})}static throw(t,s){throw o.create(t,s)}static capture(s,r){const{signal:a,message:o,payload:n,stack:c}=r,i=[o,t(s)?s.message:void 0].filter(Boolean);e.formatted.danger(a,...i,{error:s,payload:n,stack:c})}static forward(t,s){throw o.capture(t,s),t}static parse(s){const r={};return!0===t(s)?{message:s.message,status:0,errors:r,isExternal:!0}:{message:\"Some error!\",status:0,errors:r,isExternal:!0}}}export{o as ErrorHandler,e as Log};\n//# sourceMappingURL=index.mjs.map\n","import { Dimensions as NativeDimensions } from 'react-native'\nimport { DIMENSIONS_DESIGN_HEIGHT, DIMENSIONS_DESIGN_WIDTH } from './Dimensions.constants'\n\n/**\n * window: reports width/height without the soft menu bar\n *\n * screen: reports entire screen's width/height\n */\nclass Dimensions {\n static get windowWidth() {\n return NativeDimensions.get('window').width\n }\n\n static get windowHeight() {\n return NativeDimensions.get('window').height\n }\n\n static get ratio() {\n const widthRatio = Dimensions.windowWidth / DIMENSIONS_DESIGN_WIDTH\n const heightRatio = Dimensions.windowHeight / DIMENSIONS_DESIGN_HEIGHT\n\n return Math.min(widthRatio, heightRatio)\n }\n\n static byWindowWidth(value: number) {\n return Dimensions.windowWidth * value\n }\n\n static byWindowHeight(value: number) {\n return Dimensions.windowHeight * value\n }\n\n static byRatio(value: number) {\n return Dimensions.ratio * value\n }\n}\n\nexport default Dimensions\n","const DIMENSIONS_DESIGN_WIDTH = 375\n\nconst DIMENSIONS_DESIGN_HEIGHT = 812\n\nexport { DIMENSIONS_DESIGN_WIDTH, DIMENSIONS_DESIGN_HEIGHT }\n","enum PlatformOS {\n Ios = 'ios',\n Android = 'android'\n // Macos = 'macos',\n // Windows = 'windows',\n // Web = 'web',\n}\n\nexport { PlatformOS }\n","import { Platform as NativePlatform } from 'react-native'\nimport { PlatformOS } from './Platform.constants'\nimport { PlatformByData, PlatformRequiredOS } from './Platform.types'\n\nclass Platform {\n static get OS() {\n return NativePlatform.OS\n }\n\n static get isIos() {\n return Platform.OS === 'ios'\n }\n\n static get isAndroid() {\n return Platform.OS === 'android'\n }\n\n // static get isMac() {\n // return Platform.OS === 'macos'\n // }\n\n // static get isWindows() {\n // return Platform.OS === 'windows'\n // }\n\n // static get isWeb() {\n // return Platform.OS === 'web'\n // }\n\n static by<Value>(data: PlatformByData<Value>, defaultOS: PlatformRequiredOS = PlatformOS.Ios) {\n return NativePlatform.select({ ...data, default: data[defaultOS] })\n }\n}\n\nexport default Platform\n","import NativeClipboard from '@react-native-clipboard/clipboard'\nimport { Log } from '@mediacubeco/javascript-base/helpers'\nimport { ClipboardValue } from './Clipboard.types'\n\nclass Clipboard {\n static copy(value: ClipboardValue) {\n Log.formatted.info('copy', value)\n\n return NativeClipboard.setString(value.toString())\n }\n\n static async paste() {\n const value = await NativeClipboard.getString()\n\n Log.formatted.info('paste', value)\n\n return value\n }\n}\n\nexport default Clipboard\n"],"names":["t","Error","s","r","a","toUpperCase","e","reduce","length","push","StartGroup","EndGroup","Default","Info","Success","Warning","Danger","static","info","success","warning","danger","console","startGroup","o","endGroup","create","cause","capture","signal","message","payload","n","stack","c","i","filter","Boolean","formatted","error","forward","parse","status","errors","isExternal","Dimensions","windowWidth","NativeDimensions","get","width","windowHeight","height","ratio","widthRatio","heightRatio","Math","min","byWindowWidth","value","byWindowHeight","byRatio","PlatformOS","Platform","OS","NativePlatform","isIos","isAndroid","by","data","defaultOS","Ios","select","default","copy","Log","NativeClipboard","setString","toString","paste","getString"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../../node_modules/@mediacubeco/javascript-base/dist/helpers/index.mjs","../../src/helpers/Dimensions/Dimensions.ts","../../src/helpers/Dimensions/Dimensions.constants.ts","../../node_modules/@mediacubeco/javascript-base/dist/utils/index.mjs","../../src/utils/listeners/appState.ts","../../src/utils/listeners/keyboard.ts","../../src/helpers/Platform/Platform.constants.ts","../../src/helpers/EventEmitter/Event/Event.ts","../../src/helpers/Platform/Platform.ts","../../src/helpers/Clipboard/Clipboard.ts","../../src/helpers/EventEmitter/EventEmitter.ts"],"sourcesContent":["import{isAxiosError as t}from\"axios\";const s=t=>t instanceof Error,r=t=>{for(let s in t)return!1;return!0},e=(t=\"?\",...s)=>{const r=(t&&(e=t,\"string\"==typeof e)?t:\"?\").toUpperCase();var e;const a=s.reduce((t,s,r,{length:e})=>{const a=r===e-1?[]:[\"|\"];return t.push(s,...a),t},s.length?[\"-\"]:[]);return[`[${r}]`,...a]};var a,o;!function(t){t.StartGroup=\"group\",t.EndGroup=\"groupEnd\",t.Default=\"log\"}(a||(a={})),function(t){t.Info=\"\u001b[36m%s\u001b[0m\",t.Success=\"\u001b[32m%s\u001b[0m\",t.Warning=\"\u001b[33m%s\u001b[0m\",t.Danger=\"\u001b[31m%s\u001b[0m\"}(o||(o={}));class n{static formatted={info:(...t)=>n.info(...e(...t)),success:(...t)=>n.success(...e(...t)),warning:(...t)=>n.warning(...e(...t)),danger:(...t)=>n.danger(...e(...t))};static#t(t,...s){console[t](...s)}static startGroup(t,s,...r){n.#t(a.StartGroup,...((t,...s)=>[\"%c%s\",t,...s])(`font-size: 16px;${s}`,...e(t,...r)))}static endGroup(){n.#t(a.EndGroup)}static info(...t){n.#t(a.Default,o.Info,...t)}static success(...t){n.#t(a.Default,o.Success,...t)}static warning(...t){n.#t(a.Default,o.Warning,...t)}static danger(...t){n.#t(a.Default,o.Danger,...t)}}class c{static ignore(t){}static create(t,s){return new Error(t,{cause:s})}static throw(t,s){throw c.create(t,s)}static capture(t,r){const{signal:e,message:a,payload:o,stack:c}=r,i=[a,s(t)?t.message:void 0].filter(Boolean);n.formatted.danger(e,...i,{error:t,payload:o,stack:c})}static forward(t,s){throw c.capture(t,s),t}static parse(e){const a=\"Some error!\",o=0,n={};switch(!0){case t(e):{const{status:t=o,data:s,config:c}=e.response??{},{message:i=a,errors:u=n}=s??{};return{message:i,status:t,errors:u,isExternal:r(u)}}case s(e):return{message:e.message,status:o,errors:n,isExternal:!0};default:return{message:a,status:o,errors:n,isExternal:!0}}}}export{c as ErrorHandler,n as Log};\n//# sourceMappingURL=index.mjs.map\n","import { Dimensions as NativeDimensions, StatusBar } from 'react-native'\nimport { DIMENSIONS_DESIGN_HEIGHT, DIMENSIONS_DESIGN_WIDTH } from './Dimensions.constants'\n\n/**\n * window: reports width/height without the soft menu bar\n *\n * screen: reports entire screen's width/height\n */\nclass Dimensions {\n static get windowWidth() {\n return NativeDimensions.get('window').width\n }\n\n static get windowHeight() {\n return NativeDimensions.get('window').height\n }\n\n static get statusBarWidth() {\n return Dimensions.windowWidth\n }\n\n static get statusBarHeight() {\n return StatusBar.currentHeight ?? 0\n }\n\n static get ratio() {\n const widthRatio = Dimensions.windowWidth / DIMENSIONS_DESIGN_WIDTH\n const heightRatio = Dimensions.windowHeight / DIMENSIONS_DESIGN_HEIGHT\n\n return Math.min(widthRatio, heightRatio)\n }\n\n static byWindowWidth(value: number) {\n return Dimensions.windowWidth * value\n }\n\n static byWindowHeight(value: number) {\n return Dimensions.windowHeight * value\n }\n\n static byRatio(value: number) {\n return Dimensions.ratio * value\n }\n}\n\nexport default Dimensions\n","const DIMENSIONS_DESIGN_WIDTH = 375\n\nconst DIMENSIONS_DESIGN_HEIGHT = 812\n\nexport { DIMENSIONS_DESIGN_WIDTH, DIMENSIONS_DESIGN_HEIGHT }\n","const e=e=>void 0===e,t=e=>null===e,n=n=>e(n)||t(n),o=e=>\"string\"==typeof e,r=e=>\"number\"==typeof e,i=e=>\"bigint\"==typeof e,s=e=>Number.isNaN(e),f=e=>\"boolean\"==typeof e,c=e=>\"symbol\"==typeof e,a=e=>\"object\"==typeof e,u=e=>{const t=[l,p,y,b,m,g,j,x,E,N,T].some(t=>t(e));return!!e&&\"object\"==typeof e&&!t},l=e=>Array.isArray(e),p=e=>e instanceof ArrayBuffer,y=e=>e instanceof Map,b=e=>e instanceof Set,m=e=>e instanceof Map,g=e=>e instanceof Set,j=e=>e instanceof Date,x=e=>e instanceof Error,A=e=>e instanceof Proxy,E=e=>e instanceof RegExp,N=e=>e instanceof Promise,T=e=>e instanceof Function;function h(e,t,n){return 2===arguments.length?t[e]:t[e]??n}const M=(e,...t)=>{if(T(e))return e(...t)},O=(e,t)=>{const n=Object.entries(e);return Object.fromEntries(n.map(([e,n],o,r)=>[e,t(e,n,o,r)]))},P=(e,t)=>{let n;return(...o)=>{n&&clearTimeout(n),n=setTimeout(()=>M(e,...o),t)}},S=(e,t)=>{let n=!0;return(...o)=>{n&&(M(e,...o),n=!1),setTimeout(()=>n=!0,t)}},d=e=>{for(let t in e)return!1;return!0},v=e=>0===e.length,B=(e,t)=>!(!a(t)||!(e in t)),D=(e,t=\"isVisible\")=>e.filter(e=>!B(t,e)||e[t]),F=e=>e.filter(e=>!n(e));export{P as debounce,D as filterByProperty,F as filterNullableValues,h as getValueByProperty,B as hasProperty,a as isAnyObject,l as isArray,p as isArrayBuffer,v as isArrayEmpty,i as isBigint,f as isBoolean,j as isDate,x as isError,T as isFunction,y as isMap,s as isNaN,t as isNull,n as isNullable,r as isNumber,u as isObject,d as isObjectEmpty,N as isPromise,A as isProxy,E as isRegExp,b as isSet,o as isString,c as isSymbol,e as isUndefined,m as isWeakMap,g as isWeakSet,O as mapRecord,M as runCallback,S as throttle};\n//# sourceMappingURL=index.mjs.map\n","import { AppState, AppStateStatus, NativeEventSubscription } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, Callback } from '@mediacubeco/javascript-base/types'\nimport { Platform } from '../../helpers'\n\ntype AppStateAdditionalHandlerName = 'onFocus' | 'onBlur'\n\ntype AppStateHandlerName =\n | AppStateAdditionalHandlerName\n | 'onActive'\n | 'onInactive'\n | 'onBackground'\n | 'onExtension'\n | 'onUnknown'\n | 'onChange'\n\ntype AppStateHandlerCallback = Callback<[AppStateStatus]>\n\ntype AppStateHandlers = Partial<BaseRecord<AppStateHandlerCallback, AppStateHandlerName>>\n\ninterface HandleChangeAppStateConfig {\n state: AppStateStatus\n handlers: Omit<AppStateHandlers, AppStateAdditionalHandlerName>\n}\n\ntype HandleChangeAppState = (config: HandleChangeAppStateConfig) => void\n\ntype ListenAppState = (handlers: AppStateHandlers) => NativeEventSubscription\n\nenum AppStatus {\n Active = 'active',\n Inactive = 'inactive',\n Background = 'background',\n Extension = 'extension',\n Unknown = 'unknown'\n}\n\nconst handleChangeAppState: HandleChangeAppState = ({ state, handlers }) => {\n const { onActive, onInactive, onBackground, onExtension, onUnknown, onChange } = handlers ?? {}\n\n const handler = {\n [AppStatus.Active]: onActive,\n [AppStatus.Inactive]: onInactive,\n [AppStatus.Background]: onBackground,\n [AppStatus.Extension]: onExtension,\n [AppStatus.Unknown]: onUnknown\n }[state]\n\n runCallback(onChange, state)\n runCallback(handler, state)\n}\n\nconst listenAppState: ListenAppState = ({ onFocus, onBlur, ...handlers }) => {\n const listenerList: NativeEventSubscription[] = []\n\n if (Platform.isAndroid) {\n listenerList.push(\n AppState.addEventListener('focus', (state) => runCallback(onFocus, state)),\n AppState.addEventListener('blur', (state) => runCallback(onBlur, state))\n )\n }\n\n listenerList.push(\n AppState.addEventListener('change', (state) => handleChangeAppState({ state, handlers }))\n )\n\n return {\n remove() {\n listenerList.forEach((listener) => listener.remove())\n }\n }\n}\n\nexport { listenAppState }\nexport type { AppStateHandlers }\n","import { Keyboard, KeyboardEventListener, NativeEventSubscription } from 'react-native'\nimport {\n mapRecord,\n filterNullableValues,\n isNullable\n} from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, KeyOf } from '@mediacubeco/javascript-base/types'\n\nenum KeyboardEventName {\n onWillShow = 'keyboardWillShow',\n onDidShow = 'keyboardDidShow',\n onWillHide = 'keyboardWillHide',\n onDidHide = 'keyboardDidHide',\n onWillChangeFrame = 'keyboardWillChangeFrame',\n onDidChangeFrame = 'keyboardDidChangeFrame'\n}\n\ntype KeyboardHandlers = Partial<BaseRecord<KeyboardEventListener, KeyOf<typeof KeyboardEventName>>>\n\ntype ListenKeyboard = (handlers: KeyboardHandlers) => NativeEventSubscription\n\nconst listenKeyboard: ListenKeyboard = (handlers) => {\n const list = mapRecord(handlers, (key, handler) => {\n if (isNullable(handler)) return\n\n return Keyboard.addListener(KeyboardEventName[key], handler)\n })\n\n return {\n remove() {\n return filterNullableValues(Object.values(list)).map((unsubscribe) => unsubscribe.remove())\n }\n }\n}\n\nexport { listenKeyboard }\nexport type { KeyboardHandlers }\n","enum PlatformOS {\n Ios = 'ios',\n Android = 'android'\n // Macos = 'macos',\n // Windows = 'windows',\n // Web = 'web',\n}\n\nexport { PlatformOS }\n","class Event {\n isDefaultPrevented = false\n\n constructor() {\n this.preventDefault = this.preventDefault.bind(this)\n this.overrideDefault = this.overrideDefault.bind(this)\n }\n\n preventDefault() {\n this.isDefaultPrevented = true\n }\n\n overrideDefault() {\n this.isDefaultPrevented = false\n }\n}\n\nexport default Event\n","import { Platform as NativePlatform } from 'react-native'\nimport { PlatformOS } from './Platform.constants'\nimport { PlatformByData, PlatformRequiredOS } from './Platform.types'\n\n// Platform.Version\nclass Platform {\n static get OS() {\n return NativePlatform.OS\n }\n\n static get version() {\n return NativePlatform.Version\n }\n\n static get isIos() {\n return Platform.OS === 'ios'\n }\n\n static get isAndroid() {\n return Platform.OS === 'android'\n }\n\n // static get isMac() {\n // return Platform.OS === 'macos'\n // }\n\n // static get isWindows() {\n // return Platform.OS === 'windows'\n // }\n\n // static get isWeb() {\n // return Platform.OS === 'web'\n // }\n\n static by<Value>(data: PlatformByData<Value>, defaultOS: PlatformRequiredOS = PlatformOS.Ios) {\n return NativePlatform.select({ ...data, default: data[defaultOS] })\n }\n}\n\nexport default Platform\n","import NativeClipboard from '@react-native-clipboard/clipboard'\nimport { Log } from '@mediacubeco/javascript-base/helpers'\nimport { ClipboardValue } from './Clipboard.types'\n\nclass Clipboard {\n static copy(value: ClipboardValue) {\n Log.formatted.info('copy', value)\n\n return NativeClipboard.setString(value.toString())\n }\n\n static async paste() {\n const value = await NativeClipboard.getString()\n\n Log.formatted.info('paste', value)\n\n return value\n }\n}\n\nexport default Clipboard\n","import { runCallback } from '../../utils'\nimport { Nullable } from '../../types'\nimport {\n EventEmitterDefaultAction,\n EventEmitterListener,\n EventEmitterSubscriptions\n} from './EventEmitter.types'\nimport Event from './Event'\n\n/**\n * ### Create instance\n * **Returns ```EventEmitter```**\n * ```\n * const emitter = new EventEmitter()\n * const testEmitter = new EventEmitter<'test'>()\n * const testEmitterWithParam = new EventEmitter<'test', { param: 'param' }>()\n * ```\n *\n * ---\n *\n * ### EventEmitter.emit\n * **Returns ```void```**\n * ```\n * emitter.emit('test')\n * emitter.emit('test', { param: 'param' })\n * emitter.emit('test', undefined, () => 'default')\n * emitter.emit('test', { param: 'param' }, () => 'default')\n * ```\n *\n * ---\n *\n * ### EventEmitter.on\n * **Returns ```Noop```**\n * ```\n * const listener = () => null\n * emitter.on('test', listener)\n *\n * emitter.on('test', () => null)\n * emitter.on('test', (event) => null)\n * emitter.on('test', ({ param }) => null)\n * ```\n *\n * ---\n *\n * ### EventEmitter.off\n * **Returns ```void```**\n * ```\n * const listener = () => 'event'\n * emitter.off(listener)\n *\n * const unsubscribe = emitter.on('test', () => 'event')\n * unsubscribe()\n * ```\n *\n * ---\n *\n * ### EventEmitter.clear\n * **Returns ```void```**\n * ```\n * EventEmitter.clear('clear')\n * ```\n */\nclass EventEmitter<\n EventName extends string = string,\n EventParam extends Nullable<object> = undefined\n> {\n #subscriptions = {} as EventEmitterSubscriptions<EventName, EventParam>\n\n constructor() {\n this.emit = this.emit.bind(this)\n this.on = this.on.bind(this)\n this.off = this.off.bind(this)\n this.clear = this.clear.bind(this)\n }\n\n get eventNameList() {\n return Object.keys(this.#subscriptions) as EventName[]\n }\n\n emit(name: EventName, param?: EventParam, defaultAction?: EventEmitterDefaultAction) {\n const subscription = this.#subscriptions[name]\n\n if (!subscription) return runCallback(defaultAction)\n\n const { event, listenerList } = subscription\n\n listenerList.forEach((listener) => runCallback(listener, { ...event, ...(param as any) }))\n\n !event.isDefaultPrevented && runCallback(defaultAction)\n }\n\n on(name: EventName, listener: EventEmitterListener<EventParam>) {\n const subscription = this.#subscriptions[name]\n\n subscription\n ? subscription.listenerList.push(listener)\n : (this.#subscriptions[name] = { event: new Event(), listenerList: [listener] })\n\n return () => this.off(name, listener)\n }\n\n off(name: EventName, listener: EventEmitterListener<EventParam>) {\n const subscription = this.#subscriptions[name]\n\n if (!subscription) return\n\n const { event, listenerList } = subscription\n\n this.#subscriptions[name] = {\n event,\n listenerList: listenerList.filter((listenerItem) => listenerItem !== listener)\n }\n\n event.overrideDefault()\n }\n\n clear(name: EventName) {\n delete this.#subscriptions[name]\n }\n}\n\nexport default EventEmitter\n"],"names":["s","t","Error","r","e","toUpperCase","a","reduce","length","push","o","StartGroup","EndGroup","Default","Info","Success","Warning","Danger","n","static","info","success","warning","danger","console","startGroup","endGroup","c","ignore","create","cause","capture","signal","message","payload","stack","i","filter","Boolean","formatted","error","forward","parse","status","data","config","response","errors","u","isExternal","Dimensions","windowWidth","NativeDimensions","get","width","windowHeight","height","statusBarWidth","statusBarHeight","StatusBar","currentHeight","ratio","widthRatio","heightRatio","Math","min","byWindowWidth","value","byWindowHeight","byRatio","M","Function","T","AppStatus","KeyboardEventName","PlatformOS","Event","isDefaultPrevented","constructor","this","preventDefault","bind","overrideDefault","Platform","OS","NativePlatform","version","Version","isIos","isAndroid","by","defaultOS","Ios","select","default","copy","Log","NativeClipboard","setString","toString","paste","getString","subscriptions","emit","on","off","clear","eventNameList","Object","keys","name","param","defaultAction","subscription","runCallback","event","listenerList","forEach","listener","listenerItem"],"mappings":"2KAAqC,MAAMA,EAAEC,GAAGA,aAAaC,MAAMC,EAAEF,IAAI,IAAI,IAAID,KAAKC,EAAE,OAAM,EAAG,OAAM,GAAIG,EAAE,CAACH,EAAE,OAAOD,KAAK,MAAMG,GAAGF,IAAIG,EAAEH,EAAE,iBAAiBG,GAAGH,EAAE,KAAKI,cAAc,IAAID,EAAE,MAAME,EAAEN,EAAEO,OAAO,CAACN,EAAED,EAAEG,GAAGK,OAAOJ,MAAM,MAAME,EAAEH,IAAIC,EAAE,EAAE,GAAG,CAAC,KAAK,OAAOH,EAAEQ,KAAKT,KAAKM,GAAGL,GAAGD,EAAEQ,OAAO,CAAC,KAAK,IAAI,MAAM,CAAC,IAAIL,QAAQG,IAAI,IAAIA,EAAEI,EAAYT,KAA+DK,IAAIA,EAAE,CAAA,IAAhEK,WAAW,QAAQV,EAAEW,SAAS,WAAWX,EAAEY,QAAQ,MAAkB,SAASZ,GAAGA,EAAEa,KAAK,cAAcb,EAAEc,QAAQ,cAAcd,EAAEe,QAAQ,cAAcf,EAAEgB,OAAO,aAAa,CAAvG,CAAyGP,IAAIA,EAAE,CAAA,IAAK,MAAMQ,EAAEC,iBAAiB,CAACC,KAAK,IAAInB,IAAIiB,EAAEE,QAAQhB,KAAKH,IAAIoB,QAAQ,IAAIpB,IAAIiB,EAAEG,WAAWjB,KAAKH,IAAIqB,QAAQ,IAAIrB,IAAIiB,EAAEI,WAAWlB,KAAKH,IAAIsB,OAAO,IAAItB,IAAIiB,EAAEK,UAAUnB,KAAKH,KAAK,QAAMA,CAAGA,KAAKD,GAAGwB,QAAQvB,MAAMD,EAAE,CAAC,iBAAOyB,CAAWxB,EAAED,KAAKG,GAAGe,GAAEjB,EAAGK,EAAEK,cAAc,EAAEV,KAAKD,IAAI,CAAC,OAAOC,KAAKD,GAAxB,CAA4B,mBAAmBA,OAAOI,EAAEH,KAAKE,IAAI,CAAC,eAAOuB,GAAWR,GAAEjB,EAAGK,EAAEM,SAAS,CAAC,WAAOQ,IAAQnB,GAAGiB,GAAEjB,EAAGK,EAAEO,QAAQH,EAAEI,QAAQb,EAAE,CAAC,cAAOoB,IAAWpB,GAAGiB,GAAEjB,EAAGK,EAAEO,QAAQH,EAAEK,WAAWd,EAAE,CAAC,cAAOqB,IAAWrB,GAAGiB,GAAEjB,EAAGK,EAAEO,QAAQH,EAAEM,WAAWf,EAAE,CAAC,aAAOsB,IAAUtB,GAAGiB,GAAEjB,EAAGK,EAAEO,QAAQH,EAAEO,UAAUhB,EAAE,EAAE,MAAM0B,EAAE,aAAOC,CAAO3B,GAAG,CAAC,aAAO4B,CAAO5B,EAAED,GAAG,OAAO,IAAIE,MAAMD,EAAE,CAAC6B,MAAM9B,GAAG,CAAC,YAAO,CAAMC,EAAED,GAAG,MAAM2B,EAAEE,OAAO5B,EAAED,EAAE,CAAC,cAAO+B,CAAQ9B,EAAEE,GAAG,MAAM6B,OAAO5B,EAAE6B,QAAQ3B,EAAE4B,QAAQxB,EAAEyB,MAAMR,GAAGxB,EAAEiC,EAAE,CAAC9B,EAAEN,EAAEC,GAAGA,EAAEgC,aAAQ,GAAQI,OAAOC,SAASpB,EAAEqB,UAAUhB,OAAOnB,KAAKgC,EAAE,CAACI,MAAMvC,EAAEiC,QAAQxB,EAAEyB,MAAMR,GAAG,CAAC,cAAOc,CAAQxC,EAAED,GAAG,MAAM2B,EAAEI,QAAQ9B,EAAED,GAAGC,CAAC,CAAC,YAAOyC,CAAMtC,GAAG,MAAME,EAAE,cAAcI,EAAE,EAAEQ,EAAE,CAAA,EAAG,QAAO,GAAI,KAAKjB,EAAAA,aAAEG,GAAG,CAAC,MAAMuC,OAAO1C,EAAES,EAAEkC,KAAK5C,EAAE6C,OAAOlB,GAAGvB,EAAE0C,UAAU,CAAA,GAAIb,QAAQG,EAAE9B,EAAEyC,OAAOC,EAAE9B,GAAGlB,GAAG,CAAA,EAAG,MAAM,CAACiC,QAAQG,EAAEO,OAAO1C,EAAE8C,OAAOC,EAAEC,WAAW9C,EAAE6C,GAAG,CAAC,KAAKhD,EAAEI,GAAG,MAAM,CAAC6B,QAAQ7B,EAAE6B,QAAQU,OAAOjC,EAAEqC,OAAO7B,EAAE+B,YAAW,GAAI,QAAQ,MAAM,CAAChB,QAAQ3B,EAAEqC,OAAOjC,EAAEqC,OAAO7B,EAAE+B,YAAW,GAAI,ECQlsD,MAAMC,EACJ,sBAAWC,GACT,OAAOC,aAAiBC,IAAI,UAAUC,KACxC,CAEA,uBAAWC,GACT,OAAOH,aAAiBC,IAAI,UAAUG,MACxC,CAEA,yBAAWC,GACT,OAAOP,EAAWC,WACpB,CAEA,0BAAWO,GACT,OAAOC,EAAAA,UAAUC,eAAiB,CACpC,CAEA,gBAAWC,GACT,MAAMC,EAAaZ,EAAWC,YC1BF,ID2BtBY,EAAcb,EAAWK,aCzBF,ID2B7B,OAAOS,KAAKC,IAAIH,EAAYC,EAC9B,CAEA,oBAAOG,CAAcC,GACnB,OAAOjB,EAAWC,YAAcgB,CAClC,CAEA,qBAAOC,CAAeD,GACpB,OAAOjB,EAAWK,aAAeY,CACnC,CAEA,cAAOE,CAAQF,GACb,OAAOjB,EAAWW,MAAQM,CAC5B,EE1CG,MAA8oBG,EAAE,CAAClE,KAAKH,KAAK,GAAvGG,IAAGA,aAAamE,SAA0FC,CAAEpE,GAAG,OAAOA,KAAKH,IC6BprB,IAAKwE,ECrBAC,ECRAC,GF6BL,SAAKF,GACHA,EAAA,OAAA,SACAA,EAAA,SAAA,WACAA,EAAA,WAAA,aACAA,EAAA,UAAA,YACAA,EAAA,QAAA,SACD,CAND,CAAKA,IAAAA,EAAS,CAAA,ICrBd,SAAKC,GACHA,EAAA,WAAA,mBACAA,EAAA,UAAA,kBACAA,EAAA,WAAA,mBACAA,EAAA,UAAA,kBACAA,EAAA,kBAAA,0BACAA,EAAA,iBAAA,wBACD,CAPD,CAAKA,IAAAA,EAAiB,CAAA,IERtB,MAAME,EACJC,oBAAqB,EAErBC,WAAAA,GACEC,KAAKC,eAAiBD,KAAKC,eAAeC,KAAKF,MAC/CA,KAAKG,gBAAkBH,KAAKG,gBAAgBD,KAAKF,KACnD,CAEAC,cAAAA,GACED,KAAKF,oBAAqB,CAC5B,CAEAK,eAAAA,GACEH,KAAKF,oBAAqB,CAC5B,EDdGF,QAAAA,gBAAAA,GAAAA,EAAAA,QAAAA,aAAAA,mBAAU,CAAA,IACb,IAAA,MACAA,EAAA,QAAA,UEGF,MAAMQ,EACJ,aAAWC,GACT,OAAOC,EAAAA,SAAeD,EACxB,CAEA,kBAAWE,GACT,OAAOD,EAAAA,SAAeE,OACxB,CAEA,gBAAWC,GACT,MAAuB,QAAhBL,EAASC,EAClB,CAEA,oBAAWK,GACT,MAAuB,YAAhBN,EAASC,EAClB,CAcA,SAAOM,CAAU9C,EAA6B+C,EAAgChB,QAAAA,WAAWiB,KACvF,OAAOP,EAAAA,SAAeQ,OAAO,IAAKjD,EAAMkD,QAASlD,EAAK+C,IACxD,oBChCF,MACE,WAAOI,CAAK5B,GAGV,OAFA6B,EAAIzD,UAAUnB,KAAK,OAAQ+C,GAEpB8B,UAAgBC,UAAU/B,EAAMgC,WACzC,CAEA,kBAAaC,GACX,MAAMjC,QAAc8B,EAAAA,QAAgBI,YAIpC,OAFAL,EAAIzD,UAAUnB,KAAK,QAAS+C,GAErBA,CACT,oEC6CF,MAIEmC,GAAiB,CAAA,EAEjBxB,WAAAA,GACEC,KAAKwB,KAAOxB,KAAKwB,KAAKtB,KAAKF,MAC3BA,KAAKyB,GAAKzB,KAAKyB,GAAGvB,KAAKF,MACvBA,KAAK0B,IAAM1B,KAAK0B,IAAIxB,KAAKF,MACzBA,KAAK2B,MAAQ3B,KAAK2B,MAAMzB,KAAKF,KAC/B,CAEA,iBAAI4B,GACF,OAAOC,OAAOC,KAAK9B,MAAKuB,EAC1B,CAEAC,IAAAA,CAAKO,EAAiBC,EAAoBC,GACxC,MAAMC,EAAelC,MAAKuB,EAAeQ,GAEzC,IAAKG,EAAc,OAAOC,EAAYF,GAEtC,MAAMG,MAAEA,EAAKC,aAAEA,GAAiBH,EAEhCG,EAAaC,QAASC,GAAaJ,EAAYI,EAAU,IAAKH,KAAWJ,MAExEI,EAAMtC,oBAAsBqC,EAAYF,EAC3C,CAEAR,EAAAA,CAAGM,EAAiBQ,GAClB,MAAML,EAAelC,MAAKuB,EAAeQ,GAMzC,OAJAG,EACIA,EAAaG,aAAa3G,KAAK6G,GAC9BvC,MAAKuB,EAAeQ,GAAQ,CAAEK,MAAO,IAAIvC,EAASwC,aAAc,CAACE,IAE/D,IAAMvC,KAAK0B,IAAIK,EAAMQ,EAC9B,CAEAb,GAAAA,CAAIK,EAAiBQ,GACnB,MAAML,EAAelC,MAAKuB,EAAeQ,GAEzC,IAAKG,EAAc,OAEnB,MAAME,MAAEA,EAAKC,aAAEA,GAAiBH,EAEhClC,MAAKuB,EAAeQ,GAAQ,CAC1BK,QACAC,aAAcA,EAAa/E,OAAQkF,GAAiBA,IAAiBD,IAGvEH,EAAMjC,iBACR,CAEAwB,KAAAA,CAAMI,UACG/B,MAAKuB,EAAeQ,EAC7B","x_google_ignoreList":[0,3]}
|
package/dist/helpers/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export * from '@mediacubeco/javascript-base/helpers';
|
|
2
|
-
import { Include, BaseRecord } from '@mediacubeco/javascript-base/types';
|
|
2
|
+
import { Noop, Callback, Nullable, Include, BaseRecord } from '@mediacubeco/javascript-base/types';
|
|
3
3
|
|
|
4
4
|
type ClipboardValue = string;
|
|
5
5
|
|
|
@@ -16,12 +16,87 @@ declare class Clipboard {
|
|
|
16
16
|
declare class Dimensions {
|
|
17
17
|
static get windowWidth(): number;
|
|
18
18
|
static get windowHeight(): number;
|
|
19
|
+
static get statusBarWidth(): number;
|
|
20
|
+
static get statusBarHeight(): number;
|
|
19
21
|
static get ratio(): number;
|
|
20
22
|
static byWindowWidth(value: number): number;
|
|
21
23
|
static byWindowHeight(value: number): number;
|
|
22
24
|
static byRatio(value: number): number;
|
|
23
25
|
}
|
|
24
26
|
|
|
27
|
+
declare class Event {
|
|
28
|
+
isDefaultPrevented: boolean;
|
|
29
|
+
constructor();
|
|
30
|
+
preventDefault(): void;
|
|
31
|
+
overrideDefault(): void;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
type EventEmitterDefaultAction = Noop;
|
|
35
|
+
type EventEmitterListener<Params> = Callback<[Event & Params]>;
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* ### Create instance
|
|
39
|
+
* **Returns ```EventEmitter```**
|
|
40
|
+
* ```
|
|
41
|
+
* const emitter = new EventEmitter()
|
|
42
|
+
* const testEmitter = new EventEmitter<'test'>()
|
|
43
|
+
* const testEmitterWithParam = new EventEmitter<'test', { param: 'param' }>()
|
|
44
|
+
* ```
|
|
45
|
+
*
|
|
46
|
+
* ---
|
|
47
|
+
*
|
|
48
|
+
* ### EventEmitter.emit
|
|
49
|
+
* **Returns ```void```**
|
|
50
|
+
* ```
|
|
51
|
+
* emitter.emit('test')
|
|
52
|
+
* emitter.emit('test', { param: 'param' })
|
|
53
|
+
* emitter.emit('test', undefined, () => 'default')
|
|
54
|
+
* emitter.emit('test', { param: 'param' }, () => 'default')
|
|
55
|
+
* ```
|
|
56
|
+
*
|
|
57
|
+
* ---
|
|
58
|
+
*
|
|
59
|
+
* ### EventEmitter.on
|
|
60
|
+
* **Returns ```Noop```**
|
|
61
|
+
* ```
|
|
62
|
+
* const listener = () => null
|
|
63
|
+
* emitter.on('test', listener)
|
|
64
|
+
*
|
|
65
|
+
* emitter.on('test', () => null)
|
|
66
|
+
* emitter.on('test', (event) => null)
|
|
67
|
+
* emitter.on('test', ({ param }) => null)
|
|
68
|
+
* ```
|
|
69
|
+
*
|
|
70
|
+
* ---
|
|
71
|
+
*
|
|
72
|
+
* ### EventEmitter.off
|
|
73
|
+
* **Returns ```void```**
|
|
74
|
+
* ```
|
|
75
|
+
* const listener = () => 'event'
|
|
76
|
+
* emitter.off(listener)
|
|
77
|
+
*
|
|
78
|
+
* const unsubscribe = emitter.on('test', () => 'event')
|
|
79
|
+
* unsubscribe()
|
|
80
|
+
* ```
|
|
81
|
+
*
|
|
82
|
+
* ---
|
|
83
|
+
*
|
|
84
|
+
* ### EventEmitter.clear
|
|
85
|
+
* **Returns ```void```**
|
|
86
|
+
* ```
|
|
87
|
+
* EventEmitter.clear('clear')
|
|
88
|
+
* ```
|
|
89
|
+
*/
|
|
90
|
+
declare class EventEmitter<EventName extends string = string, EventParam extends Nullable<object> = undefined> {
|
|
91
|
+
#private;
|
|
92
|
+
constructor();
|
|
93
|
+
get eventNameList(): EventName[];
|
|
94
|
+
emit(name: EventName, param?: EventParam, defaultAction?: EventEmitterDefaultAction): void;
|
|
95
|
+
on(name: EventName, listener: EventEmitterListener<EventParam>): () => void;
|
|
96
|
+
off(name: EventName, listener: EventEmitterListener<EventParam>): void;
|
|
97
|
+
clear(name: EventName): void;
|
|
98
|
+
}
|
|
99
|
+
|
|
25
100
|
declare enum PlatformOS {
|
|
26
101
|
Ios = "ios",
|
|
27
102
|
Android = "android"
|
|
@@ -32,10 +107,11 @@ type PlatformByData<Value> = Include<BaseRecord<Value, PlatformOS>, PlatformRequ
|
|
|
32
107
|
|
|
33
108
|
declare class Platform {
|
|
34
109
|
static get OS(): "ios" | "android" | "windows" | "macos" | "web";
|
|
110
|
+
static get version(): string | number;
|
|
35
111
|
static get isIos(): boolean;
|
|
36
112
|
static get isAndroid(): boolean;
|
|
37
113
|
static by<Value>(data: PlatformByData<Value>, defaultOS?: PlatformRequiredOS): Value;
|
|
38
114
|
}
|
|
39
115
|
|
|
40
|
-
export { Clipboard, Dimensions, Platform, PlatformOS };
|
|
116
|
+
export { Clipboard, Dimensions, EventEmitter, Platform, PlatformOS };
|
|
41
117
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sources":["../../src/helpers/Clipboard/Clipboard.types.ts","../../src/helpers/Clipboard/Clipboard.ts","../../src/helpers/Dimensions/Dimensions.ts","../../src/helpers/Platform/Platform.constants.ts","../../src/helpers/Platform/Platform.types.ts","../../src/helpers/Platform/Platform.ts"],"sourcesContent":["type ClipboardValue = string\n\nexport type { ClipboardValue }\n","import NativeClipboard from '@react-native-clipboard/clipboard'\nimport { Log } from '@mediacubeco/javascript-base/helpers'\nimport { ClipboardValue } from './Clipboard.types'\n\nclass Clipboard {\n static copy(value: ClipboardValue) {\n Log.formatted.info('copy', value)\n\n return NativeClipboard.setString(value.toString())\n }\n\n static async paste() {\n const value = await NativeClipboard.getString()\n\n Log.formatted.info('paste', value)\n\n return value\n }\n}\n\nexport default Clipboard\n","import { Dimensions as NativeDimensions } from 'react-native'\nimport { DIMENSIONS_DESIGN_HEIGHT, DIMENSIONS_DESIGN_WIDTH } from './Dimensions.constants'\n\n/**\n * window: reports width/height without the soft menu bar\n *\n * screen: reports entire screen's width/height\n */\nclass Dimensions {\n static get windowWidth() {\n return NativeDimensions.get('window').width\n }\n\n static get windowHeight() {\n return NativeDimensions.get('window').height\n }\n\n static get ratio() {\n const widthRatio = Dimensions.windowWidth / DIMENSIONS_DESIGN_WIDTH\n const heightRatio = Dimensions.windowHeight / DIMENSIONS_DESIGN_HEIGHT\n\n return Math.min(widthRatio, heightRatio)\n }\n\n static byWindowWidth(value: number) {\n return Dimensions.windowWidth * value\n }\n\n static byWindowHeight(value: number) {\n return Dimensions.windowHeight * value\n }\n\n static byRatio(value: number) {\n return Dimensions.ratio * value\n }\n}\n\nexport default Dimensions\n","enum PlatformOS {\n Ios = 'ios',\n Android = 'android'\n // Macos = 'macos',\n // Windows = 'windows',\n // Web = 'web',\n}\n\nexport { PlatformOS }\n","import { BaseRecord, Include } from '@mediacubeco/javascript-base/types'\nimport { PlatformOS } from './Platform.constants'\n\ntype PlatformRequiredOS = PlatformOS.Ios | PlatformOS.Android\n\ntype PlatformByData<Value> = Include<BaseRecord<Value, PlatformOS>, PlatformRequiredOS>\n\nexport type { PlatformRequiredOS, PlatformByData }\n","import { Platform as NativePlatform } from 'react-native'\nimport { PlatformOS } from './Platform.constants'\nimport { PlatformByData, PlatformRequiredOS } from './Platform.types'\n\nclass Platform {\n static get OS() {\n return NativePlatform.OS\n }\n\n static get isIos() {\n return Platform.OS === 'ios'\n }\n\n static get isAndroid() {\n return Platform.OS === 'android'\n }\n\n // static get isMac() {\n // return Platform.OS === 'macos'\n // }\n\n // static get isWindows() {\n // return Platform.OS === 'windows'\n // }\n\n // static get isWeb() {\n // return Platform.OS === 'web'\n // }\n\n static by<Value>(data: PlatformByData<Value>, defaultOS: PlatformRequiredOS = PlatformOS.Ios) {\n return NativePlatform.select({ ...data, default: data[defaultOS] })\n }\n}\n\nexport default Platform\n"],"names":[],"mappings":";;;AAAA;;ACCA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sources":["../../src/helpers/Clipboard/Clipboard.types.ts","../../src/helpers/Clipboard/Clipboard.ts","../../src/helpers/Dimensions/Dimensions.ts","../../src/helpers/EventEmitter/Event/Event.ts","../../src/helpers/EventEmitter/EventEmitter.types.ts","../../src/helpers/EventEmitter/EventEmitter.ts","../../src/helpers/Platform/Platform.constants.ts","../../src/helpers/Platform/Platform.types.ts","../../src/helpers/Platform/Platform.ts"],"sourcesContent":["type ClipboardValue = string\n\nexport type { ClipboardValue }\n","import NativeClipboard from '@react-native-clipboard/clipboard'\nimport { Log } from '@mediacubeco/javascript-base/helpers'\nimport { ClipboardValue } from './Clipboard.types'\n\nclass Clipboard {\n static copy(value: ClipboardValue) {\n Log.formatted.info('copy', value)\n\n return NativeClipboard.setString(value.toString())\n }\n\n static async paste() {\n const value = await NativeClipboard.getString()\n\n Log.formatted.info('paste', value)\n\n return value\n }\n}\n\nexport default Clipboard\n","import { Dimensions as NativeDimensions, StatusBar } from 'react-native'\nimport { DIMENSIONS_DESIGN_HEIGHT, DIMENSIONS_DESIGN_WIDTH } from './Dimensions.constants'\n\n/**\n * window: reports width/height without the soft menu bar\n *\n * screen: reports entire screen's width/height\n */\nclass Dimensions {\n static get windowWidth() {\n return NativeDimensions.get('window').width\n }\n\n static get windowHeight() {\n return NativeDimensions.get('window').height\n }\n\n static get statusBarWidth() {\n return Dimensions.windowWidth\n }\n\n static get statusBarHeight() {\n return StatusBar.currentHeight ?? 0\n }\n\n static get ratio() {\n const widthRatio = Dimensions.windowWidth / DIMENSIONS_DESIGN_WIDTH\n const heightRatio = Dimensions.windowHeight / DIMENSIONS_DESIGN_HEIGHT\n\n return Math.min(widthRatio, heightRatio)\n }\n\n static byWindowWidth(value: number) {\n return Dimensions.windowWidth * value\n }\n\n static byWindowHeight(value: number) {\n return Dimensions.windowHeight * value\n }\n\n static byRatio(value: number) {\n return Dimensions.ratio * value\n }\n}\n\nexport default Dimensions\n","class Event {\n isDefaultPrevented = false\n\n constructor() {\n this.preventDefault = this.preventDefault.bind(this)\n this.overrideDefault = this.overrideDefault.bind(this)\n }\n\n preventDefault() {\n this.isDefaultPrevented = true\n }\n\n overrideDefault() {\n this.isDefaultPrevented = false\n }\n}\n\nexport default Event\n","import { BaseRecord, Callback, Noop, Nullable } from '../../types'\nimport Event from './Event'\n\ntype EventEmitterDefaultAction = Noop\n\ninterface EventEmitterConfig<Params> {\n event: Event\n listenerList: EventEmitterListener<Params>[]\n}\n\ntype EventEmitterSubscriptions<Key extends string, Params> = BaseRecord<\n Nullable<EventEmitterConfig<Params>>,\n Key\n>\n\ntype EventEmitterListener<Params> = Callback<[Event & Params]>\n\nexport type { EventEmitterDefaultAction, EventEmitterSubscriptions, EventEmitterListener }\n","import { runCallback } from '../../utils'\nimport { Nullable } from '../../types'\nimport {\n EventEmitterDefaultAction,\n EventEmitterListener,\n EventEmitterSubscriptions\n} from './EventEmitter.types'\nimport Event from './Event'\n\n/**\n * ### Create instance\n * **Returns ```EventEmitter```**\n * ```\n * const emitter = new EventEmitter()\n * const testEmitter = new EventEmitter<'test'>()\n * const testEmitterWithParam = new EventEmitter<'test', { param: 'param' }>()\n * ```\n *\n * ---\n *\n * ### EventEmitter.emit\n * **Returns ```void```**\n * ```\n * emitter.emit('test')\n * emitter.emit('test', { param: 'param' })\n * emitter.emit('test', undefined, () => 'default')\n * emitter.emit('test', { param: 'param' }, () => 'default')\n * ```\n *\n * ---\n *\n * ### EventEmitter.on\n * **Returns ```Noop```**\n * ```\n * const listener = () => null\n * emitter.on('test', listener)\n *\n * emitter.on('test', () => null)\n * emitter.on('test', (event) => null)\n * emitter.on('test', ({ param }) => null)\n * ```\n *\n * ---\n *\n * ### EventEmitter.off\n * **Returns ```void```**\n * ```\n * const listener = () => 'event'\n * emitter.off(listener)\n *\n * const unsubscribe = emitter.on('test', () => 'event')\n * unsubscribe()\n * ```\n *\n * ---\n *\n * ### EventEmitter.clear\n * **Returns ```void```**\n * ```\n * EventEmitter.clear('clear')\n * ```\n */\nclass EventEmitter<\n EventName extends string = string,\n EventParam extends Nullable<object> = undefined\n> {\n #subscriptions = {} as EventEmitterSubscriptions<EventName, EventParam>\n\n constructor() {\n this.emit = this.emit.bind(this)\n this.on = this.on.bind(this)\n this.off = this.off.bind(this)\n this.clear = this.clear.bind(this)\n }\n\n get eventNameList() {\n return Object.keys(this.#subscriptions) as EventName[]\n }\n\n emit(name: EventName, param?: EventParam, defaultAction?: EventEmitterDefaultAction) {\n const subscription = this.#subscriptions[name]\n\n if (!subscription) return runCallback(defaultAction)\n\n const { event, listenerList } = subscription\n\n listenerList.forEach((listener) => runCallback(listener, { ...event, ...(param as any) }))\n\n !event.isDefaultPrevented && runCallback(defaultAction)\n }\n\n on(name: EventName, listener: EventEmitterListener<EventParam>) {\n const subscription = this.#subscriptions[name]\n\n subscription\n ? subscription.listenerList.push(listener)\n : (this.#subscriptions[name] = { event: new Event(), listenerList: [listener] })\n\n return () => this.off(name, listener)\n }\n\n off(name: EventName, listener: EventEmitterListener<EventParam>) {\n const subscription = this.#subscriptions[name]\n\n if (!subscription) return\n\n const { event, listenerList } = subscription\n\n this.#subscriptions[name] = {\n event,\n listenerList: listenerList.filter((listenerItem) => listenerItem !== listener)\n }\n\n event.overrideDefault()\n }\n\n clear(name: EventName) {\n delete this.#subscriptions[name]\n }\n}\n\nexport default EventEmitter\n","enum PlatformOS {\n Ios = 'ios',\n Android = 'android'\n // Macos = 'macos',\n // Windows = 'windows',\n // Web = 'web',\n}\n\nexport { PlatformOS }\n","import { BaseRecord, Include } from '@mediacubeco/javascript-base/types'\nimport { PlatformOS } from './Platform.constants'\n\ntype PlatformRequiredOS = PlatformOS.Ios | PlatformOS.Android\n\ntype PlatformByData<Value> = Include<BaseRecord<Value, PlatformOS>, PlatformRequiredOS>\n\nexport type { PlatformRequiredOS, PlatformByData }\n","import { Platform as NativePlatform } from 'react-native'\nimport { PlatformOS } from './Platform.constants'\nimport { PlatformByData, PlatformRequiredOS } from './Platform.types'\n\n// Platform.Version\nclass Platform {\n static get OS() {\n return NativePlatform.OS\n }\n\n static get version() {\n return NativePlatform.Version\n }\n\n static get isIos() {\n return Platform.OS === 'ios'\n }\n\n static get isAndroid() {\n return Platform.OS === 'android'\n }\n\n // static get isMac() {\n // return Platform.OS === 'macos'\n // }\n\n // static get isWindows() {\n // return Platform.OS === 'windows'\n // }\n\n // static get isWeb() {\n // return Platform.OS === 'web'\n // }\n\n static by<Value>(data: PlatformByData<Value>, defaultOS: PlatformRequiredOS = PlatformOS.Ios) {\n return NativePlatform.select({ ...data, default: data[defaultOS] })\n }\n}\n\nexport default Platform\n"],"names":[],"mappings":";;;AAAA;;ACCA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;;ACHA;AAMA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/DA;AACA;AACA;AACA;;ACDA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;;"}
|
package/dist/helpers/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import t from"@react-native-clipboard/clipboard";import{Dimensions as
|
|
1
|
+
import{isAxiosError as t}from"axios";import e from"@react-native-clipboard/clipboard";import{Dimensions as s,StatusBar as i,Platform as r}from"react-native";const n=t=>t instanceof Error,a=t=>{for(let e in t)return!1;return!0},o=(t="?",...e)=>{const s=(t&&(i=t,"string"==typeof i)?t:"?").toUpperCase();var i;const r=e.reduce((t,e,s,{length:i})=>{const r=s===i-1?[]:["|"];return t.push(e,...r),t},e.length?["-"]:[]);return[`[${s}]`,...r]};var c,u,d;(d=c||(c={})).StartGroup="group",d.EndGroup="groupEnd",d.Default="log",function(t){t.Info="[36m%s[0m",t.Success="[32m%s[0m",t.Warning="[33m%s[0m",t.Danger="[31m%s[0m"}(u||(u={}));class l{static formatted={info:(...t)=>l.info(...o(...t)),success:(...t)=>l.success(...o(...t)),warning:(...t)=>l.warning(...o(...t)),danger:(...t)=>l.danger(...o(...t))};static#t(t,...e){console[t](...e)}static startGroup(t,e,...s){l.#t(c.StartGroup,...((t,...e)=>["%c%s",t,...e])(`font-size: 16px;${e}`,...o(t,...s)))}static endGroup(){l.#t(c.EndGroup)}static info(...t){l.#t(c.Default,u.Info,...t)}static success(...t){l.#t(c.Default,u.Success,...t)}static warning(...t){l.#t(c.Default,u.Warning,...t)}static danger(...t){l.#t(c.Default,u.Danger,...t)}}class h{static ignore(t){}static create(t,e){return new Error(t,{cause:e})}static throw(t,e){throw h.create(t,e)}static capture(t,e){const{signal:s,message:i,payload:r,stack:a}=e,o=[i,n(t)?t.message:void 0].filter(Boolean);l.formatted.danger(s,...o,{error:t,payload:r,stack:a})}static forward(t,e){throw h.capture(t,e),t}static parse(e){const s="Some error!",i=0,r={};switch(!0){case t(e):{const{status:t=i,data:n,config:o}=e.response??{},{message:c=s,errors:u=r}=n??{};return{message:c,status:t,errors:u,isExternal:a(u)}}case n(e):return{message:e.message,status:i,errors:r,isExternal:!0};default:return{message:s,status:i,errors:r,isExternal:!0}}}}class f{static copy(t){return l.formatted.info("copy",t),e.setString(t.toString())}static async paste(){const t=await e.getString();return l.formatted.info("paste",t),t}}class g{static get windowWidth(){return s.get("window").width}static get windowHeight(){return s.get("window").height}static get statusBarWidth(){return g.windowWidth}static get statusBarHeight(){return i.currentHeight??0}static get ratio(){const t=g.windowWidth/375,e=g.windowHeight/812;return Math.min(t,e)}static byWindowWidth(t){return g.windowWidth*t}static byWindowHeight(t){return g.windowHeight*t}static byRatio(t){return g.ratio*t}}const p=(t,...e)=>{if((t=>t instanceof Function)(t))return t(...e)};var w,m,b;!function(t){t.Active="active",t.Inactive="inactive",t.Background="background",t.Extension="extension",t.Unknown="unknown"}(w||(w={})),function(t){t.onWillShow="keyboardWillShow",t.onDidShow="keyboardDidShow",t.onWillHide="keyboardWillHide",t.onDidHide="keyboardDidHide",t.onWillChangeFrame="keyboardWillChangeFrame",t.onDidChangeFrame="keyboardDidChangeFrame"}(m||(m={}));class v{isDefaultPrevented=!1;constructor(){this.preventDefault=this.preventDefault.bind(this),this.overrideDefault=this.overrideDefault.bind(this)}preventDefault(){this.isDefaultPrevented=!0}overrideDefault(){this.isDefaultPrevented=!1}}class D{#e={};constructor(){this.emit=this.emit.bind(this),this.on=this.on.bind(this),this.off=this.off.bind(this),this.clear=this.clear.bind(this)}get eventNameList(){return Object.keys(this.#e)}emit(t,e,s){const i=this.#e[t];if(!i)return p(s);const{event:r,listenerList:n}=i;n.forEach(t=>p(t,{...r,...e})),!r.isDefaultPrevented&&p(s)}on(t,e){const s=this.#e[t];return s?s.listenerList.push(e):this.#e[t]={event:new v,listenerList:[e]},()=>this.off(t,e)}off(t,e){const s=this.#e[t];if(!s)return;const{event:i,listenerList:r}=s;this.#e[t]={event:i,listenerList:r.filter(t=>t!==e)},i.overrideDefault()}clear(t){delete this.#e[t]}}!function(t){t.Ios="ios",t.Android="android"}(b||(b={}));class y{static get OS(){return r.OS}static get version(){return r.Version}static get isIos(){return"ios"===y.OS}static get isAndroid(){return"android"===y.OS}static by(t,e=b.Ios){return r.select({...t,default:t[e]})}}export{f as Clipboard,g as Dimensions,h as ErrorHandler,D as EventEmitter,l as Log,y as Platform,b as PlatformOS};
|
|
2
2
|
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../node_modules/@mediacubeco/javascript-base/dist/helpers/index.mjs","../../src/helpers/Clipboard/Clipboard.ts","../../src/helpers/Dimensions/Dimensions.ts","../../src/helpers/Dimensions/Dimensions.constants.ts","../../src/helpers/Platform/Platform.constants.ts","../../src/helpers/Platform/Platform.ts"],"sourcesContent":["const t=t=>t instanceof Error,s=(t=\"?\",...s)=>{const r=(t&&(a=t,\"string\"==typeof a)?t:\"?\").toUpperCase();var a;const e=s.reduce((t,s,r,{length:a})=>{const e=r===a-1?[]:[\"|\"];return t.push(s,...e),t},s.length?[\"-\"]:[]);return[`[${r}]`,...e]};var r,a;!function(t){t.StartGroup=\"group\",t.EndGroup=\"groupEnd\",t.Default=\"log\"}(r||(r={})),function(t){t.Info=\"\u001b[36m%s\u001b[0m\",t.Success=\"\u001b[32m%s\u001b[0m\",t.Warning=\"\u001b[33m%s\u001b[0m\",t.Danger=\"\u001b[31m%s\u001b[0m\"}(a||(a={}));class e{static formatted={info:(...t)=>e.info(...s(...t)),success:(...t)=>e.success(...s(...t)),warning:(...t)=>e.warning(...s(...t)),danger:(...t)=>e.danger(...s(...t))};static#t(t,...s){console[t](...s)}static startGroup(t,a,...o){e.#t(r.StartGroup,...((t,...s)=>[\"%c%s\",t,...s])(`font-size: 16px;${a}`,...s(t,...o)))}static endGroup(){e.#t(r.EndGroup)}static info(...t){e.#t(r.Default,a.Info,...t)}static success(...t){e.#t(r.Default,a.Success,...t)}static warning(...t){e.#t(r.Default,a.Warning,...t)}static danger(...t){e.#t(r.Default,a.Danger,...t)}}class o{static create(t,s){return new Error(t,{cause:s})}static throw(t,s){throw o.create(t,s)}static capture(s,r){const{signal:a,message:o,payload:n,stack:c}=r,i=[o,t(s)?s.message:void 0].filter(Boolean);e.formatted.danger(a,...i,{error:s,payload:n,stack:c})}static forward(t,s){throw o.capture(t,s),t}static parse(s){const r={};return!0===t(s)?{message:s.message,status:0,errors:r,isExternal:!0}:{message:\"Some error!\",status:0,errors:r,isExternal:!0}}}export{o as ErrorHandler,e as Log};\n//# sourceMappingURL=index.mjs.map\n","import NativeClipboard from '@react-native-clipboard/clipboard'\nimport { Log } from '@mediacubeco/javascript-base/helpers'\nimport { ClipboardValue } from './Clipboard.types'\n\nclass Clipboard {\n static copy(value: ClipboardValue) {\n Log.formatted.info('copy', value)\n\n return NativeClipboard.setString(value.toString())\n }\n\n static async paste() {\n const value = await NativeClipboard.getString()\n\n Log.formatted.info('paste', value)\n\n return value\n }\n}\n\nexport default Clipboard\n","import { Dimensions as NativeDimensions } from 'react-native'\nimport { DIMENSIONS_DESIGN_HEIGHT, DIMENSIONS_DESIGN_WIDTH } from './Dimensions.constants'\n\n/**\n * window: reports width/height without the soft menu bar\n *\n * screen: reports entire screen's width/height\n */\nclass Dimensions {\n static get windowWidth() {\n return NativeDimensions.get('window').width\n }\n\n static get windowHeight() {\n return NativeDimensions.get('window').height\n }\n\n static get ratio() {\n const widthRatio = Dimensions.windowWidth / DIMENSIONS_DESIGN_WIDTH\n const heightRatio = Dimensions.windowHeight / DIMENSIONS_DESIGN_HEIGHT\n\n return Math.min(widthRatio, heightRatio)\n }\n\n static byWindowWidth(value: number) {\n return Dimensions.windowWidth * value\n }\n\n static byWindowHeight(value: number) {\n return Dimensions.windowHeight * value\n }\n\n static byRatio(value: number) {\n return Dimensions.ratio * value\n }\n}\n\nexport default Dimensions\n","const DIMENSIONS_DESIGN_WIDTH = 375\n\nconst DIMENSIONS_DESIGN_HEIGHT = 812\n\nexport { DIMENSIONS_DESIGN_WIDTH, DIMENSIONS_DESIGN_HEIGHT }\n","enum PlatformOS {\n Ios = 'ios',\n Android = 'android'\n // Macos = 'macos',\n // Windows = 'windows',\n // Web = 'web',\n}\n\nexport { PlatformOS }\n","import { Platform as NativePlatform } from 'react-native'\nimport { PlatformOS } from './Platform.constants'\nimport { PlatformByData, PlatformRequiredOS } from './Platform.types'\n\nclass Platform {\n static get OS() {\n return NativePlatform.OS\n }\n\n static get isIos() {\n return Platform.OS === 'ios'\n }\n\n static get isAndroid() {\n return Platform.OS === 'android'\n }\n\n // static get isMac() {\n // return Platform.OS === 'macos'\n // }\n\n // static get isWindows() {\n // return Platform.OS === 'windows'\n // }\n\n // static get isWeb() {\n // return Platform.OS === 'web'\n // }\n\n static by<Value>(data: PlatformByData<Value>, defaultOS: PlatformRequiredOS = PlatformOS.Ios) {\n return NativePlatform.select({ ...data, default: data[defaultOS] })\n }\n}\n\nexport default Platform\n"],"names":["t","Error","s","r","a","toUpperCase","e","reduce","length","push","StartGroup","EndGroup","Default","Info","Success","Warning","Danger","static","info","success","warning","danger","console","startGroup","o","endGroup","create","cause","capture","signal","message","payload","n","stack","c","i","filter","Boolean","formatted","error","forward","parse","status","errors","isExternal","Clipboard","copy","value","Log","NativeClipboard","setString","toString","paste","getString","Dimensions","windowWidth","NativeDimensions","get","width","windowHeight","height","ratio","widthRatio","heightRatio","Math","min","byWindowWidth","byWindowHeight","byRatio","PlatformOS","Platform","OS","NativePlatform","isIos","isAndroid","by","data","defaultOS","Ios","select","default"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../node_modules/@mediacubeco/javascript-base/dist/helpers/index.mjs","../../src/helpers/Clipboard/Clipboard.ts","../../src/helpers/Dimensions/Dimensions.ts","../../src/helpers/Dimensions/Dimensions.constants.ts","../../node_modules/@mediacubeco/javascript-base/dist/utils/index.mjs","../../src/utils/listeners/appState.ts","../../src/utils/listeners/keyboard.ts","../../src/helpers/Platform/Platform.constants.ts","../../src/helpers/EventEmitter/Event/Event.ts","../../src/helpers/EventEmitter/EventEmitter.ts","../../src/helpers/Platform/Platform.ts"],"sourcesContent":["import{isAxiosError as t}from\"axios\";const s=t=>t instanceof Error,r=t=>{for(let s in t)return!1;return!0},e=(t=\"?\",...s)=>{const r=(t&&(e=t,\"string\"==typeof e)?t:\"?\").toUpperCase();var e;const a=s.reduce((t,s,r,{length:e})=>{const a=r===e-1?[]:[\"|\"];return t.push(s,...a),t},s.length?[\"-\"]:[]);return[`[${r}]`,...a]};var a,o;!function(t){t.StartGroup=\"group\",t.EndGroup=\"groupEnd\",t.Default=\"log\"}(a||(a={})),function(t){t.Info=\"\u001b[36m%s\u001b[0m\",t.Success=\"\u001b[32m%s\u001b[0m\",t.Warning=\"\u001b[33m%s\u001b[0m\",t.Danger=\"\u001b[31m%s\u001b[0m\"}(o||(o={}));class n{static formatted={info:(...t)=>n.info(...e(...t)),success:(...t)=>n.success(...e(...t)),warning:(...t)=>n.warning(...e(...t)),danger:(...t)=>n.danger(...e(...t))};static#t(t,...s){console[t](...s)}static startGroup(t,s,...r){n.#t(a.StartGroup,...((t,...s)=>[\"%c%s\",t,...s])(`font-size: 16px;${s}`,...e(t,...r)))}static endGroup(){n.#t(a.EndGroup)}static info(...t){n.#t(a.Default,o.Info,...t)}static success(...t){n.#t(a.Default,o.Success,...t)}static warning(...t){n.#t(a.Default,o.Warning,...t)}static danger(...t){n.#t(a.Default,o.Danger,...t)}}class c{static ignore(t){}static create(t,s){return new Error(t,{cause:s})}static throw(t,s){throw c.create(t,s)}static capture(t,r){const{signal:e,message:a,payload:o,stack:c}=r,i=[a,s(t)?t.message:void 0].filter(Boolean);n.formatted.danger(e,...i,{error:t,payload:o,stack:c})}static forward(t,s){throw c.capture(t,s),t}static parse(e){const a=\"Some error!\",o=0,n={};switch(!0){case t(e):{const{status:t=o,data:s,config:c}=e.response??{},{message:i=a,errors:u=n}=s??{};return{message:i,status:t,errors:u,isExternal:r(u)}}case s(e):return{message:e.message,status:o,errors:n,isExternal:!0};default:return{message:a,status:o,errors:n,isExternal:!0}}}}export{c as ErrorHandler,n as Log};\n//# sourceMappingURL=index.mjs.map\n","import NativeClipboard from '@react-native-clipboard/clipboard'\nimport { Log } from '@mediacubeco/javascript-base/helpers'\nimport { ClipboardValue } from './Clipboard.types'\n\nclass Clipboard {\n static copy(value: ClipboardValue) {\n Log.formatted.info('copy', value)\n\n return NativeClipboard.setString(value.toString())\n }\n\n static async paste() {\n const value = await NativeClipboard.getString()\n\n Log.formatted.info('paste', value)\n\n return value\n }\n}\n\nexport default Clipboard\n","import { Dimensions as NativeDimensions, StatusBar } from 'react-native'\nimport { DIMENSIONS_DESIGN_HEIGHT, DIMENSIONS_DESIGN_WIDTH } from './Dimensions.constants'\n\n/**\n * window: reports width/height without the soft menu bar\n *\n * screen: reports entire screen's width/height\n */\nclass Dimensions {\n static get windowWidth() {\n return NativeDimensions.get('window').width\n }\n\n static get windowHeight() {\n return NativeDimensions.get('window').height\n }\n\n static get statusBarWidth() {\n return Dimensions.windowWidth\n }\n\n static get statusBarHeight() {\n return StatusBar.currentHeight ?? 0\n }\n\n static get ratio() {\n const widthRatio = Dimensions.windowWidth / DIMENSIONS_DESIGN_WIDTH\n const heightRatio = Dimensions.windowHeight / DIMENSIONS_DESIGN_HEIGHT\n\n return Math.min(widthRatio, heightRatio)\n }\n\n static byWindowWidth(value: number) {\n return Dimensions.windowWidth * value\n }\n\n static byWindowHeight(value: number) {\n return Dimensions.windowHeight * value\n }\n\n static byRatio(value: number) {\n return Dimensions.ratio * value\n }\n}\n\nexport default Dimensions\n","const DIMENSIONS_DESIGN_WIDTH = 375\n\nconst DIMENSIONS_DESIGN_HEIGHT = 812\n\nexport { DIMENSIONS_DESIGN_WIDTH, DIMENSIONS_DESIGN_HEIGHT }\n","const e=e=>void 0===e,t=e=>null===e,n=n=>e(n)||t(n),o=e=>\"string\"==typeof e,r=e=>\"number\"==typeof e,i=e=>\"bigint\"==typeof e,s=e=>Number.isNaN(e),f=e=>\"boolean\"==typeof e,c=e=>\"symbol\"==typeof e,a=e=>\"object\"==typeof e,u=e=>{const t=[l,p,y,b,m,g,j,x,E,N,T].some(t=>t(e));return!!e&&\"object\"==typeof e&&!t},l=e=>Array.isArray(e),p=e=>e instanceof ArrayBuffer,y=e=>e instanceof Map,b=e=>e instanceof Set,m=e=>e instanceof Map,g=e=>e instanceof Set,j=e=>e instanceof Date,x=e=>e instanceof Error,A=e=>e instanceof Proxy,E=e=>e instanceof RegExp,N=e=>e instanceof Promise,T=e=>e instanceof Function;function h(e,t,n){return 2===arguments.length?t[e]:t[e]??n}const M=(e,...t)=>{if(T(e))return e(...t)},O=(e,t)=>{const n=Object.entries(e);return Object.fromEntries(n.map(([e,n],o,r)=>[e,t(e,n,o,r)]))},P=(e,t)=>{let n;return(...o)=>{n&&clearTimeout(n),n=setTimeout(()=>M(e,...o),t)}},S=(e,t)=>{let n=!0;return(...o)=>{n&&(M(e,...o),n=!1),setTimeout(()=>n=!0,t)}},d=e=>{for(let t in e)return!1;return!0},v=e=>0===e.length,B=(e,t)=>!(!a(t)||!(e in t)),D=(e,t=\"isVisible\")=>e.filter(e=>!B(t,e)||e[t]),F=e=>e.filter(e=>!n(e));export{P as debounce,D as filterByProperty,F as filterNullableValues,h as getValueByProperty,B as hasProperty,a as isAnyObject,l as isArray,p as isArrayBuffer,v as isArrayEmpty,i as isBigint,f as isBoolean,j as isDate,x as isError,T as isFunction,y as isMap,s as isNaN,t as isNull,n as isNullable,r as isNumber,u as isObject,d as isObjectEmpty,N as isPromise,A as isProxy,E as isRegExp,b as isSet,o as isString,c as isSymbol,e as isUndefined,m as isWeakMap,g as isWeakSet,O as mapRecord,M as runCallback,S as throttle};\n//# sourceMappingURL=index.mjs.map\n","import { AppState, AppStateStatus, NativeEventSubscription } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, Callback } from '@mediacubeco/javascript-base/types'\nimport { Platform } from '../../helpers'\n\ntype AppStateAdditionalHandlerName = 'onFocus' | 'onBlur'\n\ntype AppStateHandlerName =\n | AppStateAdditionalHandlerName\n | 'onActive'\n | 'onInactive'\n | 'onBackground'\n | 'onExtension'\n | 'onUnknown'\n | 'onChange'\n\ntype AppStateHandlerCallback = Callback<[AppStateStatus]>\n\ntype AppStateHandlers = Partial<BaseRecord<AppStateHandlerCallback, AppStateHandlerName>>\n\ninterface HandleChangeAppStateConfig {\n state: AppStateStatus\n handlers: Omit<AppStateHandlers, AppStateAdditionalHandlerName>\n}\n\ntype HandleChangeAppState = (config: HandleChangeAppStateConfig) => void\n\ntype ListenAppState = (handlers: AppStateHandlers) => NativeEventSubscription\n\nenum AppStatus {\n Active = 'active',\n Inactive = 'inactive',\n Background = 'background',\n Extension = 'extension',\n Unknown = 'unknown'\n}\n\nconst handleChangeAppState: HandleChangeAppState = ({ state, handlers }) => {\n const { onActive, onInactive, onBackground, onExtension, onUnknown, onChange } = handlers ?? {}\n\n const handler = {\n [AppStatus.Active]: onActive,\n [AppStatus.Inactive]: onInactive,\n [AppStatus.Background]: onBackground,\n [AppStatus.Extension]: onExtension,\n [AppStatus.Unknown]: onUnknown\n }[state]\n\n runCallback(onChange, state)\n runCallback(handler, state)\n}\n\nconst listenAppState: ListenAppState = ({ onFocus, onBlur, ...handlers }) => {\n const listenerList: NativeEventSubscription[] = []\n\n if (Platform.isAndroid) {\n listenerList.push(\n AppState.addEventListener('focus', (state) => runCallback(onFocus, state)),\n AppState.addEventListener('blur', (state) => runCallback(onBlur, state))\n )\n }\n\n listenerList.push(\n AppState.addEventListener('change', (state) => handleChangeAppState({ state, handlers }))\n )\n\n return {\n remove() {\n listenerList.forEach((listener) => listener.remove())\n }\n }\n}\n\nexport { listenAppState }\nexport type { AppStateHandlers }\n","import { Keyboard, KeyboardEventListener, NativeEventSubscription } from 'react-native'\nimport {\n mapRecord,\n filterNullableValues,\n isNullable\n} from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, KeyOf } from '@mediacubeco/javascript-base/types'\n\nenum KeyboardEventName {\n onWillShow = 'keyboardWillShow',\n onDidShow = 'keyboardDidShow',\n onWillHide = 'keyboardWillHide',\n onDidHide = 'keyboardDidHide',\n onWillChangeFrame = 'keyboardWillChangeFrame',\n onDidChangeFrame = 'keyboardDidChangeFrame'\n}\n\ntype KeyboardHandlers = Partial<BaseRecord<KeyboardEventListener, KeyOf<typeof KeyboardEventName>>>\n\ntype ListenKeyboard = (handlers: KeyboardHandlers) => NativeEventSubscription\n\nconst listenKeyboard: ListenKeyboard = (handlers) => {\n const list = mapRecord(handlers, (key, handler) => {\n if (isNullable(handler)) return\n\n return Keyboard.addListener(KeyboardEventName[key], handler)\n })\n\n return {\n remove() {\n return filterNullableValues(Object.values(list)).map((unsubscribe) => unsubscribe.remove())\n }\n }\n}\n\nexport { listenKeyboard }\nexport type { KeyboardHandlers }\n","enum PlatformOS {\n Ios = 'ios',\n Android = 'android'\n // Macos = 'macos',\n // Windows = 'windows',\n // Web = 'web',\n}\n\nexport { PlatformOS }\n","class Event {\n isDefaultPrevented = false\n\n constructor() {\n this.preventDefault = this.preventDefault.bind(this)\n this.overrideDefault = this.overrideDefault.bind(this)\n }\n\n preventDefault() {\n this.isDefaultPrevented = true\n }\n\n overrideDefault() {\n this.isDefaultPrevented = false\n }\n}\n\nexport default Event\n","import { runCallback } from '../../utils'\nimport { Nullable } from '../../types'\nimport {\n EventEmitterDefaultAction,\n EventEmitterListener,\n EventEmitterSubscriptions\n} from './EventEmitter.types'\nimport Event from './Event'\n\n/**\n * ### Create instance\n * **Returns ```EventEmitter```**\n * ```\n * const emitter = new EventEmitter()\n * const testEmitter = new EventEmitter<'test'>()\n * const testEmitterWithParam = new EventEmitter<'test', { param: 'param' }>()\n * ```\n *\n * ---\n *\n * ### EventEmitter.emit\n * **Returns ```void```**\n * ```\n * emitter.emit('test')\n * emitter.emit('test', { param: 'param' })\n * emitter.emit('test', undefined, () => 'default')\n * emitter.emit('test', { param: 'param' }, () => 'default')\n * ```\n *\n * ---\n *\n * ### EventEmitter.on\n * **Returns ```Noop```**\n * ```\n * const listener = () => null\n * emitter.on('test', listener)\n *\n * emitter.on('test', () => null)\n * emitter.on('test', (event) => null)\n * emitter.on('test', ({ param }) => null)\n * ```\n *\n * ---\n *\n * ### EventEmitter.off\n * **Returns ```void```**\n * ```\n * const listener = () => 'event'\n * emitter.off(listener)\n *\n * const unsubscribe = emitter.on('test', () => 'event')\n * unsubscribe()\n * ```\n *\n * ---\n *\n * ### EventEmitter.clear\n * **Returns ```void```**\n * ```\n * EventEmitter.clear('clear')\n * ```\n */\nclass EventEmitter<\n EventName extends string = string,\n EventParam extends Nullable<object> = undefined\n> {\n #subscriptions = {} as EventEmitterSubscriptions<EventName, EventParam>\n\n constructor() {\n this.emit = this.emit.bind(this)\n this.on = this.on.bind(this)\n this.off = this.off.bind(this)\n this.clear = this.clear.bind(this)\n }\n\n get eventNameList() {\n return Object.keys(this.#subscriptions) as EventName[]\n }\n\n emit(name: EventName, param?: EventParam, defaultAction?: EventEmitterDefaultAction) {\n const subscription = this.#subscriptions[name]\n\n if (!subscription) return runCallback(defaultAction)\n\n const { event, listenerList } = subscription\n\n listenerList.forEach((listener) => runCallback(listener, { ...event, ...(param as any) }))\n\n !event.isDefaultPrevented && runCallback(defaultAction)\n }\n\n on(name: EventName, listener: EventEmitterListener<EventParam>) {\n const subscription = this.#subscriptions[name]\n\n subscription\n ? subscription.listenerList.push(listener)\n : (this.#subscriptions[name] = { event: new Event(), listenerList: [listener] })\n\n return () => this.off(name, listener)\n }\n\n off(name: EventName, listener: EventEmitterListener<EventParam>) {\n const subscription = this.#subscriptions[name]\n\n if (!subscription) return\n\n const { event, listenerList } = subscription\n\n this.#subscriptions[name] = {\n event,\n listenerList: listenerList.filter((listenerItem) => listenerItem !== listener)\n }\n\n event.overrideDefault()\n }\n\n clear(name: EventName) {\n delete this.#subscriptions[name]\n }\n}\n\nexport default EventEmitter\n","import { Platform as NativePlatform } from 'react-native'\nimport { PlatformOS } from './Platform.constants'\nimport { PlatformByData, PlatformRequiredOS } from './Platform.types'\n\n// Platform.Version\nclass Platform {\n static get OS() {\n return NativePlatform.OS\n }\n\n static get version() {\n return NativePlatform.Version\n }\n\n static get isIos() {\n return Platform.OS === 'ios'\n }\n\n static get isAndroid() {\n return Platform.OS === 'android'\n }\n\n // static get isMac() {\n // return Platform.OS === 'macos'\n // }\n\n // static get isWindows() {\n // return Platform.OS === 'windows'\n // }\n\n // static get isWeb() {\n // return Platform.OS === 'web'\n // }\n\n static by<Value>(data: PlatformByData<Value>, defaultOS: PlatformRequiredOS = PlatformOS.Ios) {\n return NativePlatform.select({ ...data, default: data[defaultOS] })\n }\n}\n\nexport default Platform\n"],"names":["s","t","Error","r","e","toUpperCase","a","reduce","length","push","o","StartGroup","EndGroup","Default","Info","Success","Warning","Danger","n","static","info","success","warning","danger","console","startGroup","endGroup","c","ignore","create","cause","capture","signal","message","payload","stack","i","filter","Boolean","formatted","error","forward","parse","status","data","config","response","errors","u","isExternal","Clipboard","copy","value","Log","NativeClipboard","setString","toString","paste","getString","Dimensions","windowWidth","NativeDimensions","get","width","windowHeight","height","statusBarWidth","statusBarHeight","StatusBar","currentHeight","ratio","widthRatio","heightRatio","Math","min","byWindowWidth","byWindowHeight","byRatio","M","Function","T","AppStatus","KeyboardEventName","PlatformOS","Event","isDefaultPrevented","constructor","this","preventDefault","bind","overrideDefault","EventEmitter","subscriptions","emit","on","off","clear","eventNameList","Object","keys","name","param","defaultAction","subscription","runCallback","event","listenerList","forEach","listener","listenerItem","Platform","OS","NativePlatform","version","Version","isIos","isAndroid","by","defaultOS","Ios","select","default"],"mappings":"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","x_google_ignoreList":[0,4]}
|
package/dist/hooks/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var e=require("react"),t=require("react-native");require("@react-native-clipboard/clipboard");const n=e=>(e=>void 0===e)(e)||(e=>null===e)(e),r=(e,...t)=>{if((e=>e instanceof Function)(e))return e(...t)};var o,a,s
|
|
1
|
+
"use strict";var e=require("react"),t=require("react-native");require("axios"),require("@react-native-clipboard/clipboard");const n=e=>(e=>void 0===e)(e)||(e=>null===e)(e),r=(e,...t)=>{if((e=>e instanceof Function)(e))return e(...t)};var o,a,i,s;!function(e){e.StartGroup="group",e.EndGroup="groupEnd",e.Default="log"}(o||(o={})),function(e){e.Info="[36m%s[0m",e.Success="[32m%s[0m",e.Warning="[33m%s[0m",e.Danger="[31m%s[0m"}(a||(a={})),function(e){e.Ios="ios",e.Android="android"}(i||(i={}));class u{static get OS(){return t.Platform.OS}static get version(){return t.Platform.Version}static get isIos(){return"ios"===u.OS}static get isAndroid(){return"android"===u.OS}static by(e,n=i.Ios){return t.Platform.select({...e,default:e[n]})}}!function(e){e.Active="active",e.Inactive="inactive",e.Background="background",e.Extension="extension",e.Unknown="unknown"}(s||(s={}));const c=({onFocus:e,onBlur:n,...o})=>{const a=[];return u.isAndroid&&a.push(t.AppState.addEventListener("focus",t=>r(e,t)),t.AppState.addEventListener("blur",e=>r(n,e))),a.push(t.AppState.addEventListener("change",e=>(({state:e,handlers:t})=>{const{onActive:n,onInactive:o,onBackground:a,onExtension:i,onUnknown:u,onChange:c}=t??{},l={[s.Active]:n,[s.Inactive]:o,[s.Background]:a,[s.Extension]:i,[s.Unknown]:u}[e];r(c,e),r(l,e)})({state:e,handlers:o}))),{remove(){a.forEach(e=>e.remove())}}};var l;!function(e){e.onWillShow="keyboardWillShow",e.onDidShow="keyboardDidShow",e.onWillHide="keyboardWillHide",e.onDidHide="keyboardDidHide",e.onWillChangeFrame="keyboardWillChangeFrame",e.onDidChangeFrame="keyboardDidChangeFrame"}(l||(l={}));const d=e=>{const r=((e,t)=>{const n=Object.entries(e);return Object.fromEntries(n.map(([e,n],r,o)=>[e,t(e,n,r,o)]))})(e,(e,r)=>{if(!n(r))return t.Keyboard.addListener(l[e],r)});return{remove:()=>(e=>e.filter(e=>!n(e)))(Object.values(r)).map(e=>e.remove())}},h={top:0,left:0,width:0,height:0},g={top:null,left:null,width:null,height:null};const p={x:0,y:0,width:0,height:0,pageX:0,pageY:0},f={left:0,top:0,width:0,height:0},m={x:0,y:0,width:0,height:0};exports.DEFAULT_LAYOUT=h,exports.DEFAULT_NULLABLE_LAYOUT=g,exports.getResponder=e=>{const t=e.current?.getScrollResponder()??null,n=t?.getInnerViewRef?.()??null,r=t?.getNativeScrollRef?.()??null;return{responder:t,inner:n,outer:r}},exports.useAppState=t=>{e.useEffect(()=>{const e=c(t);return()=>e.remove()},[t])},exports.useKeyboard=t=>{e.useEffect(()=>{const e=d(t);return()=>{e.remove()}},[t])},exports.useLayout=function({onLayout:t,isNullable:n}={isNullable:!1}){const[o,a]=e.useState(n?g:h),i=e.useCallback(e=>{r(t,e);const{layout:n}=e.nativeEvent,{y:o,x:i,width:s,height:u}=n;a({top:o,left:i,width:s,height:u})},[t]);return[o,i]},exports.useMeasures=()=>{const t=e.useRef(p),r=e.useRef(f),o=e.useRef(m),a=e.useCallback(async(e,t,r)=>new Promise(o=>{n(e)?o(t):r(e,o)}),[]),i=e.useCallback(e=>a(e,p,(e,n)=>{e.measure((e=0,r=0,o=0,a=0,i=0,s=0)=>{t.current={x:e,y:r,width:o,height:a,pageX:i,pageY:s},n(t.current)})}),[]),s=e.useCallback((e,t)=>a(e,f,(e,n)=>{e.measureLayout(t,(e=0,t=0,o=0,a=0)=>{r.current={left:e,top:t,width:o,height:a},n(r.current)})}),[]),u=e.useCallback(e=>a(e,m,(e,t)=>{e.measureInWindow((e=0,n=0,r=0,a=0)=>{o.current={x:e,y:n,width:r,height:a},t(o.current)})}),[]);return{measuresRef:t,measuresInContainerRef:r,measuresInWindowRef:o,calculateMeasures:i,calculateMeasuresInContainer:s,calculateMeasuresInWindow:u}};
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/dist/hooks/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sources":["../../node_modules/@mediacubeco/javascript-base/dist/utils/index.mjs","../../node_modules/@mediacubeco/javascript-base/dist/helpers/index.mjs","../../src/helpers/Platform/Platform.constants.ts","../../src/utils/listeners/appState.ts","../../src/helpers/Platform/Platform.ts","../../src/utils/listeners/keyboard.ts","../../src/hooks/useLayout/useLayout.constants.ts","../../src/hooks/useMeasures/useMeasures.constants.ts","../../src/hooks/useMeasures/useMeasures.utils.ts","../../src/hooks/useAppState/useAppState.ts","../../src/hooks/useKeyboard/useKeyboard.ts","../../src/hooks/useLayout/useLayout.ts","../../src/hooks/useMeasures/useMeasures.ts"],"sourcesContent":["const e=e=>void 0===e,t=e=>null===e,n=n=>e(n)||t(n),o=e=>\"string\"==typeof e,r=e=>\"number\"==typeof e,i=e=>\"bigint\"==typeof e,s=e=>Number.isNaN(e),f=e=>\"boolean\"==typeof e,c=e=>\"symbol\"==typeof e,a=e=>\"object\"==typeof e,u=e=>{const t=[l,p,y,b,m,g,j,x,E,N,T].some(t=>t(e));return!!e&&\"object\"==typeof e&&!t},l=e=>Array.isArray(e),p=e=>e instanceof ArrayBuffer,y=e=>e instanceof Map,b=e=>e instanceof Set,m=e=>e instanceof Map,g=e=>e instanceof Set,j=e=>e instanceof Date,x=e=>e instanceof Error,A=e=>e instanceof Proxy,E=e=>e instanceof RegExp,N=e=>e instanceof Promise,T=e=>e instanceof Function;function h(e,t,n){return 2===arguments.length?t[e]:t[e]??n}const M=(e,...t)=>{if(T(e))return e(...t)},O=(e,t)=>{const n=Object.entries(e);return Object.fromEntries(n.map(([e,n],o,r)=>[e,t(e,n,o,r)]))},P=(e,t)=>{let n;return(...o)=>{n&&clearTimeout(n),n=setTimeout(()=>M(e,...o),t)}},S=(e,t)=>{let n=!0;return(...o)=>{n&&(M(e,...o),n=!1),setTimeout(()=>n=!0,t)}},d=e=>{for(let t in e)return!1;return!0},v=e=>0===e.length,B=(e,t)=>!(!a(t)||!(e in t)),D=(e,t=\"isVisible\")=>e.filter(e=>!B(t,e)||e[t]),F=e=>e.filter(e=>!n(e));export{P as debounce,D as filterByProperty,F as filterNullableValues,h as getValueByProperty,B as hasProperty,a as isAnyObject,l as isArray,p as isArrayBuffer,v as isArrayEmpty,i as isBigint,f as isBoolean,j as isDate,x as isError,T as isFunction,y as isMap,s as isNaN,t as isNull,n as isNullable,r as isNumber,u as isObject,d as isObjectEmpty,N as isPromise,A as isProxy,E as isRegExp,b as isSet,o as isString,c as isSymbol,e as isUndefined,m as isWeakMap,g as isWeakSet,O as mapRecord,M as runCallback,S as throttle};\n//# sourceMappingURL=index.mjs.map\n","const t=t=>t instanceof Error,s=(t=\"?\",...s)=>{const r=(t&&(a=t,\"string\"==typeof a)?t:\"?\").toUpperCase();var a;const e=s.reduce((t,s,r,{length:a})=>{const e=r===a-1?[]:[\"|\"];return t.push(s,...e),t},s.length?[\"-\"]:[]);return[`[${r}]`,...e]};var r,a;!function(t){t.StartGroup=\"group\",t.EndGroup=\"groupEnd\",t.Default=\"log\"}(r||(r={})),function(t){t.Info=\"\u001b[36m%s\u001b[0m\",t.Success=\"\u001b[32m%s\u001b[0m\",t.Warning=\"\u001b[33m%s\u001b[0m\",t.Danger=\"\u001b[31m%s\u001b[0m\"}(a||(a={}));class e{static formatted={info:(...t)=>e.info(...s(...t)),success:(...t)=>e.success(...s(...t)),warning:(...t)=>e.warning(...s(...t)),danger:(...t)=>e.danger(...s(...t))};static#t(t,...s){console[t](...s)}static startGroup(t,a,...o){e.#t(r.StartGroup,...((t,...s)=>[\"%c%s\",t,...s])(`font-size: 16px;${a}`,...s(t,...o)))}static endGroup(){e.#t(r.EndGroup)}static info(...t){e.#t(r.Default,a.Info,...t)}static success(...t){e.#t(r.Default,a.Success,...t)}static warning(...t){e.#t(r.Default,a.Warning,...t)}static danger(...t){e.#t(r.Default,a.Danger,...t)}}class o{static create(t,s){return new Error(t,{cause:s})}static throw(t,s){throw o.create(t,s)}static capture(s,r){const{signal:a,message:o,payload:n,stack:c}=r,i=[o,t(s)?s.message:void 0].filter(Boolean);e.formatted.danger(a,...i,{error:s,payload:n,stack:c})}static forward(t,s){throw o.capture(t,s),t}static parse(s){const r={};return!0===t(s)?{message:s.message,status:0,errors:r,isExternal:!0}:{message:\"Some error!\",status:0,errors:r,isExternal:!0}}}export{o as ErrorHandler,e as Log};\n//# sourceMappingURL=index.mjs.map\n","enum PlatformOS {\n Ios = 'ios',\n Android = 'android'\n // Macos = 'macos',\n // Windows = 'windows',\n // Web = 'web',\n}\n\nexport { PlatformOS }\n","import { AppState, AppStateStatus, NativeEventSubscription } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, Callback } from '@mediacubeco/javascript-base/types'\nimport { Platform } from '../../helpers'\n\ntype AppStateAdditionalHandlerName = 'onFocus' | 'onBlur'\n\ntype AppStateHandlerName =\n | AppStateAdditionalHandlerName\n | 'onActive'\n | 'onInactive'\n | 'onBackground'\n | 'onExtension'\n | 'onUnknown'\n | 'onChange'\n\ntype AppStateHandlerCallback = Callback<[AppStateStatus]>\n\ntype AppStateHandlers = Partial<BaseRecord<AppStateHandlerCallback, AppStateHandlerName>>\n\ninterface HandleChangeAppStateConfig {\n state: AppStateStatus\n handlers: Omit<AppStateHandlers, AppStateAdditionalHandlerName>\n}\n\ntype HandleChangeAppState = (config: HandleChangeAppStateConfig) => void\n\ntype ListenAppState = (handlers: AppStateHandlers) => NativeEventSubscription\n\nenum AppStatus {\n Active = 'active',\n Inactive = 'inactive',\n Background = 'background',\n Extension = 'extension',\n Unknown = 'unknown'\n}\n\nconst handleChangeAppState: HandleChangeAppState = ({ state, handlers }) => {\n const { onActive, onInactive, onBackground, onExtension, onUnknown, onChange } = handlers ?? {}\n\n const handler = {\n [AppStatus.Active]: onActive,\n [AppStatus.Inactive]: onInactive,\n [AppStatus.Background]: onBackground,\n [AppStatus.Extension]: onExtension,\n [AppStatus.Unknown]: onUnknown\n }[state]\n\n runCallback(onChange, state)\n runCallback(handler, state)\n}\n\nconst listenAppState: ListenAppState = ({ onFocus, onBlur, ...handlers }) => {\n const listenerList: NativeEventSubscription[] = []\n\n if (Platform.isAndroid) {\n listenerList.push(\n AppState.addEventListener('focus', (state) => runCallback(onFocus, state)),\n AppState.addEventListener('blur', (state) => runCallback(onBlur, state))\n )\n }\n\n listenerList.push(\n AppState.addEventListener('change', (state) => handleChangeAppState({ state, handlers }))\n )\n\n return {\n remove() {\n listenerList.forEach((listener) => listener.remove())\n }\n }\n}\n\nexport { listenAppState }\nexport type { AppStateHandlers }\n","import { Platform as NativePlatform } from 'react-native'\nimport { PlatformOS } from './Platform.constants'\nimport { PlatformByData, PlatformRequiredOS } from './Platform.types'\n\nclass Platform {\n static get OS() {\n return NativePlatform.OS\n }\n\n static get isIos() {\n return Platform.OS === 'ios'\n }\n\n static get isAndroid() {\n return Platform.OS === 'android'\n }\n\n // static get isMac() {\n // return Platform.OS === 'macos'\n // }\n\n // static get isWindows() {\n // return Platform.OS === 'windows'\n // }\n\n // static get isWeb() {\n // return Platform.OS === 'web'\n // }\n\n static by<Value>(data: PlatformByData<Value>, defaultOS: PlatformRequiredOS = PlatformOS.Ios) {\n return NativePlatform.select({ ...data, default: data[defaultOS] })\n }\n}\n\nexport default Platform\n","import { Keyboard, KeyboardEventListener, NativeEventSubscription } from 'react-native'\nimport {\n mapRecord,\n filterNullableValues,\n isNullable\n} from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, KeyOf } from '@mediacubeco/javascript-base/types'\n\nenum KeyboardEventName {\n onWillShow = 'keyboardWillShow',\n onDidShow = 'keyboardDidShow',\n onWillHide = 'keyboardWillHide',\n onDidHide = 'keyboardDidHide',\n onWillChangeFrame = 'keyboardWillChangeFrame',\n onDidChangeFrame = 'keyboardDidChangeFrame'\n}\n\ntype KeyboardHandlers = Partial<BaseRecord<KeyboardEventListener, KeyOf<typeof KeyboardEventName>>>\n\ntype ListenKeyboard = (handlers: KeyboardHandlers) => NativeEventSubscription\n\nconst listenKeyboard: ListenKeyboard = (handlers) => {\n const list = mapRecord(handlers, (key, handler) => {\n if (isNullable(handler)) return\n\n return Keyboard.addListener(KeyboardEventName[key], handler)\n })\n\n return {\n remove() {\n return filterNullableValues(Object.values(list)).map((unsubscribe) => unsubscribe.remove())\n }\n }\n}\n\nexport { listenKeyboard }\nexport type { KeyboardHandlers }\n","import { Layout, NullableLayout } from './useLayout.types'\n\nconst DEFAULT_LAYOUT: Layout = {\n top: 0,\n left: 0,\n width: 0,\n height: 0,\n}\n\nconst DEFAULT_NULLABLE_LAYOUT: NullableLayout = {\n top: null,\n left: null,\n width: null,\n height: null,\n}\n\nexport { DEFAULT_LAYOUT, DEFAULT_NULLABLE_LAYOUT }\n","const DEFAULT_MEASURES = { x: 0, y: 0, width: 0, height: 0, pageX: 0, pageY: 0 }\nconst DEFAULT_MEASURES_IN_CONTAINER = { left: 0, top: 0, width: 0, height: 0 }\nconst DEFAULT_MEASURES_IN_WINDOW = { x: 0, y: 0, width: 0, height: 0 }\n\nexport { DEFAULT_MEASURES, DEFAULT_MEASURES_IN_CONTAINER, DEFAULT_MEASURES_IN_WINDOW }\n","import { RefObject } from 'react'\nimport { FlatList, ScrollView, SectionList, View } from 'react-native'\nimport { Nullable } from '@mediacubeco/javascript-base/types'\n\nconst getResponder = <\n ScrolledCurrent extends Nullable<ScrollView | FlatList | SectionList>,\n Current extends Nullable<View>\n>(\n scrolledRef: RefObject<ScrolledCurrent>\n) => {\n const responder = scrolledRef.current?.getScrollResponder() ?? null\n\n const inner = (responder?.getInnerViewRef?.() ?? null) as Current\n const outer = (responder?.getNativeScrollRef?.() ?? null) as Current\n\n return { responder, inner, outer }\n}\n\nexport { getResponder }\n","import { useEffect } from 'react'\nimport { AppStateHandlers, listenAppState } from '../../utils/listeners'\n\nconst useAppState = (handlers: AppStateHandlers) => {\n useEffect(() => {\n const listener = listenAppState(handlers)\n\n return () => listener.remove()\n }, [handlers])\n}\n\nexport { useAppState }\n","import { useEffect } from 'react'\nimport { KeyboardHandlers, listenKeyboard } from '../../utils/listeners'\n\nconst useKeyboard = (handlers: KeyboardHandlers) => {\n useEffect(() => {\n const listener = listenKeyboard(handlers)\n\n return () => {\n listener.remove()\n }\n }, [handlers])\n}\n\nexport { useKeyboard }\n","import { useCallback, useState } from 'react'\nimport { LayoutChangeEvent } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { DEFAULT_LAYOUT, DEFAULT_NULLABLE_LAYOUT } from './useLayout.constants'\nimport { UseLayoutConfig, HandleLayout, Layout, NullableLayout } from './useLayout.types'\n\nfunction useLayout(config?: UseLayoutConfig<false>): [Layout, HandleLayout]\nfunction useLayout(config?: UseLayoutConfig<true>): [NullableLayout, HandleLayout]\nfunction useLayout({ onLayout, isNullable }: UseLayoutConfig = { isNullable: false }) {\n const [layout, setLayout] = useState(isNullable ? DEFAULT_NULLABLE_LAYOUT : DEFAULT_LAYOUT)\n\n const handleLayout = useCallback(\n (event: LayoutChangeEvent) => {\n runCallback(onLayout, event)\n\n const { layout } = event.nativeEvent\n const { y: top, x: left, width, height } = layout\n\n setLayout({ top, left, width, height })\n },\n [onLayout]\n )\n\n return [layout, handleLayout] as const\n}\n\nexport { useLayout }\n","import { useCallback, useRef } from 'react'\nimport { isNullable } from '@mediacubeco/javascript-base/utils'\nimport {\n DEFAULT_MEASURES,\n DEFAULT_MEASURES_IN_CONTAINER,\n DEFAULT_MEASURES_IN_WINDOW\n} from './useMeasures.constants'\nimport {\n Calculate,\n CalculateMeasures,\n CalculateMeasuresInContainer,\n CalculateMeasuresInWindow,\n Measures,\n MeasuresInContainer,\n MeasuresInWindow,\n OnResolve\n} from './useMeasures.types'\n\nconst useMeasures = () => {\n const measuresRef = useRef(DEFAULT_MEASURES)\n const measuresInContainerRef = useRef(DEFAULT_MEASURES_IN_CONTAINER)\n const measuresInWindowRef = useRef(DEFAULT_MEASURES_IN_WINDOW)\n\n const calculate: Calculate = useCallback(async (current, defaultData, onResolve) => {\n return new Promise((resolve) => {\n if (isNullable(current)) {\n resolve(defaultData)\n } else {\n onResolve(current, resolve)\n }\n })\n }, [])\n\n const calculateMeasures: CalculateMeasures = useCallback((current) => {\n const onResolve: OnResolve<Measures> = (current, resolve) => {\n current.measure((x = 0, y = 0, width = 0, height = 0, pageX = 0, pageY = 0) => {\n measuresRef.current = { x, y, width, height, pageX, pageY }\n\n resolve(measuresRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES, onResolve)\n }, [])\n\n const calculateMeasuresInContainer: CalculateMeasuresInContainer = useCallback(\n (current, container) => {\n const onResolve: OnResolve<MeasuresInContainer> = (current, resolve) => {\n current.measureLayout(container, (left = 0, top = 0, width = 0, height = 0) => {\n measuresInContainerRef.current = { left, top, width, height }\n\n resolve(measuresInContainerRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES_IN_CONTAINER, onResolve)\n },\n []\n )\n\n const calculateMeasuresInWindow: CalculateMeasuresInWindow = useCallback((current) => {\n const onResolve: OnResolve<MeasuresInWindow> = (current, resolve) => {\n current.measureInWindow((x = 0, y = 0, width = 0, height = 0) => {\n measuresInWindowRef.current = { x, y, width, height }\n\n resolve(measuresInWindowRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES_IN_WINDOW, onResolve)\n }, [])\n\n return {\n measuresRef,\n measuresInContainerRef,\n measuresInWindowRef,\n calculateMeasures,\n calculateMeasuresInContainer,\n calculateMeasuresInWindow\n }\n}\n\nexport { useMeasures }\n"],"names":["n","e","t","M","Function","T","r","a","PlatformOS","AppStatus","StartGroup","EndGroup","Default","Info","Success","Warning","Danger","Platform","OS","NativePlatform","isIos","isAndroid","by","data","defaultOS","Ios","select","default","listenAppState","onFocus","onBlur","handlers","listenerList","push","AppState","addEventListener","state","runCallback","handleChangeAppState","onActive","onInactive","onBackground","onExtension","onUnknown","onChange","handler","Active","Inactive","Background","Extension","Unknown","remove","forEach","listener","KeyboardEventName","listenKeyboard","list","Object","entries","fromEntries","map","o","mapRecord","key","isNullable","Keyboard","addListener","filter","filterNullableValues","values","unsubscribe","DEFAULT_LAYOUT","top","left","width","height","DEFAULT_NULLABLE_LAYOUT","DEFAULT_MEASURES","x","y","pageX","pageY","DEFAULT_MEASURES_IN_CONTAINER","DEFAULT_MEASURES_IN_WINDOW","scrolledRef","responder","current","getScrollResponder","inner","getInnerViewRef","outer","getNativeScrollRef","useEffect","onLayout","layout","setLayout","useState","handleLayout","useCallback","event","nativeEvent","useMeasures","measuresRef","useRef","measuresInContainerRef","measuresInWindowRef","calculate","async","defaultData","onResolve","Promise","resolve","calculateMeasures","measure","calculateMeasuresInContainer","container","measureLayout","calculateMeasuresInWindow","measureInWindow"],"mappings":"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","x_google_ignoreList":[0,1]}
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../../node_modules/@mediacubeco/javascript-base/dist/utils/index.mjs","../../node_modules/@mediacubeco/javascript-base/dist/helpers/index.mjs","../../src/helpers/Platform/Platform.constants.ts","../../src/utils/listeners/appState.ts","../../src/helpers/Platform/Platform.ts","../../src/utils/listeners/keyboard.ts","../../src/hooks/useLayout/useLayout.constants.ts","../../src/hooks/useMeasures/useMeasures.constants.ts","../../src/hooks/useMeasures/useMeasures.utils.ts","../../src/hooks/useAppState/useAppState.ts","../../src/hooks/useKeyboard/useKeyboard.ts","../../src/hooks/useLayout/useLayout.ts","../../src/hooks/useMeasures/useMeasures.ts"],"sourcesContent":["const e=e=>void 0===e,t=e=>null===e,n=n=>e(n)||t(n),o=e=>\"string\"==typeof e,r=e=>\"number\"==typeof e,i=e=>\"bigint\"==typeof e,s=e=>Number.isNaN(e),f=e=>\"boolean\"==typeof e,c=e=>\"symbol\"==typeof e,a=e=>\"object\"==typeof e,u=e=>{const t=[l,p,y,b,m,g,j,x,E,N,T].some(t=>t(e));return!!e&&\"object\"==typeof e&&!t},l=e=>Array.isArray(e),p=e=>e instanceof ArrayBuffer,y=e=>e instanceof Map,b=e=>e instanceof Set,m=e=>e instanceof Map,g=e=>e instanceof Set,j=e=>e instanceof Date,x=e=>e instanceof Error,A=e=>e instanceof Proxy,E=e=>e instanceof RegExp,N=e=>e instanceof Promise,T=e=>e instanceof Function;function h(e,t,n){return 2===arguments.length?t[e]:t[e]??n}const M=(e,...t)=>{if(T(e))return e(...t)},O=(e,t)=>{const n=Object.entries(e);return Object.fromEntries(n.map(([e,n],o,r)=>[e,t(e,n,o,r)]))},P=(e,t)=>{let n;return(...o)=>{n&&clearTimeout(n),n=setTimeout(()=>M(e,...o),t)}},S=(e,t)=>{let n=!0;return(...o)=>{n&&(M(e,...o),n=!1),setTimeout(()=>n=!0,t)}},d=e=>{for(let t in e)return!1;return!0},v=e=>0===e.length,B=(e,t)=>!(!a(t)||!(e in t)),D=(e,t=\"isVisible\")=>e.filter(e=>!B(t,e)||e[t]),F=e=>e.filter(e=>!n(e));export{P as debounce,D as filterByProperty,F as filterNullableValues,h as getValueByProperty,B as hasProperty,a as isAnyObject,l as isArray,p as isArrayBuffer,v as isArrayEmpty,i as isBigint,f as isBoolean,j as isDate,x as isError,T as isFunction,y as isMap,s as isNaN,t as isNull,n as isNullable,r as isNumber,u as isObject,d as isObjectEmpty,N as isPromise,A as isProxy,E as isRegExp,b as isSet,o as isString,c as isSymbol,e as isUndefined,m as isWeakMap,g as isWeakSet,O as mapRecord,M as runCallback,S as throttle};\n//# sourceMappingURL=index.mjs.map\n","import{isAxiosError as t}from\"axios\";const s=t=>t instanceof Error,r=t=>{for(let s in t)return!1;return!0},e=(t=\"?\",...s)=>{const r=(t&&(e=t,\"string\"==typeof e)?t:\"?\").toUpperCase();var e;const a=s.reduce((t,s,r,{length:e})=>{const a=r===e-1?[]:[\"|\"];return t.push(s,...a),t},s.length?[\"-\"]:[]);return[`[${r}]`,...a]};var a,o;!function(t){t.StartGroup=\"group\",t.EndGroup=\"groupEnd\",t.Default=\"log\"}(a||(a={})),function(t){t.Info=\"\u001b[36m%s\u001b[0m\",t.Success=\"\u001b[32m%s\u001b[0m\",t.Warning=\"\u001b[33m%s\u001b[0m\",t.Danger=\"\u001b[31m%s\u001b[0m\"}(o||(o={}));class n{static formatted={info:(...t)=>n.info(...e(...t)),success:(...t)=>n.success(...e(...t)),warning:(...t)=>n.warning(...e(...t)),danger:(...t)=>n.danger(...e(...t))};static#t(t,...s){console[t](...s)}static startGroup(t,s,...r){n.#t(a.StartGroup,...((t,...s)=>[\"%c%s\",t,...s])(`font-size: 16px;${s}`,...e(t,...r)))}static endGroup(){n.#t(a.EndGroup)}static info(...t){n.#t(a.Default,o.Info,...t)}static success(...t){n.#t(a.Default,o.Success,...t)}static warning(...t){n.#t(a.Default,o.Warning,...t)}static danger(...t){n.#t(a.Default,o.Danger,...t)}}class c{static ignore(t){}static create(t,s){return new Error(t,{cause:s})}static throw(t,s){throw c.create(t,s)}static capture(t,r){const{signal:e,message:a,payload:o,stack:c}=r,i=[a,s(t)?t.message:void 0].filter(Boolean);n.formatted.danger(e,...i,{error:t,payload:o,stack:c})}static forward(t,s){throw c.capture(t,s),t}static parse(e){const a=\"Some error!\",o=0,n={};switch(!0){case t(e):{const{status:t=o,data:s,config:c}=e.response??{},{message:i=a,errors:u=n}=s??{};return{message:i,status:t,errors:u,isExternal:r(u)}}case s(e):return{message:e.message,status:o,errors:n,isExternal:!0};default:return{message:a,status:o,errors:n,isExternal:!0}}}}export{c as ErrorHandler,n as Log};\n//# sourceMappingURL=index.mjs.map\n","enum PlatformOS {\n Ios = 'ios',\n Android = 'android'\n // Macos = 'macos',\n // Windows = 'windows',\n // Web = 'web',\n}\n\nexport { PlatformOS }\n","import { AppState, AppStateStatus, NativeEventSubscription } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, Callback } from '@mediacubeco/javascript-base/types'\nimport { Platform } from '../../helpers'\n\ntype AppStateAdditionalHandlerName = 'onFocus' | 'onBlur'\n\ntype AppStateHandlerName =\n | AppStateAdditionalHandlerName\n | 'onActive'\n | 'onInactive'\n | 'onBackground'\n | 'onExtension'\n | 'onUnknown'\n | 'onChange'\n\ntype AppStateHandlerCallback = Callback<[AppStateStatus]>\n\ntype AppStateHandlers = Partial<BaseRecord<AppStateHandlerCallback, AppStateHandlerName>>\n\ninterface HandleChangeAppStateConfig {\n state: AppStateStatus\n handlers: Omit<AppStateHandlers, AppStateAdditionalHandlerName>\n}\n\ntype HandleChangeAppState = (config: HandleChangeAppStateConfig) => void\n\ntype ListenAppState = (handlers: AppStateHandlers) => NativeEventSubscription\n\nenum AppStatus {\n Active = 'active',\n Inactive = 'inactive',\n Background = 'background',\n Extension = 'extension',\n Unknown = 'unknown'\n}\n\nconst handleChangeAppState: HandleChangeAppState = ({ state, handlers }) => {\n const { onActive, onInactive, onBackground, onExtension, onUnknown, onChange } = handlers ?? {}\n\n const handler = {\n [AppStatus.Active]: onActive,\n [AppStatus.Inactive]: onInactive,\n [AppStatus.Background]: onBackground,\n [AppStatus.Extension]: onExtension,\n [AppStatus.Unknown]: onUnknown\n }[state]\n\n runCallback(onChange, state)\n runCallback(handler, state)\n}\n\nconst listenAppState: ListenAppState = ({ onFocus, onBlur, ...handlers }) => {\n const listenerList: NativeEventSubscription[] = []\n\n if (Platform.isAndroid) {\n listenerList.push(\n AppState.addEventListener('focus', (state) => runCallback(onFocus, state)),\n AppState.addEventListener('blur', (state) => runCallback(onBlur, state))\n )\n }\n\n listenerList.push(\n AppState.addEventListener('change', (state) => handleChangeAppState({ state, handlers }))\n )\n\n return {\n remove() {\n listenerList.forEach((listener) => listener.remove())\n }\n }\n}\n\nexport { listenAppState }\nexport type { AppStateHandlers }\n","import { Platform as NativePlatform } from 'react-native'\nimport { PlatformOS } from './Platform.constants'\nimport { PlatformByData, PlatformRequiredOS } from './Platform.types'\n\n// Platform.Version\nclass Platform {\n static get OS() {\n return NativePlatform.OS\n }\n\n static get version() {\n return NativePlatform.Version\n }\n\n static get isIos() {\n return Platform.OS === 'ios'\n }\n\n static get isAndroid() {\n return Platform.OS === 'android'\n }\n\n // static get isMac() {\n // return Platform.OS === 'macos'\n // }\n\n // static get isWindows() {\n // return Platform.OS === 'windows'\n // }\n\n // static get isWeb() {\n // return Platform.OS === 'web'\n // }\n\n static by<Value>(data: PlatformByData<Value>, defaultOS: PlatformRequiredOS = PlatformOS.Ios) {\n return NativePlatform.select({ ...data, default: data[defaultOS] })\n }\n}\n\nexport default Platform\n","import { Keyboard, KeyboardEventListener, NativeEventSubscription } from 'react-native'\nimport {\n mapRecord,\n filterNullableValues,\n isNullable\n} from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, KeyOf } from '@mediacubeco/javascript-base/types'\n\nenum KeyboardEventName {\n onWillShow = 'keyboardWillShow',\n onDidShow = 'keyboardDidShow',\n onWillHide = 'keyboardWillHide',\n onDidHide = 'keyboardDidHide',\n onWillChangeFrame = 'keyboardWillChangeFrame',\n onDidChangeFrame = 'keyboardDidChangeFrame'\n}\n\ntype KeyboardHandlers = Partial<BaseRecord<KeyboardEventListener, KeyOf<typeof KeyboardEventName>>>\n\ntype ListenKeyboard = (handlers: KeyboardHandlers) => NativeEventSubscription\n\nconst listenKeyboard: ListenKeyboard = (handlers) => {\n const list = mapRecord(handlers, (key, handler) => {\n if (isNullable(handler)) return\n\n return Keyboard.addListener(KeyboardEventName[key], handler)\n })\n\n return {\n remove() {\n return filterNullableValues(Object.values(list)).map((unsubscribe) => unsubscribe.remove())\n }\n }\n}\n\nexport { listenKeyboard }\nexport type { KeyboardHandlers }\n","import { Layout, NullableLayout } from './useLayout.types'\n\nconst DEFAULT_LAYOUT: Layout = {\n top: 0,\n left: 0,\n width: 0,\n height: 0,\n}\n\nconst DEFAULT_NULLABLE_LAYOUT: NullableLayout = {\n top: null,\n left: null,\n width: null,\n height: null,\n}\n\nexport { DEFAULT_LAYOUT, DEFAULT_NULLABLE_LAYOUT }\n","const DEFAULT_MEASURES = { x: 0, y: 0, width: 0, height: 0, pageX: 0, pageY: 0 }\nconst DEFAULT_MEASURES_IN_CONTAINER = { left: 0, top: 0, width: 0, height: 0 }\nconst DEFAULT_MEASURES_IN_WINDOW = { x: 0, y: 0, width: 0, height: 0 }\n\nexport { DEFAULT_MEASURES, DEFAULT_MEASURES_IN_CONTAINER, DEFAULT_MEASURES_IN_WINDOW }\n","import { RefObject } from 'react'\nimport { FlatList, ScrollView, SectionList, View } from 'react-native'\nimport { Nullable } from '@mediacubeco/javascript-base/types'\n\nconst getResponder = <\n ScrolledCurrent extends Nullable<ScrollView | FlatList | SectionList>,\n Current extends Nullable<View>\n>(\n scrolledRef: RefObject<ScrolledCurrent>\n) => {\n const responder = scrolledRef.current?.getScrollResponder() ?? null\n\n const inner = (responder?.getInnerViewRef?.() ?? null) as Current\n const outer = (responder?.getNativeScrollRef?.() ?? null) as Current\n\n return { responder, inner, outer }\n}\n\nexport { getResponder }\n","import { useEffect } from 'react'\nimport { AppStateHandlers, listenAppState } from '../../utils/listeners'\n\nconst useAppState = (handlers: AppStateHandlers) => {\n useEffect(() => {\n const listener = listenAppState(handlers)\n\n return () => listener.remove()\n }, [handlers])\n}\n\nexport { useAppState }\n","import { useEffect } from 'react'\nimport { KeyboardHandlers, listenKeyboard } from '../../utils/listeners'\n\nconst useKeyboard = (handlers: KeyboardHandlers) => {\n useEffect(() => {\n const listener = listenKeyboard(handlers)\n\n return () => {\n listener.remove()\n }\n }, [handlers])\n}\n\nexport { useKeyboard }\n","import { useCallback, useState } from 'react'\nimport { LayoutChangeEvent } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { DEFAULT_LAYOUT, DEFAULT_NULLABLE_LAYOUT } from './useLayout.constants'\nimport { UseLayoutConfig, HandleLayout, Layout, NullableLayout } from './useLayout.types'\n\nfunction useLayout(config?: UseLayoutConfig<false>): [Layout, HandleLayout]\nfunction useLayout(config?: UseLayoutConfig<true>): [NullableLayout, HandleLayout]\nfunction useLayout({ onLayout, isNullable }: UseLayoutConfig = { isNullable: false }) {\n const [layout, setLayout] = useState(isNullable ? DEFAULT_NULLABLE_LAYOUT : DEFAULT_LAYOUT)\n\n const handleLayout = useCallback(\n (event: LayoutChangeEvent) => {\n runCallback(onLayout, event)\n\n const { layout } = event.nativeEvent\n const { y: top, x: left, width, height } = layout\n\n setLayout({ top, left, width, height })\n },\n [onLayout]\n )\n\n return [layout, handleLayout] as const\n}\n\nexport { useLayout }\n","import { useCallback, useRef } from 'react'\nimport { isNullable } from '@mediacubeco/javascript-base/utils'\nimport {\n DEFAULT_MEASURES,\n DEFAULT_MEASURES_IN_CONTAINER,\n DEFAULT_MEASURES_IN_WINDOW\n} from './useMeasures.constants'\nimport {\n Calculate,\n CalculateMeasures,\n CalculateMeasuresInContainer,\n CalculateMeasuresInWindow,\n Measures,\n MeasuresInContainer,\n MeasuresInWindow,\n OnResolve\n} from './useMeasures.types'\n\nconst useMeasures = () => {\n const measuresRef = useRef(DEFAULT_MEASURES)\n const measuresInContainerRef = useRef(DEFAULT_MEASURES_IN_CONTAINER)\n const measuresInWindowRef = useRef(DEFAULT_MEASURES_IN_WINDOW)\n\n const calculate: Calculate = useCallback(async (current, defaultData, onResolve) => {\n return new Promise((resolve) => {\n if (isNullable(current)) {\n resolve(defaultData)\n } else {\n onResolve(current, resolve)\n }\n })\n }, [])\n\n const calculateMeasures: CalculateMeasures = useCallback((current) => {\n const onResolve: OnResolve<Measures> = (current, resolve) => {\n current.measure((x = 0, y = 0, width = 0, height = 0, pageX = 0, pageY = 0) => {\n measuresRef.current = { x, y, width, height, pageX, pageY }\n\n resolve(measuresRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES, onResolve)\n }, [])\n\n const calculateMeasuresInContainer: CalculateMeasuresInContainer = useCallback(\n (current, container) => {\n const onResolve: OnResolve<MeasuresInContainer> = (current, resolve) => {\n current.measureLayout(container, (left = 0, top = 0, width = 0, height = 0) => {\n measuresInContainerRef.current = { left, top, width, height }\n\n resolve(measuresInContainerRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES_IN_CONTAINER, onResolve)\n },\n []\n )\n\n const calculateMeasuresInWindow: CalculateMeasuresInWindow = useCallback((current) => {\n const onResolve: OnResolve<MeasuresInWindow> = (current, resolve) => {\n current.measureInWindow((x = 0, y = 0, width = 0, height = 0) => {\n measuresInWindowRef.current = { x, y, width, height }\n\n resolve(measuresInWindowRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES_IN_WINDOW, onResolve)\n }, [])\n\n return {\n measuresRef,\n measuresInContainerRef,\n measuresInWindowRef,\n calculateMeasures,\n calculateMeasuresInContainer,\n calculateMeasuresInWindow\n }\n}\n\nexport { useMeasures }\n"],"names":["n","e","t","M","Function","T","a","o","PlatformOS","AppStatus","StartGroup","EndGroup","Default","Info","Success","Warning","Danger","Platform","OS","NativePlatform","version","Version","isIos","isAndroid","by","data","defaultOS","Ios","select","default","listenAppState","onFocus","onBlur","handlers","listenerList","push","AppState","addEventListener","state","runCallback","handleChangeAppState","onActive","onInactive","onBackground","onExtension","onUnknown","onChange","handler","Active","Inactive","Background","Extension","Unknown","remove","forEach","listener","KeyboardEventName","listenKeyboard","list","Object","entries","fromEntries","map","r","mapRecord","key","isNullable","Keyboard","addListener","filter","filterNullableValues","values","unsubscribe","DEFAULT_LAYOUT","top","left","width","height","DEFAULT_NULLABLE_LAYOUT","DEFAULT_MEASURES","x","y","pageX","pageY","DEFAULT_MEASURES_IN_CONTAINER","DEFAULT_MEASURES_IN_WINDOW","scrolledRef","responder","current","getScrollResponder","inner","getInnerViewRef","outer","getNativeScrollRef","useEffect","onLayout","layout","setLayout","useState","handleLayout","useCallback","event","nativeEvent","useMeasures","measuresRef","useRef","measuresInContainerRef","measuresInWindowRef","calculate","async","defaultData","onResolve","Promise","resolve","calculateMeasures","measure","calculateMeasuresInContainer","container","measureLayout","calculateMeasuresInWindow","measureInWindow"],"mappings":"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","x_google_ignoreList":[0,1]}
|
package/dist/hooks/index.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import * as react_native from 'react-native';
|
|
1
2
|
import { AppStateStatus, KeyboardEventListener, LayoutChangeEvent, NativeMethods, View, ScrollView, FlatList, SectionList } from 'react-native';
|
|
2
3
|
import { BaseRecord, Callback, KeyOf, Nullable } from '@mediacubeco/javascript-base/types';
|
|
3
4
|
import * as react from 'react';
|
|
@@ -94,7 +95,7 @@ declare const useMeasures: () => {
|
|
|
94
95
|
};
|
|
95
96
|
|
|
96
97
|
declare const getResponder: <ScrolledCurrent extends Nullable<ScrollView | FlatList | SectionList>, Current extends Nullable<View>>(scrolledRef: RefObject<ScrolledCurrent>) => {
|
|
97
|
-
responder:
|
|
98
|
+
responder: react_native.ScrollResponderMixin | react.JSX.Element | null;
|
|
98
99
|
inner: Current;
|
|
99
100
|
outer: Current;
|
|
100
101
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sources":["../../src/utils/listeners/appState.ts","../../src/utils/listeners/keyboard.ts","../../src/hooks/useAppState/useAppState.ts","../../src/hooks/useKeyboard/useKeyboard.ts","../../src/hooks/useLayout/useLayout.types.ts","../../src/hooks/useLayout/useLayout.ts","../../src/hooks/useLayout/useLayout.constants.ts","../../src/hooks/useMeasures/useMeasures.constants.ts","../../src/hooks/useMeasures/useMeasures.types.ts","../../src/hooks/useMeasures/useMeasures.ts","../../src/hooks/useMeasures/useMeasures.utils.ts"],"sourcesContent":["import { AppState, AppStateStatus, NativeEventSubscription } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, Callback } from '@mediacubeco/javascript-base/types'\nimport { Platform } from '../../helpers'\n\ntype AppStateAdditionalHandlerName = 'onFocus' | 'onBlur'\n\ntype AppStateHandlerName =\n | AppStateAdditionalHandlerName\n | 'onActive'\n | 'onInactive'\n | 'onBackground'\n | 'onExtension'\n | 'onUnknown'\n | 'onChange'\n\ntype AppStateHandlerCallback = Callback<[AppStateStatus]>\n\ntype AppStateHandlers = Partial<BaseRecord<AppStateHandlerCallback, AppStateHandlerName>>\n\ninterface HandleChangeAppStateConfig {\n state: AppStateStatus\n handlers: Omit<AppStateHandlers, AppStateAdditionalHandlerName>\n}\n\ntype HandleChangeAppState = (config: HandleChangeAppStateConfig) => void\n\ntype ListenAppState = (handlers: AppStateHandlers) => NativeEventSubscription\n\nenum AppStatus {\n Active = 'active',\n Inactive = 'inactive',\n Background = 'background',\n Extension = 'extension',\n Unknown = 'unknown'\n}\n\nconst handleChangeAppState: HandleChangeAppState = ({ state, handlers }) => {\n const { onActive, onInactive, onBackground, onExtension, onUnknown, onChange } = handlers ?? {}\n\n const handler = {\n [AppStatus.Active]: onActive,\n [AppStatus.Inactive]: onInactive,\n [AppStatus.Background]: onBackground,\n [AppStatus.Extension]: onExtension,\n [AppStatus.Unknown]: onUnknown\n }[state]\n\n runCallback(onChange, state)\n runCallback(handler, state)\n}\n\nconst listenAppState: ListenAppState = ({ onFocus, onBlur, ...handlers }) => {\n const listenerList: NativeEventSubscription[] = []\n\n if (Platform.isAndroid) {\n listenerList.push(\n AppState.addEventListener('focus', (state) => runCallback(onFocus, state)),\n AppState.addEventListener('blur', (state) => runCallback(onBlur, state))\n )\n }\n\n listenerList.push(\n AppState.addEventListener('change', (state) => handleChangeAppState({ state, handlers }))\n )\n\n return {\n remove() {\n listenerList.forEach((listener) => listener.remove())\n }\n }\n}\n\nexport { listenAppState }\nexport type { AppStateHandlers }\n","import { Keyboard, KeyboardEventListener, NativeEventSubscription } from 'react-native'\nimport {\n mapRecord,\n filterNullableValues,\n isNullable\n} from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, KeyOf } from '@mediacubeco/javascript-base/types'\n\nenum KeyboardEventName {\n onWillShow = 'keyboardWillShow',\n onDidShow = 'keyboardDidShow',\n onWillHide = 'keyboardWillHide',\n onDidHide = 'keyboardDidHide',\n onWillChangeFrame = 'keyboardWillChangeFrame',\n onDidChangeFrame = 'keyboardDidChangeFrame'\n}\n\ntype KeyboardHandlers = Partial<BaseRecord<KeyboardEventListener, KeyOf<typeof KeyboardEventName>>>\n\ntype ListenKeyboard = (handlers: KeyboardHandlers) => NativeEventSubscription\n\nconst listenKeyboard: ListenKeyboard = (handlers) => {\n const list = mapRecord(handlers, (key, handler) => {\n if (isNullable(handler)) return\n\n return Keyboard.addListener(KeyboardEventName[key], handler)\n })\n\n return {\n remove() {\n return filterNullableValues(Object.values(list)).map((unsubscribe) => unsubscribe.remove())\n }\n }\n}\n\nexport { listenKeyboard }\nexport type { KeyboardHandlers }\n","import { useEffect } from 'react'\nimport { AppStateHandlers, listenAppState } from '../../utils/listeners'\n\nconst useAppState = (handlers: AppStateHandlers) => {\n useEffect(() => {\n const listener = listenAppState(handlers)\n\n return () => listener.remove()\n }, [handlers])\n}\n\nexport { useAppState }\n","import { useEffect } from 'react'\nimport { KeyboardHandlers, listenKeyboard } from '../../utils/listeners'\n\nconst useKeyboard = (handlers: KeyboardHandlers) => {\n useEffect(() => {\n const listener = listenKeyboard(handlers)\n\n return () => {\n listener.remove()\n }\n }, [handlers])\n}\n\nexport { useKeyboard }\n","import { LayoutChangeEvent } from 'react-native'\nimport { Nullable } from '@mediacubeco/javascript-base/types'\n\ntype HandleLayout = (event: LayoutChangeEvent) => void\n\ntype UseLayoutConfig<IsNullable extends boolean = boolean> = {\n isNullable?: IsNullable\n onLayout?: HandleLayout\n}\n\ntype Layout = Record<'top' | 'left' | 'width' | 'height', number>\n\ntype NullableLayout = Record<'top' | 'left' | 'width' | 'height', Nullable<number>>\n\nexport type { UseLayoutConfig, HandleLayout, Layout, NullableLayout }\n","import { useCallback, useState } from 'react'\nimport { LayoutChangeEvent } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { DEFAULT_LAYOUT, DEFAULT_NULLABLE_LAYOUT } from './useLayout.constants'\nimport { UseLayoutConfig, HandleLayout, Layout, NullableLayout } from './useLayout.types'\n\nfunction useLayout(config?: UseLayoutConfig<false>): [Layout, HandleLayout]\nfunction useLayout(config?: UseLayoutConfig<true>): [NullableLayout, HandleLayout]\nfunction useLayout({ onLayout, isNullable }: UseLayoutConfig = { isNullable: false }) {\n const [layout, setLayout] = useState(isNullable ? DEFAULT_NULLABLE_LAYOUT : DEFAULT_LAYOUT)\n\n const handleLayout = useCallback(\n (event: LayoutChangeEvent) => {\n runCallback(onLayout, event)\n\n const { layout } = event.nativeEvent\n const { y: top, x: left, width, height } = layout\n\n setLayout({ top, left, width, height })\n },\n [onLayout]\n )\n\n return [layout, handleLayout] as const\n}\n\nexport { useLayout }\n","import { Layout, NullableLayout } from './useLayout.types'\n\nconst DEFAULT_LAYOUT: Layout = {\n top: 0,\n left: 0,\n width: 0,\n height: 0,\n}\n\nconst DEFAULT_NULLABLE_LAYOUT: NullableLayout = {\n top: null,\n left: null,\n width: null,\n height: null,\n}\n\nexport { DEFAULT_LAYOUT, DEFAULT_NULLABLE_LAYOUT }\n","const DEFAULT_MEASURES = { x: 0, y: 0, width: 0, height: 0, pageX: 0, pageY: 0 }\nconst DEFAULT_MEASURES_IN_CONTAINER = { left: 0, top: 0, width: 0, height: 0 }\nconst DEFAULT_MEASURES_IN_WINDOW = { x: 0, y: 0, width: 0, height: 0 }\n\nexport { DEFAULT_MEASURES, DEFAULT_MEASURES_IN_CONTAINER, DEFAULT_MEASURES_IN_WINDOW }\n","import { NativeMethods, View } from 'react-native'\nimport { NotNullable, Nullable } from '@mediacubeco/javascript-base/types'\nimport type {\n DEFAULT_MEASURES,\n DEFAULT_MEASURES_IN_CONTAINER,\n DEFAULT_MEASURES_IN_WINDOW\n} from './useMeasures.constants'\n\ntype Measures = typeof DEFAULT_MEASURES\n\ntype MeasuresInContainer = typeof DEFAULT_MEASURES_IN_CONTAINER\n\ntype MeasuresInWindow = typeof DEFAULT_MEASURES_IN_WINDOW\n\ntype Current = Nullable<NativeMethods>\n\ninterface Container extends View {}\n\ntype OnResolve<Measures> = (\n current: NotNullable<Current>,\n resolve: (value: Measures) => void\n) => void\n\ntype Calculate = <Measures>(\n current: Current,\n defaultData: Measures,\n onResolve: OnResolve<Measures>\n) => Promise<Measures>\n\ntype CalculateMeasures = (current: Current) => Promise<Measures>\n\ntype CalculateMeasuresInContainer = (\n current: Current,\n container: Container\n) => Promise<MeasuresInContainer>\n\ntype CalculateMeasuresInWindow = (current: Current) => Promise<MeasuresInWindow>\n\nexport type {\n Measures,\n MeasuresInContainer,\n MeasuresInWindow,\n OnResolve,\n Calculate,\n CalculateMeasures,\n CalculateMeasuresInContainer,\n CalculateMeasuresInWindow\n}\n","import { useCallback, useRef } from 'react'\nimport { isNullable } from '@mediacubeco/javascript-base/utils'\nimport {\n DEFAULT_MEASURES,\n DEFAULT_MEASURES_IN_CONTAINER,\n DEFAULT_MEASURES_IN_WINDOW\n} from './useMeasures.constants'\nimport {\n Calculate,\n CalculateMeasures,\n CalculateMeasuresInContainer,\n CalculateMeasuresInWindow,\n Measures,\n MeasuresInContainer,\n MeasuresInWindow,\n OnResolve\n} from './useMeasures.types'\n\nconst useMeasures = () => {\n const measuresRef = useRef(DEFAULT_MEASURES)\n const measuresInContainerRef = useRef(DEFAULT_MEASURES_IN_CONTAINER)\n const measuresInWindowRef = useRef(DEFAULT_MEASURES_IN_WINDOW)\n\n const calculate: Calculate = useCallback(async (current, defaultData, onResolve) => {\n return new Promise((resolve) => {\n if (isNullable(current)) {\n resolve(defaultData)\n } else {\n onResolve(current, resolve)\n }\n })\n }, [])\n\n const calculateMeasures: CalculateMeasures = useCallback((current) => {\n const onResolve: OnResolve<Measures> = (current, resolve) => {\n current.measure((x = 0, y = 0, width = 0, height = 0, pageX = 0, pageY = 0) => {\n measuresRef.current = { x, y, width, height, pageX, pageY }\n\n resolve(measuresRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES, onResolve)\n }, [])\n\n const calculateMeasuresInContainer: CalculateMeasuresInContainer = useCallback(\n (current, container) => {\n const onResolve: OnResolve<MeasuresInContainer> = (current, resolve) => {\n current.measureLayout(container, (left = 0, top = 0, width = 0, height = 0) => {\n measuresInContainerRef.current = { left, top, width, height }\n\n resolve(measuresInContainerRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES_IN_CONTAINER, onResolve)\n },\n []\n )\n\n const calculateMeasuresInWindow: CalculateMeasuresInWindow = useCallback((current) => {\n const onResolve: OnResolve<MeasuresInWindow> = (current, resolve) => {\n current.measureInWindow((x = 0, y = 0, width = 0, height = 0) => {\n measuresInWindowRef.current = { x, y, width, height }\n\n resolve(measuresInWindowRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES_IN_WINDOW, onResolve)\n }, [])\n\n return {\n measuresRef,\n measuresInContainerRef,\n measuresInWindowRef,\n calculateMeasures,\n calculateMeasuresInContainer,\n calculateMeasuresInWindow\n }\n}\n\nexport { useMeasures }\n","import { RefObject } from 'react'\nimport { FlatList, ScrollView, SectionList, View } from 'react-native'\nimport { Nullable } from '@mediacubeco/javascript-base/types'\n\nconst getResponder = <\n ScrolledCurrent extends Nullable<ScrollView | FlatList | SectionList>,\n Current extends Nullable<View>\n>(\n scrolledRef: RefObject<ScrolledCurrent>\n) => {\n const responder = scrolledRef.current?.getScrollResponder() ?? null\n\n const inner = (responder?.getInnerViewRef?.() ?? null) as Current\n const outer = (responder?.getNativeScrollRef?.() ?? null) as Current\n\n return { responder, inner, outer }\n}\n\nexport { getResponder }\n"],"names":[],"mappings":";;;;;AAEA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;;ACAA;;ACCA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;;ACDA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;;;"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sources":["../../src/utils/listeners/appState.ts","../../src/utils/listeners/keyboard.ts","../../src/hooks/useAppState/useAppState.ts","../../src/hooks/useKeyboard/useKeyboard.ts","../../src/hooks/useLayout/useLayout.types.ts","../../src/hooks/useLayout/useLayout.ts","../../src/hooks/useLayout/useLayout.constants.ts","../../src/hooks/useMeasures/useMeasures.constants.ts","../../src/hooks/useMeasures/useMeasures.types.ts","../../src/hooks/useMeasures/useMeasures.ts","../../src/hooks/useMeasures/useMeasures.utils.ts"],"sourcesContent":["import { AppState, AppStateStatus, NativeEventSubscription } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, Callback } from '@mediacubeco/javascript-base/types'\nimport { Platform } from '../../helpers'\n\ntype AppStateAdditionalHandlerName = 'onFocus' | 'onBlur'\n\ntype AppStateHandlerName =\n | AppStateAdditionalHandlerName\n | 'onActive'\n | 'onInactive'\n | 'onBackground'\n | 'onExtension'\n | 'onUnknown'\n | 'onChange'\n\ntype AppStateHandlerCallback = Callback<[AppStateStatus]>\n\ntype AppStateHandlers = Partial<BaseRecord<AppStateHandlerCallback, AppStateHandlerName>>\n\ninterface HandleChangeAppStateConfig {\n state: AppStateStatus\n handlers: Omit<AppStateHandlers, AppStateAdditionalHandlerName>\n}\n\ntype HandleChangeAppState = (config: HandleChangeAppStateConfig) => void\n\ntype ListenAppState = (handlers: AppStateHandlers) => NativeEventSubscription\n\nenum AppStatus {\n Active = 'active',\n Inactive = 'inactive',\n Background = 'background',\n Extension = 'extension',\n Unknown = 'unknown'\n}\n\nconst handleChangeAppState: HandleChangeAppState = ({ state, handlers }) => {\n const { onActive, onInactive, onBackground, onExtension, onUnknown, onChange } = handlers ?? {}\n\n const handler = {\n [AppStatus.Active]: onActive,\n [AppStatus.Inactive]: onInactive,\n [AppStatus.Background]: onBackground,\n [AppStatus.Extension]: onExtension,\n [AppStatus.Unknown]: onUnknown\n }[state]\n\n runCallback(onChange, state)\n runCallback(handler, state)\n}\n\nconst listenAppState: ListenAppState = ({ onFocus, onBlur, ...handlers }) => {\n const listenerList: NativeEventSubscription[] = []\n\n if (Platform.isAndroid) {\n listenerList.push(\n AppState.addEventListener('focus', (state) => runCallback(onFocus, state)),\n AppState.addEventListener('blur', (state) => runCallback(onBlur, state))\n )\n }\n\n listenerList.push(\n AppState.addEventListener('change', (state) => handleChangeAppState({ state, handlers }))\n )\n\n return {\n remove() {\n listenerList.forEach((listener) => listener.remove())\n }\n }\n}\n\nexport { listenAppState }\nexport type { AppStateHandlers }\n","import { Keyboard, KeyboardEventListener, NativeEventSubscription } from 'react-native'\nimport {\n mapRecord,\n filterNullableValues,\n isNullable\n} from '@mediacubeco/javascript-base/utils'\nimport { BaseRecord, KeyOf } from '@mediacubeco/javascript-base/types'\n\nenum KeyboardEventName {\n onWillShow = 'keyboardWillShow',\n onDidShow = 'keyboardDidShow',\n onWillHide = 'keyboardWillHide',\n onDidHide = 'keyboardDidHide',\n onWillChangeFrame = 'keyboardWillChangeFrame',\n onDidChangeFrame = 'keyboardDidChangeFrame'\n}\n\ntype KeyboardHandlers = Partial<BaseRecord<KeyboardEventListener, KeyOf<typeof KeyboardEventName>>>\n\ntype ListenKeyboard = (handlers: KeyboardHandlers) => NativeEventSubscription\n\nconst listenKeyboard: ListenKeyboard = (handlers) => {\n const list = mapRecord(handlers, (key, handler) => {\n if (isNullable(handler)) return\n\n return Keyboard.addListener(KeyboardEventName[key], handler)\n })\n\n return {\n remove() {\n return filterNullableValues(Object.values(list)).map((unsubscribe) => unsubscribe.remove())\n }\n }\n}\n\nexport { listenKeyboard }\nexport type { KeyboardHandlers }\n","import { useEffect } from 'react'\nimport { AppStateHandlers, listenAppState } from '../../utils/listeners'\n\nconst useAppState = (handlers: AppStateHandlers) => {\n useEffect(() => {\n const listener = listenAppState(handlers)\n\n return () => listener.remove()\n }, [handlers])\n}\n\nexport { useAppState }\n","import { useEffect } from 'react'\nimport { KeyboardHandlers, listenKeyboard } from '../../utils/listeners'\n\nconst useKeyboard = (handlers: KeyboardHandlers) => {\n useEffect(() => {\n const listener = listenKeyboard(handlers)\n\n return () => {\n listener.remove()\n }\n }, [handlers])\n}\n\nexport { useKeyboard }\n","import { LayoutChangeEvent } from 'react-native'\nimport { Nullable } from '@mediacubeco/javascript-base/types'\n\ntype HandleLayout = (event: LayoutChangeEvent) => void\n\ntype UseLayoutConfig<IsNullable extends boolean = boolean> = {\n isNullable?: IsNullable\n onLayout?: HandleLayout\n}\n\ntype Layout = Record<'top' | 'left' | 'width' | 'height', number>\n\ntype NullableLayout = Record<'top' | 'left' | 'width' | 'height', Nullable<number>>\n\nexport type { UseLayoutConfig, HandleLayout, Layout, NullableLayout }\n","import { useCallback, useState } from 'react'\nimport { LayoutChangeEvent } from 'react-native'\nimport { runCallback } from '@mediacubeco/javascript-base/utils'\nimport { DEFAULT_LAYOUT, DEFAULT_NULLABLE_LAYOUT } from './useLayout.constants'\nimport { UseLayoutConfig, HandleLayout, Layout, NullableLayout } from './useLayout.types'\n\nfunction useLayout(config?: UseLayoutConfig<false>): [Layout, HandleLayout]\nfunction useLayout(config?: UseLayoutConfig<true>): [NullableLayout, HandleLayout]\nfunction useLayout({ onLayout, isNullable }: UseLayoutConfig = { isNullable: false }) {\n const [layout, setLayout] = useState(isNullable ? DEFAULT_NULLABLE_LAYOUT : DEFAULT_LAYOUT)\n\n const handleLayout = useCallback(\n (event: LayoutChangeEvent) => {\n runCallback(onLayout, event)\n\n const { layout } = event.nativeEvent\n const { y: top, x: left, width, height } = layout\n\n setLayout({ top, left, width, height })\n },\n [onLayout]\n )\n\n return [layout, handleLayout] as const\n}\n\nexport { useLayout }\n","import { Layout, NullableLayout } from './useLayout.types'\n\nconst DEFAULT_LAYOUT: Layout = {\n top: 0,\n left: 0,\n width: 0,\n height: 0,\n}\n\nconst DEFAULT_NULLABLE_LAYOUT: NullableLayout = {\n top: null,\n left: null,\n width: null,\n height: null,\n}\n\nexport { DEFAULT_LAYOUT, DEFAULT_NULLABLE_LAYOUT }\n","const DEFAULT_MEASURES = { x: 0, y: 0, width: 0, height: 0, pageX: 0, pageY: 0 }\nconst DEFAULT_MEASURES_IN_CONTAINER = { left: 0, top: 0, width: 0, height: 0 }\nconst DEFAULT_MEASURES_IN_WINDOW = { x: 0, y: 0, width: 0, height: 0 }\n\nexport { DEFAULT_MEASURES, DEFAULT_MEASURES_IN_CONTAINER, DEFAULT_MEASURES_IN_WINDOW }\n","import { NativeMethods, View } from 'react-native'\nimport { NotNullable, Nullable } from '@mediacubeco/javascript-base/types'\nimport type {\n DEFAULT_MEASURES,\n DEFAULT_MEASURES_IN_CONTAINER,\n DEFAULT_MEASURES_IN_WINDOW\n} from './useMeasures.constants'\n\ntype Measures = typeof DEFAULT_MEASURES\n\ntype MeasuresInContainer = typeof DEFAULT_MEASURES_IN_CONTAINER\n\ntype MeasuresInWindow = typeof DEFAULT_MEASURES_IN_WINDOW\n\ntype Current = Nullable<NativeMethods>\n\ninterface Container extends View {}\n\ntype OnResolve<Measures> = (\n current: NotNullable<Current>,\n resolve: (value: Measures) => void\n) => void\n\ntype Calculate = <Measures>(\n current: Current,\n defaultData: Measures,\n onResolve: OnResolve<Measures>\n) => Promise<Measures>\n\ntype CalculateMeasures = (current: Current) => Promise<Measures>\n\ntype CalculateMeasuresInContainer = (\n current: Current,\n container: Container\n) => Promise<MeasuresInContainer>\n\ntype CalculateMeasuresInWindow = (current: Current) => Promise<MeasuresInWindow>\n\nexport type {\n Measures,\n MeasuresInContainer,\n MeasuresInWindow,\n OnResolve,\n Calculate,\n CalculateMeasures,\n CalculateMeasuresInContainer,\n CalculateMeasuresInWindow\n}\n","import { useCallback, useRef } from 'react'\nimport { isNullable } from '@mediacubeco/javascript-base/utils'\nimport {\n DEFAULT_MEASURES,\n DEFAULT_MEASURES_IN_CONTAINER,\n DEFAULT_MEASURES_IN_WINDOW\n} from './useMeasures.constants'\nimport {\n Calculate,\n CalculateMeasures,\n CalculateMeasuresInContainer,\n CalculateMeasuresInWindow,\n Measures,\n MeasuresInContainer,\n MeasuresInWindow,\n OnResolve\n} from './useMeasures.types'\n\nconst useMeasures = () => {\n const measuresRef = useRef(DEFAULT_MEASURES)\n const measuresInContainerRef = useRef(DEFAULT_MEASURES_IN_CONTAINER)\n const measuresInWindowRef = useRef(DEFAULT_MEASURES_IN_WINDOW)\n\n const calculate: Calculate = useCallback(async (current, defaultData, onResolve) => {\n return new Promise((resolve) => {\n if (isNullable(current)) {\n resolve(defaultData)\n } else {\n onResolve(current, resolve)\n }\n })\n }, [])\n\n const calculateMeasures: CalculateMeasures = useCallback((current) => {\n const onResolve: OnResolve<Measures> = (current, resolve) => {\n current.measure((x = 0, y = 0, width = 0, height = 0, pageX = 0, pageY = 0) => {\n measuresRef.current = { x, y, width, height, pageX, pageY }\n\n resolve(measuresRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES, onResolve)\n }, [])\n\n const calculateMeasuresInContainer: CalculateMeasuresInContainer = useCallback(\n (current, container) => {\n const onResolve: OnResolve<MeasuresInContainer> = (current, resolve) => {\n current.measureLayout(container, (left = 0, top = 0, width = 0, height = 0) => {\n measuresInContainerRef.current = { left, top, width, height }\n\n resolve(measuresInContainerRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES_IN_CONTAINER, onResolve)\n },\n []\n )\n\n const calculateMeasuresInWindow: CalculateMeasuresInWindow = useCallback((current) => {\n const onResolve: OnResolve<MeasuresInWindow> = (current, resolve) => {\n current.measureInWindow((x = 0, y = 0, width = 0, height = 0) => {\n measuresInWindowRef.current = { x, y, width, height }\n\n resolve(measuresInWindowRef.current)\n })\n }\n\n return calculate(current, DEFAULT_MEASURES_IN_WINDOW, onResolve)\n }, [])\n\n return {\n measuresRef,\n measuresInContainerRef,\n measuresInWindowRef,\n calculateMeasures,\n calculateMeasuresInContainer,\n calculateMeasuresInWindow\n }\n}\n\nexport { useMeasures }\n","import { RefObject } from 'react'\nimport { FlatList, ScrollView, SectionList, View } from 'react-native'\nimport { Nullable } from '@mediacubeco/javascript-base/types'\n\nconst getResponder = <\n ScrolledCurrent extends Nullable<ScrollView | FlatList | SectionList>,\n Current extends Nullable<View>\n>(\n scrolledRef: RefObject<ScrolledCurrent>\n) => {\n const responder = scrolledRef.current?.getScrollResponder() ?? null\n\n const inner = (responder?.getInnerViewRef?.() ?? null) as Current\n const outer = (responder?.getNativeScrollRef?.() ?? null) as Current\n\n return { responder, inner, outer }\n}\n\nexport { getResponder }\n"],"names":[],"mappings":";;;;;;AAEA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;;ACAA;;ACCA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;;ACDA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;;;"}
|
package/dist/hooks/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{useEffect as e,useState as n,useCallback as t,useRef as r}from"react";import{Platform as o,AppState as i,Keyboard as a}from"react-native";import"@react-native-clipboard/clipboard";const s=e=>(e=>void 0===e)(e)||(e=>null===e)(e),u=(e,...n)=>{if((e=>e instanceof Function)(e))return e(...n)};var c,l,d,h;!function(e){e.StartGroup="group",e.EndGroup="groupEnd",e.Default="log"}(c||(c={})),function(e){e.Info="[36m%s[0m",e.Success="[32m%s[0m",e.Warning="[33m%s[0m",e.Danger="[31m%s[0m"}(l||(l={})),function(e){e.Ios="ios",e.Android="android"}(d||(d={}));class g{static get OS(){return o.OS}static get isIos(){return"ios"===g.OS}static get isAndroid(){return"android"===g.OS}static by(e,n=d.Ios){return o.select({...e,default:e[n]})}}!function(e){e.Active="active",e.Inactive="inactive",e.Background="background",e.Extension="extension",e.Unknown="unknown"}(h||(h={}));const m=({onFocus:e,onBlur:n,...t})=>{const r=[];return g.isAndroid&&r.push(i.addEventListener("focus",n=>u(e,n)),i.addEventListener("blur",e=>u(n,e))),r.push(i.addEventListener("change",e=>(({state:e,handlers:n})=>{const{onActive:t,onInactive:r,onBackground:o,onExtension:i,onUnknown:a,onChange:s}=n??{},c={[h.Active]:t,[h.Inactive]:r,[h.Background]:o,[h.Extension]:i,[h.Unknown]:a}[e];u(s,e),u(c,e)})({state:e,handlers:t}))),{remove(){r.forEach(e=>e.remove())}}};var f;!function(e){e.onWillShow="keyboardWillShow",e.onDidShow="keyboardDidShow",e.onWillHide="keyboardWillHide",e.onDidHide="keyboardDidHide",e.onWillChangeFrame="keyboardWillChangeFrame",e.onDidChangeFrame="keyboardDidChangeFrame"}(f||(f={}));const v=e=>{const n=((e,n)=>{const t=Object.entries(e);return Object.fromEntries(t.map(([e,t],r,o)=>[e,n(e,t,r,o)]))})(e,(e,n)=>{if(!s(n))return a.addListener(f[e],n)});return{remove:()=>(e=>e.filter(e=>!s(e)))(Object.values(n)).map(e=>e.remove())}},p=n=>{e(()=>{const e=m(n);return()=>e.remove()},[n])},w=n=>{e(()=>{const e=v(n);return()=>{e.remove()}},[n])},b={top:0,left:0,width:0,height:0},y={top:null,left:null,width:null,height:null};function k({onLayout:e,isNullable:r}={isNullable:!1}){const[o,i]=n(r?y:b),a=t(n=>{u(e,n);const{layout:t}=n.nativeEvent,{y:r,x:o,width:a,height:s}=t;i({top:r,left:o,width:a,height:s})},[e]);return[o,a]}const I={x:0,y:0,width:0,height:0,pageX:0,pageY:0},S={left:0,top:0,width:0,height:0},
|
|
1
|
+
import{useEffect as e,useState as n,useCallback as t,useRef as r}from"react";import{Platform as o,AppState as i,Keyboard as a}from"react-native";import"axios";import"@react-native-clipboard/clipboard";const s=e=>(e=>void 0===e)(e)||(e=>null===e)(e),u=(e,...n)=>{if((e=>e instanceof Function)(e))return e(...n)};var c,l,d,h;!function(e){e.StartGroup="group",e.EndGroup="groupEnd",e.Default="log"}(c||(c={})),function(e){e.Info="[36m%s[0m",e.Success="[32m%s[0m",e.Warning="[33m%s[0m",e.Danger="[31m%s[0m"}(l||(l={})),function(e){e.Ios="ios",e.Android="android"}(d||(d={}));class g{static get OS(){return o.OS}static get version(){return o.Version}static get isIos(){return"ios"===g.OS}static get isAndroid(){return"android"===g.OS}static by(e,n=d.Ios){return o.select({...e,default:e[n]})}}!function(e){e.Active="active",e.Inactive="inactive",e.Background="background",e.Extension="extension",e.Unknown="unknown"}(h||(h={}));const m=({onFocus:e,onBlur:n,...t})=>{const r=[];return g.isAndroid&&r.push(i.addEventListener("focus",n=>u(e,n)),i.addEventListener("blur",e=>u(n,e))),r.push(i.addEventListener("change",e=>(({state:e,handlers:n})=>{const{onActive:t,onInactive:r,onBackground:o,onExtension:i,onUnknown:a,onChange:s}=n??{},c={[h.Active]:t,[h.Inactive]:r,[h.Background]:o,[h.Extension]:i,[h.Unknown]:a}[e];u(s,e),u(c,e)})({state:e,handlers:t}))),{remove(){r.forEach(e=>e.remove())}}};var f;!function(e){e.onWillShow="keyboardWillShow",e.onDidShow="keyboardDidShow",e.onWillHide="keyboardWillHide",e.onDidHide="keyboardDidHide",e.onWillChangeFrame="keyboardWillChangeFrame",e.onDidChangeFrame="keyboardDidChangeFrame"}(f||(f={}));const v=e=>{const n=((e,n)=>{const t=Object.entries(e);return Object.fromEntries(t.map(([e,t],r,o)=>[e,n(e,t,r,o)]))})(e,(e,n)=>{if(!s(n))return a.addListener(f[e],n)});return{remove:()=>(e=>e.filter(e=>!s(e)))(Object.values(n)).map(e=>e.remove())}},p=n=>{e(()=>{const e=m(n);return()=>e.remove()},[n])},w=n=>{e(()=>{const e=v(n);return()=>{e.remove()}},[n])},b={top:0,left:0,width:0,height:0},y={top:null,left:null,width:null,height:null};function k({onLayout:e,isNullable:r}={isNullable:!1}){const[o,i]=n(r?y:b),a=t(n=>{u(e,n);const{layout:t}=n.nativeEvent,{y:r,x:o,width:a,height:s}=t;i({top:r,left:o,width:a,height:s})},[e]);return[o,a]}const I={x:0,y:0,width:0,height:0,pageX:0,pageY:0},S={left:0,top:0,width:0,height:0},x={x:0,y:0,width:0,height:0},E=()=>{const e=r(I),n=r(S),o=r(x),i=t(async(e,n,t)=>new Promise(r=>{s(e)?r(n):t(e,r)}),[]),a=t(n=>i(n,I,(n,t)=>{n.measure((n=0,r=0,o=0,i=0,a=0,s=0)=>{e.current={x:n,y:r,width:o,height:i,pageX:a,pageY:s},t(e.current)})}),[]),u=t((e,t)=>i(e,S,(e,r)=>{e.measureLayout(t,(e=0,t=0,o=0,i=0)=>{n.current={left:e,top:t,width:o,height:i},r(n.current)})}),[]),c=t(e=>i(e,x,(e,n)=>{e.measureInWindow((e=0,t=0,r=0,i=0)=>{o.current={x:e,y:t,width:r,height:i},n(o.current)})}),[]);return{measuresRef:e,measuresInContainerRef:n,measuresInWindowRef:o,calculateMeasures:a,calculateMeasuresInContainer:u,calculateMeasuresInWindow:c}},W=e=>{const n=e.current?.getScrollResponder()??null,t=n?.getInnerViewRef?.()??null,r=n?.getNativeScrollRef?.()??null;return{responder:n,inner:t,outer:r}};export{b as DEFAULT_LAYOUT,y as DEFAULT_NULLABLE_LAYOUT,W as getResponder,p as useAppState,w as useKeyboard,k as useLayout,E as useMeasures};
|
|
2
2
|
//# sourceMappingURL=index.mjs.map
|