@supabase/auth-js 2.58.1-canary.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +148 -0
- package/dist/main/AuthAdminApi.d.ts +4 -0
- package/dist/main/AuthAdminApi.d.ts.map +1 -0
- package/dist/main/AuthAdminApi.js +9 -0
- package/dist/main/AuthAdminApi.js.map +1 -0
- package/dist/main/AuthClient.d.ts +4 -0
- package/dist/main/AuthClient.d.ts.map +1 -0
- package/dist/main/AuthClient.js +9 -0
- package/dist/main/AuthClient.js.map +1 -0
- package/dist/main/GoTrueAdminApi.d.ts +99 -0
- package/dist/main/GoTrueAdminApi.d.ts.map +1 -0
- package/dist/main/GoTrueAdminApi.js +278 -0
- package/dist/main/GoTrueAdminApi.js.map +1 -0
- package/dist/main/GoTrueClient.d.ts +531 -0
- package/dist/main/GoTrueClient.d.ts.map +1 -0
- package/dist/main/GoTrueClient.js +2564 -0
- package/dist/main/GoTrueClient.js.map +1 -0
- package/dist/main/index.d.ts +9 -0
- package/dist/main/index.d.ts.map +1 -0
- package/dist/main/index.js +36 -0
- package/dist/main/index.js.map +1 -0
- package/dist/main/lib/base64url.d.ts +76 -0
- package/dist/main/lib/base64url.d.ts.map +1 -0
- package/dist/main/lib/base64url.js +269 -0
- package/dist/main/lib/base64url.js.map +1 -0
- package/dist/main/lib/constants.d.ts +26 -0
- package/dist/main/lib/constants.d.ts.map +1 -0
- package/dist/main/lib/constants.js +31 -0
- package/dist/main/lib/constants.js.map +1 -0
- package/dist/main/lib/error-codes.d.ts +7 -0
- package/dist/main/lib/error-codes.d.ts.map +1 -0
- package/dist/main/lib/error-codes.js +3 -0
- package/dist/main/lib/error-codes.js.map +1 -0
- package/dist/main/lib/errors.d.ts +100 -0
- package/dist/main/lib/errors.d.ts.map +1 -0
- package/dist/main/lib/errors.js +137 -0
- package/dist/main/lib/errors.js.map +1 -0
- package/dist/main/lib/fetch.d.ts +34 -0
- package/dist/main/lib/fetch.d.ts.map +1 -0
- package/dist/main/lib/fetch.js +194 -0
- package/dist/main/lib/fetch.js.map +1 -0
- package/dist/main/lib/helpers.d.ts +67 -0
- package/dist/main/lib/helpers.d.ts.map +1 -0
- package/dist/main/lib/helpers.js +388 -0
- package/dist/main/lib/helpers.js.map +1 -0
- package/dist/main/lib/local-storage.d.ts +9 -0
- package/dist/main/lib/local-storage.d.ts.map +1 -0
- package/dist/main/lib/local-storage.js +21 -0
- package/dist/main/lib/local-storage.js.map +1 -0
- package/dist/main/lib/locks.d.ts +64 -0
- package/dist/main/lib/locks.d.ts.map +1 -0
- package/dist/main/lib/locks.js +187 -0
- package/dist/main/lib/locks.js.map +1 -0
- package/dist/main/lib/polyfills.d.ts +5 -0
- package/dist/main/lib/polyfills.d.ts.map +1 -0
- package/dist/main/lib/polyfills.js +29 -0
- package/dist/main/lib/polyfills.js.map +1 -0
- package/dist/main/lib/types.d.ts +1130 -0
- package/dist/main/lib/types.d.ts.map +1 -0
- package/dist/main/lib/types.js +22 -0
- package/dist/main/lib/types.js.map +1 -0
- package/dist/main/lib/version.d.ts +2 -0
- package/dist/main/lib/version.d.ts.map +1 -0
- package/dist/main/lib/version.js +11 -0
- package/dist/main/lib/version.js.map +1 -0
- package/dist/main/lib/web3/ethereum.d.ts +96 -0
- package/dist/main/lib/web3/ethereum.d.ts.map +1 -0
- package/dist/main/lib/web3/ethereum.js +66 -0
- package/dist/main/lib/web3/ethereum.js.map +1 -0
- package/dist/main/lib/web3/solana.d.ts +160 -0
- package/dist/main/lib/web3/solana.d.ts.map +1 -0
- package/dist/main/lib/web3/solana.js +4 -0
- package/dist/main/lib/web3/solana.js.map +1 -0
- package/dist/main/lib/webauthn.d.ts +274 -0
- package/dist/main/lib/webauthn.d.ts.map +1 -0
- package/dist/main/lib/webauthn.dom.d.ts +583 -0
- package/dist/main/lib/webauthn.dom.d.ts.map +1 -0
- package/dist/main/lib/webauthn.dom.js +4 -0
- package/dist/main/lib/webauthn.dom.js.map +1 -0
- package/dist/main/lib/webauthn.errors.d.ts +80 -0
- package/dist/main/lib/webauthn.errors.d.ts.map +1 -0
- package/dist/main/lib/webauthn.errors.js +265 -0
- package/dist/main/lib/webauthn.errors.js.map +1 -0
- package/dist/main/lib/webauthn.js +702 -0
- package/dist/main/lib/webauthn.js.map +1 -0
- package/dist/module/AuthAdminApi.d.ts +4 -0
- package/dist/module/AuthAdminApi.d.ts.map +1 -0
- package/dist/module/AuthAdminApi.js +4 -0
- package/dist/module/AuthAdminApi.js.map +1 -0
- package/dist/module/AuthClient.d.ts +4 -0
- package/dist/module/AuthClient.d.ts.map +1 -0
- package/dist/module/AuthClient.js +4 -0
- package/dist/module/AuthClient.js.map +1 -0
- package/dist/module/GoTrueAdminApi.d.ts +99 -0
- package/dist/module/GoTrueAdminApi.d.ts.map +1 -0
- package/dist/module/GoTrueAdminApi.js +275 -0
- package/dist/module/GoTrueAdminApi.js.map +1 -0
- package/dist/module/GoTrueClient.d.ts +531 -0
- package/dist/module/GoTrueClient.d.ts.map +1 -0
- package/dist/module/GoTrueClient.js +2559 -0
- package/dist/module/GoTrueClient.js.map +1 -0
- package/dist/module/index.d.ts +9 -0
- package/dist/module/index.d.ts.map +1 -0
- package/dist/module/index.js +9 -0
- package/dist/module/index.js.map +1 -0
- package/dist/module/lib/base64url.d.ts +76 -0
- package/dist/module/lib/base64url.d.ts.map +1 -0
- package/dist/module/lib/base64url.js +257 -0
- package/dist/module/lib/base64url.js.map +1 -0
- package/dist/module/lib/constants.d.ts +26 -0
- package/dist/module/lib/constants.d.ts.map +1 -0
- package/dist/module/lib/constants.js +28 -0
- package/dist/module/lib/constants.js.map +1 -0
- package/dist/module/lib/error-codes.d.ts +7 -0
- package/dist/module/lib/error-codes.d.ts.map +1 -0
- package/dist/module/lib/error-codes.js +2 -0
- package/dist/module/lib/error-codes.js.map +1 -0
- package/dist/module/lib/errors.d.ts +100 -0
- package/dist/module/lib/errors.d.ts.map +1 -0
- package/dist/module/lib/errors.js +116 -0
- package/dist/module/lib/errors.js.map +1 -0
- package/dist/module/lib/fetch.d.ts +34 -0
- package/dist/module/lib/fetch.d.ts.map +1 -0
- package/dist/module/lib/fetch.js +184 -0
- package/dist/module/lib/fetch.js.map +1 -0
- package/dist/module/lib/helpers.d.ts +67 -0
- package/dist/module/lib/helpers.d.ts.map +1 -0
- package/dist/module/lib/helpers.js +329 -0
- package/dist/module/lib/helpers.js.map +1 -0
- package/dist/module/lib/local-storage.d.ts +9 -0
- package/dist/module/lib/local-storage.d.ts.map +1 -0
- package/dist/module/lib/local-storage.js +18 -0
- package/dist/module/lib/local-storage.js.map +1 -0
- package/dist/module/lib/locks.d.ts +64 -0
- package/dist/module/lib/locks.d.ts.map +1 -0
- package/dist/module/lib/locks.js +179 -0
- package/dist/module/lib/locks.js.map +1 -0
- package/dist/module/lib/polyfills.d.ts +5 -0
- package/dist/module/lib/polyfills.d.ts.map +1 -0
- package/dist/module/lib/polyfills.js +26 -0
- package/dist/module/lib/polyfills.js.map +1 -0
- package/dist/module/lib/types.d.ts +1130 -0
- package/dist/module/lib/types.d.ts.map +1 -0
- package/dist/module/lib/types.js +19 -0
- package/dist/module/lib/types.js.map +1 -0
- package/dist/module/lib/version.d.ts +2 -0
- package/dist/module/lib/version.d.ts.map +1 -0
- package/dist/module/lib/version.js +8 -0
- package/dist/module/lib/version.js.map +1 -0
- package/dist/module/lib/web3/ethereum.d.ts +96 -0
- package/dist/module/lib/web3/ethereum.d.ts.map +1 -0
- package/dist/module/lib/web3/ethereum.js +60 -0
- package/dist/module/lib/web3/ethereum.js.map +1 -0
- package/dist/module/lib/web3/solana.d.ts +160 -0
- package/dist/module/lib/web3/solana.d.ts.map +1 -0
- package/dist/module/lib/web3/solana.js +3 -0
- package/dist/module/lib/web3/solana.js.map +1 -0
- package/dist/module/lib/webauthn.d.ts +274 -0
- package/dist/module/lib/webauthn.d.ts.map +1 -0
- package/dist/module/lib/webauthn.dom.d.ts +583 -0
- package/dist/module/lib/webauthn.dom.d.ts.map +1 -0
- package/dist/module/lib/webauthn.dom.js +3 -0
- package/dist/module/lib/webauthn.dom.js.map +1 -0
- package/dist/module/lib/webauthn.errors.d.ts +80 -0
- package/dist/module/lib/webauthn.errors.d.ts.map +1 -0
- package/dist/module/lib/webauthn.errors.js +257 -0
- package/dist/module/lib/webauthn.errors.js.map +1 -0
- package/dist/module/lib/webauthn.js +685 -0
- package/dist/module/lib/webauthn.js.map +1 -0
- package/package.json +49 -0
- package/src/AuthAdminApi.ts +5 -0
- package/src/AuthClient.ts +5 -0
- package/src/GoTrueAdminApi.ts +352 -0
- package/src/GoTrueClient.ts +3483 -0
- package/src/index.ts +13 -0
- package/src/lib/base64url.ts +308 -0
- package/src/lib/constants.ts +34 -0
- package/src/lib/error-codes.ts +90 -0
- package/src/lib/errors.ts +165 -0
- package/src/lib/fetch.ts +283 -0
- package/src/lib/helpers.ts +416 -0
- package/src/lib/local-storage.ts +21 -0
- package/src/lib/locks.ts +225 -0
- package/src/lib/polyfills.ts +23 -0
- package/src/lib/types.ts +1450 -0
- package/src/lib/version.ts +7 -0
- package/src/lib/web3/ethereum.ts +184 -0
- package/src/lib/web3/solana.ts +186 -0
- package/src/lib/webauthn.dom.ts +636 -0
- package/src/lib/webauthn.errors.ts +317 -0
- package/src/lib/webauthn.ts +929 -0
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProcessLockAcquireTimeoutError = exports.NavigatorLockAcquireTimeoutError = exports.LockAcquireTimeoutError = exports.internals = void 0;
|
|
4
|
+
exports.navigatorLock = navigatorLock;
|
|
5
|
+
exports.processLock = processLock;
|
|
6
|
+
const helpers_1 = require("./helpers");
|
|
7
|
+
/**
|
|
8
|
+
* @experimental
|
|
9
|
+
*/
|
|
10
|
+
exports.internals = {
|
|
11
|
+
/**
|
|
12
|
+
* @experimental
|
|
13
|
+
*/
|
|
14
|
+
debug: !!(globalThis &&
|
|
15
|
+
(0, helpers_1.supportsLocalStorage)() &&
|
|
16
|
+
globalThis.localStorage &&
|
|
17
|
+
globalThis.localStorage.getItem('supabase.gotrue-js.locks.debug') === 'true'),
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* An error thrown when a lock cannot be acquired after some amount of time.
|
|
21
|
+
*
|
|
22
|
+
* Use the {@link #isAcquireTimeout} property instead of checking with `instanceof`.
|
|
23
|
+
*/
|
|
24
|
+
class LockAcquireTimeoutError extends Error {
|
|
25
|
+
constructor(message) {
|
|
26
|
+
super(message);
|
|
27
|
+
this.isAcquireTimeout = true;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
exports.LockAcquireTimeoutError = LockAcquireTimeoutError;
|
|
31
|
+
class NavigatorLockAcquireTimeoutError extends LockAcquireTimeoutError {
|
|
32
|
+
}
|
|
33
|
+
exports.NavigatorLockAcquireTimeoutError = NavigatorLockAcquireTimeoutError;
|
|
34
|
+
class ProcessLockAcquireTimeoutError extends LockAcquireTimeoutError {
|
|
35
|
+
}
|
|
36
|
+
exports.ProcessLockAcquireTimeoutError = ProcessLockAcquireTimeoutError;
|
|
37
|
+
/**
|
|
38
|
+
* Implements a global exclusive lock using the Navigator LockManager API. It
|
|
39
|
+
* is available on all browsers released after 2022-03-15 with Safari being the
|
|
40
|
+
* last one to release support. If the API is not available, this function will
|
|
41
|
+
* throw. Make sure you check availablility before configuring {@link
|
|
42
|
+
* GoTrueClient}.
|
|
43
|
+
*
|
|
44
|
+
* You can turn on debugging by setting the `supabase.gotrue-js.locks.debug`
|
|
45
|
+
* local storage item to `true`.
|
|
46
|
+
*
|
|
47
|
+
* Internals:
|
|
48
|
+
*
|
|
49
|
+
* Since the LockManager API does not preserve stack traces for the async
|
|
50
|
+
* function passed in the `request` method, a trick is used where acquiring the
|
|
51
|
+
* lock releases a previously started promise to run the operation in the `fn`
|
|
52
|
+
* function. The lock waits for that promise to finish (with or without error),
|
|
53
|
+
* while the function will finally wait for the result anyway.
|
|
54
|
+
*
|
|
55
|
+
* @param name Name of the lock to be acquired.
|
|
56
|
+
* @param acquireTimeout If negative, no timeout. If 0 an error is thrown if
|
|
57
|
+
* the lock can't be acquired without waiting. If positive, the lock acquire
|
|
58
|
+
* will time out after so many milliseconds. An error is
|
|
59
|
+
* a timeout if it has `isAcquireTimeout` set to true.
|
|
60
|
+
* @param fn The operation to run once the lock is acquired.
|
|
61
|
+
*/
|
|
62
|
+
async function navigatorLock(name, acquireTimeout, fn) {
|
|
63
|
+
if (exports.internals.debug) {
|
|
64
|
+
console.log('@supabase/gotrue-js: navigatorLock: acquire lock', name, acquireTimeout);
|
|
65
|
+
}
|
|
66
|
+
const abortController = new globalThis.AbortController();
|
|
67
|
+
if (acquireTimeout > 0) {
|
|
68
|
+
setTimeout(() => {
|
|
69
|
+
abortController.abort();
|
|
70
|
+
if (exports.internals.debug) {
|
|
71
|
+
console.log('@supabase/gotrue-js: navigatorLock acquire timed out', name);
|
|
72
|
+
}
|
|
73
|
+
}, acquireTimeout);
|
|
74
|
+
}
|
|
75
|
+
// MDN article: https://developer.mozilla.org/en-US/docs/Web/API/LockManager/request
|
|
76
|
+
// Wrapping navigator.locks.request() with a plain Promise is done as some
|
|
77
|
+
// libraries like zone.js patch the Promise object to track the execution
|
|
78
|
+
// context. However, it appears that most browsers use an internal promise
|
|
79
|
+
// implementation when using the navigator.locks.request() API causing them
|
|
80
|
+
// to lose context and emit confusing log messages or break certain features.
|
|
81
|
+
// This wrapping is believed to help zone.js track the execution context
|
|
82
|
+
// better.
|
|
83
|
+
return await Promise.resolve().then(() => globalThis.navigator.locks.request(name, acquireTimeout === 0
|
|
84
|
+
? {
|
|
85
|
+
mode: 'exclusive',
|
|
86
|
+
ifAvailable: true,
|
|
87
|
+
}
|
|
88
|
+
: {
|
|
89
|
+
mode: 'exclusive',
|
|
90
|
+
signal: abortController.signal,
|
|
91
|
+
}, async (lock) => {
|
|
92
|
+
if (lock) {
|
|
93
|
+
if (exports.internals.debug) {
|
|
94
|
+
console.log('@supabase/gotrue-js: navigatorLock: acquired', name, lock.name);
|
|
95
|
+
}
|
|
96
|
+
try {
|
|
97
|
+
return await fn();
|
|
98
|
+
}
|
|
99
|
+
finally {
|
|
100
|
+
if (exports.internals.debug) {
|
|
101
|
+
console.log('@supabase/gotrue-js: navigatorLock: released', name, lock.name);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
if (acquireTimeout === 0) {
|
|
107
|
+
if (exports.internals.debug) {
|
|
108
|
+
console.log('@supabase/gotrue-js: navigatorLock: not immediately available', name);
|
|
109
|
+
}
|
|
110
|
+
throw new NavigatorLockAcquireTimeoutError(`Acquiring an exclusive Navigator LockManager lock "${name}" immediately failed`);
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
if (exports.internals.debug) {
|
|
114
|
+
try {
|
|
115
|
+
const result = await globalThis.navigator.locks.query();
|
|
116
|
+
console.log('@supabase/gotrue-js: Navigator LockManager state', JSON.stringify(result, null, ' '));
|
|
117
|
+
}
|
|
118
|
+
catch (e) {
|
|
119
|
+
console.warn('@supabase/gotrue-js: Error when querying Navigator LockManager state', e);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
// Browser is not following the Navigator LockManager spec, it
|
|
123
|
+
// returned a null lock when we didn't use ifAvailable. So we can
|
|
124
|
+
// pretend the lock is acquired in the name of backward compatibility
|
|
125
|
+
// and user experience and just run the function.
|
|
126
|
+
console.warn('@supabase/gotrue-js: Navigator LockManager returned a null lock when using #request without ifAvailable set to true, it appears this browser is not following the LockManager spec https://developer.mozilla.org/en-US/docs/Web/API/LockManager/request');
|
|
127
|
+
return await fn();
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}));
|
|
131
|
+
}
|
|
132
|
+
const PROCESS_LOCKS = {};
|
|
133
|
+
/**
|
|
134
|
+
* Implements a global exclusive lock that works only in the current process.
|
|
135
|
+
* Useful for environments like React Native or other non-browser
|
|
136
|
+
* single-process (i.e. no concept of "tabs") environments.
|
|
137
|
+
*
|
|
138
|
+
* Use {@link #navigatorLock} in browser environments.
|
|
139
|
+
*
|
|
140
|
+
* @param name Name of the lock to be acquired.
|
|
141
|
+
* @param acquireTimeout If negative, no timeout. If 0 an error is thrown if
|
|
142
|
+
* the lock can't be acquired without waiting. If positive, the lock acquire
|
|
143
|
+
* will time out after so many milliseconds. An error is
|
|
144
|
+
* a timeout if it has `isAcquireTimeout` set to true.
|
|
145
|
+
* @param fn The operation to run once the lock is acquired.
|
|
146
|
+
*/
|
|
147
|
+
async function processLock(name, acquireTimeout, fn) {
|
|
148
|
+
var _a;
|
|
149
|
+
const previousOperation = (_a = PROCESS_LOCKS[name]) !== null && _a !== void 0 ? _a : Promise.resolve();
|
|
150
|
+
const currentOperation = Promise.race([
|
|
151
|
+
previousOperation.catch(() => {
|
|
152
|
+
// ignore error of previous operation that we're waiting to finish
|
|
153
|
+
return null;
|
|
154
|
+
}),
|
|
155
|
+
acquireTimeout >= 0
|
|
156
|
+
? new Promise((_, reject) => {
|
|
157
|
+
setTimeout(() => {
|
|
158
|
+
reject(new ProcessLockAcquireTimeoutError(`Acquring process lock with name "${name}" timed out`));
|
|
159
|
+
}, acquireTimeout);
|
|
160
|
+
})
|
|
161
|
+
: null,
|
|
162
|
+
].filter((x) => x))
|
|
163
|
+
.catch((e) => {
|
|
164
|
+
if (e && e.isAcquireTimeout) {
|
|
165
|
+
throw e;
|
|
166
|
+
}
|
|
167
|
+
return null;
|
|
168
|
+
})
|
|
169
|
+
.then(async () => {
|
|
170
|
+
// previous operations finished and we didn't get a race on the acquire
|
|
171
|
+
// timeout, so the current operation can finally start
|
|
172
|
+
return await fn();
|
|
173
|
+
});
|
|
174
|
+
PROCESS_LOCKS[name] = currentOperation.catch(async (e) => {
|
|
175
|
+
if (e && e.isAcquireTimeout) {
|
|
176
|
+
// if the current operation timed out, it doesn't mean that the previous
|
|
177
|
+
// operation finished, so we need contnue waiting for it to finish
|
|
178
|
+
await previousOperation;
|
|
179
|
+
return null;
|
|
180
|
+
}
|
|
181
|
+
throw e;
|
|
182
|
+
});
|
|
183
|
+
// finally wait for the current operation to finish successfully, with an
|
|
184
|
+
// error or with an acquire timeout error
|
|
185
|
+
return await currentOperation;
|
|
186
|
+
}
|
|
187
|
+
//# sourceMappingURL=locks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"locks.js","sourceRoot":"","sources":["../../../src/lib/locks.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"polyfills.d.ts","sourceRoot":"","sources":["../../../src/lib/polyfills.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,wBAAgB,kBAAkB,SAmBjC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.polyfillGlobalThis = polyfillGlobalThis;
|
|
4
|
+
/**
|
|
5
|
+
* https://mathiasbynens.be/notes/globalthis
|
|
6
|
+
*/
|
|
7
|
+
function polyfillGlobalThis() {
|
|
8
|
+
if (typeof globalThis === 'object')
|
|
9
|
+
return;
|
|
10
|
+
try {
|
|
11
|
+
Object.defineProperty(Object.prototype, '__magic__', {
|
|
12
|
+
get: function () {
|
|
13
|
+
return this;
|
|
14
|
+
},
|
|
15
|
+
configurable: true,
|
|
16
|
+
});
|
|
17
|
+
// @ts-expect-error 'Allow access to magic'
|
|
18
|
+
__magic__.globalThis = __magic__;
|
|
19
|
+
// @ts-expect-error 'Allow access to magic'
|
|
20
|
+
delete Object.prototype.__magic__;
|
|
21
|
+
}
|
|
22
|
+
catch (e) {
|
|
23
|
+
if (typeof self !== 'undefined') {
|
|
24
|
+
// @ts-expect-error 'Allow access to globals'
|
|
25
|
+
self.globalThis = self;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=polyfills.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"polyfills.js","sourceRoot":"","sources":["../../../src/lib/polyfills.ts"],"names":[],"mappings":";;AAGA,gDAmBC;AAtBD;;GAEG;AACH,SAAgB,kBAAkB;IAChC,IAAI,OAAO,UAAU,KAAK,QAAQ;QAAE,OAAM;IAC1C,IAAI,CAAC;QACH,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,SAAS,EAAE,WAAW,EAAE;YACnD,GAAG,EAAE;gBACH,OAAO,IAAI,CAAA;YACb,CAAC;YACD,YAAY,EAAE,IAAI;SACnB,CAAC,CAAA;QACF,2CAA2C;QAC3C,SAAS,CAAC,UAAU,GAAG,SAAS,CAAA;QAChC,2CAA2C;QAC3C,OAAO,MAAM,CAAC,SAAS,CAAC,SAAS,CAAA;IACnC,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,IAAI,OAAO,IAAI,KAAK,WAAW,EAAE,CAAC;YAChC,6CAA6C;YAC7C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAA;QACxB,CAAC;IACH,CAAC;AACH,CAAC"}
|