@xyo-network/metamask-connector 4.0.3 → 4.1.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.
@@ -1,5 +1,9 @@
1
+ import type { MetaMaskInpageProvider } from '@metamask/providers';
1
2
  import type { Listener } from 'ethers';
2
3
  import { BrowserProvider } from 'ethers';
4
+ declare global {
5
+ var ethereum: MetaMaskInpageProvider | undefined;
6
+ }
3
7
  export declare class MetaMaskConnector {
4
8
  private account;
5
9
  private ethereum;
@@ -7,10 +11,10 @@ export declare class MetaMaskConnector {
7
11
  private provider;
8
12
  private providerListeners;
9
13
  constructor(provider?: BrowserProvider);
10
- get chainId(): string | null;
11
- get currentAccount(): string | null;
14
+ get chainId(): string | null | undefined;
15
+ get currentAccount(): string | null | undefined;
12
16
  connectWallet(): Promise<void>;
13
- isMetaMaskInstalled(): true;
17
+ isMetaMaskInstalled(): true | undefined;
14
18
  isWalletIsConnected: () => boolean;
15
19
  /**
16
20
  * EIP-1193 Event Listeners
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAA;AAGjE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAA;AAExC,OAAO,CAAC,MAAM,CAAC;IACb,IAAI,QAAQ,EAAE,sBAAsB,GAAG,SAAS,CAAA;CACjD;AAED,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAAsB;IAEtC,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,QAAQ,CAA6B;IAC7C,OAAO,CAAC,iBAAiB,CAA4C;gBAEzD,QAAQ,CAAC,EAAE,eAAe;IAQtC,IAAI,OAAO,8BAEV;IAED,IAAI,cAAc,8BAEjB;IAEK,aAAa;IAgBnB,mBAAmB;IAInB,mBAAmB,gBAMlB;IAED;;;;;OAKG;IACH,yBAAyB,CAAC,QAAQ,EAAE,QAAQ;IAK5C,sBAAsB,CAAC,QAAQ,EAAE,QAAQ;IAKzC,iBAAiB,CAAC,QAAQ,EAAE,QAAQ;IAKpC,oBAAoB,CAAC,QAAQ,EAAE,QAAQ;IAKvC,sBAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAKxD,uBAAuB;IAIjB,eAAe,IAAI,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC;IAS3C,WAAW,CAAC,OAAO,EAAE,MAAM;IAWjC,mGAAmG;IACnG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAOvD,0BAA0B,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAOnE,2BAA2B,IAAI,IAAI;IAMnC,OAAO,CAAC,kBAAkB;CAG3B"}
@@ -0,0 +1,40 @@
1
+ import { MetaMaskInpageProvider } from '@metamask/providers';
2
+ import { BrowserProvider, Listener } from 'ethers';
3
+
4
+ declare global {
5
+ var ethereum: MetaMaskInpageProvider | undefined;
6
+ }
7
+ declare class MetaMaskConnector {
8
+ private account;
9
+ private ethereum;
10
+ private listeners;
11
+ private provider;
12
+ private providerListeners;
13
+ constructor(provider?: BrowserProvider);
14
+ get chainId(): string | null | undefined;
15
+ get currentAccount(): string | null | undefined;
16
+ connectWallet(): Promise<void>;
17
+ isMetaMaskInstalled(): true | undefined;
18
+ isWalletIsConnected: () => boolean;
19
+ /**
20
+ * EIP-1193 Event Listeners
21
+ *
22
+ * .on in Web3Provider does not understand EIP-1193 events
23
+ * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
24
+ */
25
+ providerOnAccountsChanged(listener: Listener): void;
26
+ providerOnChainChanged(listener: Listener): void;
27
+ providerOnConnect(listener: Listener): void;
28
+ providerOnDisconnect(listener: Listener): void;
29
+ providerRemoveListener(event: string, listener: Listener): void;
30
+ providerRemoveListeners(): void;
31
+ requestAccounts(): Promise<string[] | null>;
32
+ signMessage(message: string): Promise<string | undefined>;
33
+ /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
34
+ web3ProviderOn(event: string, listener: Listener): void;
35
+ web3ProviderRemoveListener(event: string, listener: Listener): void;
36
+ web3ProviderRemoveListeners(): void;
37
+ private logProviderMissing;
38
+ }
39
+
40
+ export { MetaMaskConnector };
@@ -1,5 +1,6 @@
1
1
  // src/MetaMaskConnector.ts
2
2
  import { forget } from "@xylabs/forget";
3
+ import { isString } from "@xylabs/typeof";
3
4
  import { BrowserProvider } from "ethers";
4
5
  var MetaMaskConnector = class {
5
6
  account = "";
@@ -11,7 +12,7 @@ var MetaMaskConnector = class {
11
12
  if (provider) {
12
13
  this.provider = provider;
13
14
  } else if (this.ethereum) {
14
- this.provider = new BrowserProvider(globalThis.ethereum);
15
+ this.provider = new BrowserProvider(this.ethereum);
15
16
  }
16
17
  }
17
18
  get chainId() {
@@ -37,7 +38,7 @@ var MetaMaskConnector = class {
37
38
  return this.ethereum && this.ethereum.isMetaMask;
38
39
  }
39
40
  isWalletIsConnected = () => {
40
- if (this.currentAccount) {
41
+ if (isString(this.currentAccount)) {
41
42
  console.log("Found an authorized account:", this.ethereum?.selectedAddress);
42
43
  return true;
43
44
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import type { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport type { Listener } from 'ethers'\nimport { BrowserProvider } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = globalThis.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(globalThis.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n // this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n // for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n return await signer.signMessage(message)\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener): void {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener): void {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter(savedListener => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners(): void {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing(): void {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import type { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { isString } from '@xylabs/typeof'\nimport type { Listener } from 'ethers'\nimport { BrowserProvider } from 'ethers'\n\ndeclare global {\n var ethereum: MetaMaskInpageProvider | undefined\n}\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = globalThis.ethereum\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(this.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (isString(this.currentAccount)) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n // this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n // for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n return await signer.signMessage(message)\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener): void {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener): void {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter(savedListener => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners(): void {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing(): void {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":";AACA,SAAS,cAAc;AACvB,SAAS,gBAAgB;AAEzB,SAAS,uBAAuB;AAMzB,IAAM,oBAAN,MAAwB;AAAA,EACrB,UAAU;AAAA,EACV,WAAW,WAAW;AAAA,EAEtB,YAAwB,CAAC;AAAA,EACzB;AAAA,EACA,oBAA2D,CAAC;AAAA,EAEpE,YAAY,UAA4B;AACtC,QAAI,UAAU;AACZ,WAAK,WAAW;AAAA,IAClB,WAAW,KAAK,UAAU;AACxB,WAAK,WAAW,IAAI,gBAAgB,KAAK,QAAQ;AAAA,IACnD;AAAA,EACF;AAAA,EAEA,IAAI,UAAU;AACZ,WAAO,KAAK,UAAU;AAAA,EACxB;AAAA,EAEA,IAAI,iBAAiB;AACnB,WAAO,KAAK,UAAU;AAAA,EACxB;AAAA,EAEA,MAAM,gBAAgB;AACpB,QAAI,CAAC,KAAK,UAAU;AAClB,WAAK,mBAAmB;AACxB;AAAA,IACF;AAEA,UAAM,WAAW,MAAM,KAAK,SAAS,KAAK,uBAAuB,CAAC,CAAC;AAEnE,QAAI,SAAS,SAAS,GAAG;AACvB,WAAK,UAAU,SAAS,CAAC;AACzB,cAAQ,IAAI,cAAc,KAAK,OAAO;AAAA,IACxC,OAAO;AACL,cAAQ,IAAI,8BAA8B;AAAA,IAC5C;AAAA,EACF;AAAA,EAEA,sBAAsB;AACpB,WAAO,KAAK,YAAY,KAAK,SAAS;AAAA,EACxC;AAAA,EAEA,sBAAsB,MAAM;AAC1B,QAAI,SAAS,KAAK,cAAc,GAAG;AACjC,cAAQ,IAAI,gCAAgC,KAAK,UAAU,eAAe;AAC1E,aAAO;AAAA,IACT;AACA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,0BAA0B,UAAoB;AAC5C,SAAK,UAAU,GAAG,mBAAmB,QAAQ;AAC7C,SAAK,kBAAkB,KAAK,CAAC,mBAAmB,QAAQ,CAAC;AAAA,EAC3D;AAAA,EAEA,uBAAuB,UAAoB;AACzC,SAAK,UAAU,GAAG,gBAAgB,QAAQ;AAC1C,SAAK,kBAAkB,KAAK,CAAC,gBAAgB,QAAQ,CAAC;AAAA,EACxD;AAAA,EAEA,kBAAkB,UAAoB;AACpC,SAAK,UAAU,GAAG,WAAW,QAAQ;AACrC,SAAK,kBAAkB,KAAK,CAAC,WAAW,QAAQ,CAAC;AAAA,EACnD;AAAA,EAEA,qBAAqB,UAAoB;AACvC,SAAK,UAAU,GAAG,cAAc,QAAQ;AACxC,SAAK,kBAAkB,KAAK,CAAC,cAAc,QAAQ,CAAC;AAAA,EACtD;AAAA,EAEA,uBAAuB,OAAe,UAAoB;AAExD,SAAK,oBAAoB,KAAK,kBAAkB,OAAO,CAAC,CAAC,EAAE,aAAa,MAAM,aAAa,aAAa;AAAA,EAC1G;AAAA,EAEA,0BAA0B;AAAA,EAE1B;AAAA,EAEA,MAAM,kBAA4C;AAChD,QAAI,CAAC,KAAK,UAAU;AAClB,WAAK,mBAAmB;AACxB,aAAO;AAAA,IACT;AAEA,WAAO,MAAM,KAAK,SAAS,KAAK,uBAAuB,CAAC,CAAC;AAAA,EAC3D;AAAA,EAEA,MAAM,YAAY,SAAiB;AACjC,QAAI,CAAC,KAAK,UAAU;AAClB,WAAK,mBAAmB;AACxB;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,KAAK,SAAS,UAAU;AAC7C,UAAM,OAAO,WAAW;AACxB,WAAO,MAAM,OAAO,YAAY,OAAO;AAAA,EACzC;AAAA;AAAA,EAGA,eAAe,OAAe,UAA0B;AACtD,QAAI,KAAK,UAAU;AACjB,aAAO,KAAK,SAAS,GAAG,OAAO,QAAQ,CAAC;AAAA,IAC1C;AACA,SAAK,UAAU,KAAK,QAAQ;AAAA,EAC9B;AAAA,EAEA,2BAA2B,OAAe,UAA0B;AAClE,QAAI,KAAK,UAAU;AACjB,aAAO,KAAK,SAAS,eAAe,OAAO,QAAQ,CAAC;AAAA,IACtD;AACA,SAAK,YAAY,KAAK,UAAU,OAAO,mBAAiB,aAAa,aAAa;AAAA,EACpF;AAAA,EAEA,8BAAoC;AAClC,QAAI,KAAK,UAAU;AACjB,aAAO,KAAK,SAAS,mBAAmB,CAAC;AAAA,IAC3C;AAAA,EACF;AAAA,EAEQ,qBAA2B;AACjC,YAAQ,KAAK,iHAAiH;AAAA,EAChI;AACF;","names":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xyo-network/metamask-connector",
3
- "version": "4.0.3",
3
+ "version": "4.1.0",
4
4
  "description": "Primary SDK for using XYO Protocol 2.0",
5
5
  "homepage": "https://xyo.network",
6
6
  "bugs": {
@@ -21,21 +21,22 @@
21
21
  "type": "module",
22
22
  "exports": {
23
23
  ".": {
24
- "types": "./dist/types/index.d.ts",
24
+ "types": "./dist/browser/index.d.ts",
25
25
  "default": "./dist/browser/index.mjs"
26
26
  },
27
27
  "./package.json": "./package.json"
28
28
  },
29
29
  "module": "dist/browser/index.mjs",
30
- "types": "dist/types/index.d.ts",
30
+ "types": "dist/browser/index.d.ts",
31
31
  "dependencies": {
32
- "@xylabs/forget": "^4.13.4",
32
+ "@xylabs/forget": "^4.13.15",
33
+ "@xylabs/typeof": "^4.13.15",
33
34
  "ethers": "^6.15.0"
34
35
  },
35
36
  "devDependencies": {
36
37
  "@metamask/providers": "^22.1.0",
37
- "@xylabs/ts-scripts-yarn3": "^6.5.18",
38
- "@xylabs/tsconfig-dom": "^6.5.18",
38
+ "@xylabs/ts-scripts-yarn3": "^7.0.0-rc.20",
39
+ "@xylabs/tsconfig-dom": "^7.0.0-rc.20",
39
40
  "typescript": "^5.8.3"
40
41
  },
41
42
  "publishConfig": {
@@ -1,11 +1,16 @@
1
1
  import type { MetaMaskInpageProvider } from '@metamask/providers'
2
2
  import { forget } from '@xylabs/forget'
3
+ import { isString } from '@xylabs/typeof'
3
4
  import type { Listener } from 'ethers'
4
5
  import { BrowserProvider } from 'ethers'
5
6
 
7
+ declare global {
8
+ var ethereum: MetaMaskInpageProvider | undefined
9
+ }
10
+
6
11
  export class MetaMaskConnector {
7
12
  private account = ''
8
- private ethereum = globalThis.ethereum as MetaMaskInpageProvider
13
+ private ethereum = globalThis.ethereum
9
14
 
10
15
  private listeners: Listener[] = []
11
16
  private provider: BrowserProvider | undefined
@@ -15,7 +20,7 @@ export class MetaMaskConnector {
15
20
  if (provider) {
16
21
  this.provider = provider
17
22
  } else if (this.ethereum) {
18
- this.provider = new BrowserProvider(globalThis.ethereum)
23
+ this.provider = new BrowserProvider(this.ethereum)
19
24
  }
20
25
  }
21
26
 
@@ -48,7 +53,7 @@ export class MetaMaskConnector {
48
53
  }
49
54
 
50
55
  isWalletIsConnected = () => {
51
- if (this.currentAccount) {
56
+ if (isString(this.currentAccount)) {
52
57
  console.log('Found an authorized account:', this.ethereum?.selectedAddress)
53
58
  return true
54
59
  }
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAA;AAExC,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAAgD;IAEhE,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,QAAQ,CAA6B;IAC7C,OAAO,CAAC,iBAAiB,CAA4C;gBAEzD,QAAQ,CAAC,EAAE,eAAe;IAQtC,IAAI,OAAO,kBAEV;IAED,IAAI,cAAc,kBAEjB;IAEK,aAAa;IAgBnB,mBAAmB;IAInB,mBAAmB,gBAMlB;IAED;;;;;OAKG;IACH,yBAAyB,CAAC,QAAQ,EAAE,QAAQ;IAK5C,sBAAsB,CAAC,QAAQ,EAAE,QAAQ;IAKzC,iBAAiB,CAAC,QAAQ,EAAE,QAAQ;IAKpC,oBAAoB,CAAC,QAAQ,EAAE,QAAQ;IAKvC,sBAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAKxD,uBAAuB;IAIjB,eAAe,IAAI,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC;IAS3C,WAAW,CAAC,OAAO,EAAE,MAAM;IAWjC,mGAAmG;IACnG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAOvD,0BAA0B,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAOnE,2BAA2B,IAAI,IAAI;IAMnC,OAAO,CAAC,kBAAkB;CAG3B"}
File without changes
File without changes