UNPKG

@hazae41/glacier

Version:

Yet another React data (re)fetching library

1 lines 1.25 kB
{"version":3,"file":"use-once.cjs","sources":["../../../../../../../src/mods/react/hooks/blocks/use-once.ts"],"sourcesContent":["import { ReactQuery } from \"mods/react/types/query.js\"\nimport { useEffect } from \"react\"\n\n/**\n * Do a request on mount and url change only if there is no data yet\n * @warning Will still try to fetch is there is an error\n * @param query \n * @example You want to get some data once and share it in multiple components\n */\nexport function useOnce<K, D, F>(query: ReactQuery<K, D, F>, init?: RequestInit) {\n const { fetcher, ready, data, fetchOrThrow: fetch } = query\n\n useEffect(() => {\n if (!ready)\n return\n if (fetcher == null)\n return\n if (data != null)\n return\n fetch(init).catch(console.warn)\n }, [ready, data, fetch])\n}"],"names":["useEffect"],"mappings":";;;;AAGA;;;;;AAKG;AACa,SAAA,OAAO,CAAU,KAA0B,EAAE,IAAkB,EAAA;AAC7E,IAAA,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,GAAG,KAAK,CAAA;IAE3DA,eAAS,CAAC,MAAK;AACb,QAAA,IAAI,CAAC,KAAK;YACR,OAAM;QACR,IAAI,OAAO,IAAI,IAAI;YACjB,OAAM;QACR,IAAI,IAAI,IAAI,IAAI;YACd,OAAM;QACR,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;KAChC,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC,CAAA;AAC1B;;;;"}